Handle video frame rates and subtitles a bit more correctly.
[dcpomatic.git] / src / lib / dcp_content.h
index b4aebc45eb5b83ae0bd1e4ada68e079c41a016b1..0f59bdf43e1f6aaee16d3e3835b0098e5b91f65f 100644 (file)
@@ -34,6 +34,9 @@ class DCPContentProperty
 {
 public:
        static int const CAN_BE_PLAYED;
+       static int const REFERENCE_VIDEO;
+       static int const REFERENCE_AUDIO;
+       static int const REFERENCE_SUBTITLE;
 };
 
 /** @class DCPContent
@@ -57,6 +60,8 @@ public:
        void as_xml (xmlpp::Node *) const;
        std::string identifier () const;
 
+       void set_default_colour_conversion ();
+
        /* SubtitleContent */
 
        bool has_text_subtitles () const {
@@ -68,6 +73,10 @@ public:
                return false;
        }
 
+       double subtitle_video_frame_rate () const {
+               return video_frame_rate ();
+       }
+
        boost::filesystem::path directory () const;
 
        bool encrypted () const {
@@ -83,6 +92,27 @@ public:
 
        bool can_be_played () const;
 
+       void set_reference_video (bool r);
+
+       bool reference_video () const {
+               boost::mutex::scoped_lock lm (_mutex);
+               return _reference_video;
+       }
+
+       void set_reference_audio (bool r);
+
+       bool reference_audio () const {
+               boost::mutex::scoped_lock lm (_mutex);
+               return _reference_audio;
+       }
+
+       void set_reference_subtitle (bool r);
+
+       bool reference_subtitle () const {
+               boost::mutex::scoped_lock lm (_mutex);
+               return _reference_subtitle;
+       }
+
 protected:
        void add_properties (std::list<std::pair<std::string, std::string> >& p) const;
 
@@ -96,6 +126,18 @@ private:
        boost::optional<dcp::EncryptedKDM> _kdm;
        /** true if _kdm successfully decrypts the first frame of our DCP */
        bool _kdm_valid;
+       /** true if the video in this DCP should be included in the output by reference
+        *  rather than by rewrapping.
+        */
+       bool _reference_video;
+       /** true if the audio in this DCP should be included in the output by reference
+        *  rather than by rewrapping.
+        */
+       bool _reference_audio;
+       /** true if the subtitle in this DCP should be included in the output by reference
+        *  rather than by rewrapping.
+        */
+       bool _reference_subtitle;
 };
 
 #endif