*/
-#include <dcp/dcp.h>
-#include <dcp/exceptions.h>
#include "dcp_content.h"
#include "dcp_examiner.h"
#include "job.h"
#include "film.h"
#include "config.h"
#include "compose.hpp"
+#include <dcp/dcp.h>
+#include <dcp/exceptions.h>
+#include <iterator>
#include "i18n.h"
using std::string;
using std::cout;
+using std::distance;
using boost::shared_ptr;
using boost::optional;
, SubtitleContent (f)
, _has_subtitles (false)
, _encrypted (false)
- , _directory (p)
, _kdm_valid (false)
{
read_directory (p);
+ /* Default to no colour conversion for DCPs */
+ unset_colour_conversion (false);
}
DCPContent::DCPContent (shared_ptr<const Film> f, cxml::ConstNodePtr node, int version)
{
_name = node->string_child ("Name");
_has_subtitles = node->bool_child ("HasSubtitles");
- _directory = node->string_child ("Directory");
_encrypted = node->bool_child ("Encrypted");
if (node->optional_node_child ("KDM")) {
_kdm = dcp::EncryptedKDM (node->string_child ("KDM"));
}
void
-DCPContent::examine (shared_ptr<Job> job, bool calculate_digest)
+DCPContent::examine (shared_ptr<Job> job)
{
bool const could_be_played = can_be_played ();
job->set_progress_unknown ();
- Content::examine (job, calculate_digest);
+ Content::examine (job);
shared_ptr<DCPExaminer> examiner (new DCPExaminer (shared_from_this ()));
take_from_video_examiner (examiner);
node->add_child("Name")->add_child_text (_name);
node->add_child("HasSubtitles")->add_child_text (_has_subtitles ? "1" : "0");
node->add_child("Encrypted")->add_child_text (_encrypted ? "1" : "0");
- node->add_child("Directory")->add_child_text (_directory.string ());
if (_kdm) {
node->add_child("KDM")->add_child_text (_kdm->as_xml ());
}
DCPContent::full_length () const
{
shared_ptr<const Film> film = _film.lock ();
- assert (film);
+ DCPOMATIC_ASSERT (film);
return DCPTime (video_length (), FrameRateChange (video_frame_rate (), film->video_frame_rate ()));
}
{
return !_encrypted || _kdm_valid;
}
+
+boost::filesystem::path
+DCPContent::directory () const
+{
+ optional<size_t> smallest;
+ boost::filesystem::path dir;
+ for (size_t i = 0; i < number_of_paths(); ++i) {
+ boost::filesystem::path const p = path (i).parent_path ();
+ size_t const d = distance (p.begin(), p.end());
+ if (!smallest || d < smallest.get ()) {
+ dir = p;
+ }
+ }
+
+ return dir;
+}