Logging improvements to allow prettier displays in the server GUI.
[dcpomatic.git] / src / lib / dcp_content.h
index aa53d76a9d32aa694cf7d6fb4114aa6f7ceadbc5..0f59bdf43e1f6aaee16d3e3835b0098e5b91f65f 100644 (file)
 #include "subtitle_content.h"
 #include <libcxml/cxml.h>
 #include <dcp/encrypted_kdm.h>
-#include <dcp/decrypted_kdm.h>
 
 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
@@ -43,32 +45,40 @@ public:
 class DCPContent : public VideoContent, public SingleStreamAudioContent, public SubtitleContent
 {
 public:
-       DCPContent (boost::shared_ptr<const Film> f, boost::filesystem::path p);
-       DCPContent (boost::shared_ptr<const Film> f, cxml::ConstNodePtr, int version);
+       DCPContent (boost::shared_ptr<const Film>, boost::filesystem::path p);
+       DCPContent (boost::shared_ptr<const Film>, cxml::ConstNodePtr, int version);
 
        boost::shared_ptr<DCPContent> shared_from_this () {
                return boost::dynamic_pointer_cast<DCPContent> (Content::shared_from_this ());
        }
 
        DCPTime full_length () const;
-       
+
        void examine (boost::shared_ptr<Job>);
        std::string summary () const;
        std::string technical_summary () const;
        void as_xml (xmlpp::Node *) const;
        std::string identifier () const;
 
+       void set_default_colour_conversion ();
+
        /* SubtitleContent */
-       bool has_subtitles () const {
+
+       bool has_text_subtitles () const {
                boost::mutex::scoped_lock lm (_mutex);
                return _has_subtitles;
        }
-       
-       boost::filesystem::path directory () const {
-               boost::mutex::scoped_lock lm (_mutex);
-               return _directory;
+
+       bool has_image_subtitles () const {
+               return false;
+       }
+
+       double subtitle_video_frame_rate () const {
+               return video_frame_rate ();
        }
 
+       boost::filesystem::path directory () const;
+
        bool encrypted () const {
                boost::mutex::scoped_lock lm (_mutex);
                return _encrypted;
@@ -81,18 +91,53 @@ 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;
+
 private:
        void read_directory (boost::filesystem::path);
-       
+
        std::string _name;
        bool _has_subtitles;
        /** true if our DCP is encrypted */
        bool _encrypted;
-       boost::filesystem::path _directory;
        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