More noncopyable.
[dcpomatic.git] / src / lib / playlist.h
index 9a2627b1d06c96a41217083469cf6a649d8234b4..5346dd5e7488591d7aabbfb7f722e0946e71c8dd 100644 (file)
 
 */
 
+#ifndef DCPOMATIC_PLAYLIST_H
+#define DCPOMATIC_PLAYLIST_H
+
 #include <list>
 #include <boost/shared_ptr.hpp>
 #include <boost/enable_shared_from_this.hpp>
-#include "video_source.h"
-#include "audio_source.h"
-#include "video_sink.h"
-#include "audio_sink.h"
 #include "ffmpeg_content.h"
 #include "audio_mapping.h"
 
@@ -36,6 +35,7 @@ class SndfileContent;
 class SndfileDecoder;
 class Job;
 class Film;
+class Region;
 
 /** @class Playlist
  *  @brief A set of content files (video and audio), with knowledge of how they should be arranged into
@@ -46,60 +46,60 @@ class Film;
  * 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
+
+struct ContentSorter
+{
+       bool operator() (boost::shared_ptr<Content> a, boost::shared_ptr<Content> b);
+};
+
+class Playlist : public boost::noncopyable
 {
 public:
        Playlist ();
+       ~Playlist ();
 
-       void setup (ContentList);
-
-       ContentAudioFrame audio_length () const;
-       int audio_channels () const;
-       int audio_frame_rate () const;
-       bool has_audio () const;
-       
-       float video_frame_rate () const;
-       libdcp::Size video_size () const;
-       ContentVideoFrame video_length () const;
+       void as_xml (xmlpp::Node *);
+       void set_from_xml (boost::shared_ptr<const Film>, boost::shared_ptr<const cxml::Node>);
 
-       AudioMapping default_audio_mapping () const;
+       void add (boost::shared_ptr<Content>);
+       void remove (boost::shared_ptr<Content>);
 
-       enum AudioFrom {
-               AUDIO_FFMPEG,
-               AUDIO_SNDFILE
-       };
+       bool has_subtitles () const;
 
-       AudioFrom audio_from () const {
-               return _audio_from;
+       typedef std::vector<boost::shared_ptr<Content> > ContentList;
+       
+       ContentList content () const {
+               return _content;
        }
 
-       std::list<boost::shared_ptr<const VideoContent> > video () const {
-               return _video;
-       }
+       std::string video_identifier () const;
 
-       std::list<boost::shared_ptr<const AudioContent> > audio () const {
-               return _audio;
+       int loop () const {
+               return _loop;
        }
+       
+       void set_loop (int l);
+
+       Time length () const;
+       int best_dcp_frame_rate () const;
+       Time video_end () const;
 
-       std::string audio_digest () const;
-       std::string video_digest () const;
+       void set_sequence_video (bool);
+       void maybe_sequence_video ();
 
        mutable boost::signals2::signal<void ()> Changed;
-       mutable boost::signals2::signal<void (boost::weak_ptr<Content>, int)> ContentChanged;
+       /** Third parameter is true if signals are currently being emitted frequently */
+       mutable boost::signals2::signal<void (boost::weak_ptr<Content>, int, bool)> ContentChanged;
        
 private:
-       void content_changed (boost::weak_ptr<Content>, int);
-
-       /** where we should get our audio from */
-       AudioFrom _audio_from;
-
-       /** 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;
+       void content_changed (boost::weak_ptr<Content>, int, bool);
+       void reconnect ();
 
+       ContentList _content;
+       int _loop;
+       bool _sequence_video;
+       bool _sequencing_video;
        std::list<boost::signals2::connection> _content_connections;
 };
+
+#endif