Merge master.
[dcpomatic.git] / src / lib / playlist.h
index 1d189cb070be9077f0ac241fcbefcf190366ac03..e6acff6944472db7e45827237914f1279c1c1a93 100644 (file)
@@ -37,17 +37,33 @@ class SndfileDecoder;
 class Job;
 class Film;
 
+/** @class Playlist
+ *  @brief A set of content files (video and audio), with knowledge of how they should be arranged into
+ *  a DCP.
+ *
+ * This class holds Content objects, and it knows how they should be arranged.  At the moment
+ * the ordering is implicit; video content is placed sequentially, and audio content is taken
+ * from the video unless any sound-only files are present.  If sound-only files exist, they
+ * are played simultaneously (i.e. they can be split up into multiple files for different channels)
+ */
+    
 class Playlist
 {
 public:
        Playlist ();
+       Playlist (boost::shared_ptr<const Playlist>);
 
-       void setup (ContentList);
+       void as_xml (xmlpp::Node *);
+       void set_from_xml (boost::shared_ptr<const cxml::Node>);
+
+       void add (boost::shared_ptr<Content>);
+       void remove (boost::shared_ptr<Content>);
+       void move_earlier (boost::shared_ptr<Content>);
+       void move_later (boost::shared_ptr<Content>);
 
        ContentAudioFrame audio_length () const;
        int audio_channels () const;
        int audio_frame_rate () const;
-       int64_t audio_channel_layout () const;
        bool has_audio () const;
        
        float video_frame_rate () const;
@@ -55,51 +71,62 @@ public:
        ContentVideoFrame video_length () const;
 
        AudioMapping default_audio_mapping () const;
-
-       enum VideoFrom {
-               VIDEO_NONE,
-               VIDEO_FFMPEG,
-               VIDEO_IMAGEMAGICK
-       };
+       ContentVideoFrame content_length () const;
 
        enum AudioFrom {
-               AUDIO_NONE,
                AUDIO_FFMPEG,
                AUDIO_SNDFILE
        };
 
-       VideoFrom video_from () const {
-               return _video_from;
-       }
-
        AudioFrom audio_from () const {
                return _audio_from;
        }
 
-       boost::shared_ptr<const FFmpegContent> ffmpeg () const {
-               return _ffmpeg;
+       bool has_subtitles () const;
+       
+       ContentList content () const {
+               return _content;
+       }
+
+       boost::shared_ptr<FFmpegContent> ffmpeg () const;
+
+       std::list<boost::shared_ptr<const VideoContent> > video () const {
+               return _video;
        }
 
-       std::list<boost::shared_ptr<const ImageMagickContent> > imagemagick () const {
-               return _imagemagick;
+       std::list<boost::shared_ptr<const AudioContent> > audio () const {
+               return _audio;
        }
 
-       std::list<boost::shared_ptr<const SndfileContent> > sndfile () const {
-               return _sndfile;
+       std::string audio_digest () const;
+       std::string video_digest () const;
+
+       int loop () const {
+               return _loop;
        }
+       
+       void set_loop (int l);
 
        mutable boost::signals2::signal<void ()> Changed;
        mutable boost::signals2::signal<void (boost::weak_ptr<Content>, int)> ContentChanged;
        
 private:
+       void setup ();
        void content_changed (boost::weak_ptr<Content>, int);
-       
-       VideoFrom _video_from;
+
+       /** where we should get our audio from */
        AudioFrom _audio_from;
 
-       boost::shared_ptr<const FFmpegContent> _ffmpeg;
-       std::list<boost::shared_ptr<const ImageMagickContent> > _imagemagick;
-       std::list<boost::shared_ptr<const SndfileContent> > _sndfile;
+       /** all our content */
+       ContentList _content;
+       /** all our content which contains video */
+       std::list<boost::shared_ptr<const VideoContent> > _video;
+       /** all our content which contains audio.  This may contain the same objects
+        *  as _video for FFmpegContent.
+        */
+       std::list<boost::shared_ptr<const AudioContent> > _audio;
+
+       int _loop;
 
        std::list<boost::signals2::connection> _content_connections;
 };