X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fplaylist.h;h=76055bea0341c6ac2c831a11c0cf417de91fce5a;hb=3b932abd0c7634483911e1d5361e12b2d094ae6f;hp=3a7ca73bf3dcf4f3e772c024ab41c8c92439e5b6;hpb=883d885dc8690519d205c8baa275385af8a39f4b;p=dcpomatic.git diff --git a/src/lib/playlist.h b/src/lib/playlist.h index 3a7ca73bf..76055bea0 100644 --- a/src/lib/playlist.h +++ b/src/lib/playlist.h @@ -20,87 +20,69 @@ #ifndef DCPOMATIC_PLAYLIST_H #define DCPOMATIC_PLAYLIST_H -#include +#include "util.h" +#include "frame_rate_change.h" +#include #include -#include -#include "video_source.h" -#include "audio_source.h" -#include "video_sink.h" -#include "audio_sink.h" -#include "ffmpeg_content.h" -#include "audio_mapping.h" - -class Content; -class FFmpegContent; -class FFmpegDecoder; -class ImageMagickContent; -class ImageMagickDecoder; -class SndfileContent; -class SndfileDecoder; -class Job; -class Film; -class Region; +#include +#include -/** @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 Film; struct ContentSorter { bool operator() (boost::shared_ptr a, boost::shared_ptr b); }; -class Playlist +/** @class Playlist + * @brief A set of Content objects with knowledge of how they should be arranged into + * a DCP. + */ +class Playlist : public boost::noncopyable { public: Playlist (); - Playlist (boost::shared_ptr); ~Playlist (); void as_xml (xmlpp::Node *); - void set_from_xml (boost::shared_ptr, boost::shared_ptr); + void set_from_xml (boost::shared_ptr, cxml::ConstNodePtr, int, std::list &); void add (boost::shared_ptr); void remove (boost::shared_ptr); + void remove (ContentList); + void move_earlier (boost::shared_ptr); + void move_later (boost::shared_ptr); - bool has_subtitles () const; + ContentList content () const; - typedef std::vector > ContentList; - - ContentList content () const { - return _content; - } + std::string video_identifier () const; - std::string audio_digest () const; - std::string video_digest () const; + DCPTime length () const; + boost::optional start () const; - int loop () const { - return _loop; - } - - void set_loop (int l); - - Time length () const; int best_dcp_frame_rate () const; - Time video_end () const; + DCPTime video_end () const; + FrameRateChange active_frame_rate_change (DCPTime, int dcp_frame_rate) const; void set_sequence_video (bool); + void maybe_sequence_video (); + + void repeat (ContentList, int); + /** Emitted when content has been added to or removed from the playlist */ mutable boost::signals2::signal Changed; - mutable boost::signals2::signal, int)> ContentChanged; - + /** Emitted when something about a piece of our content has changed; + * these emissions include when the position of the content changes. + * Third parameter is true if signals are currently being emitted frequently. + */ + mutable boost::signals2::signal, int, bool)> ContentChanged; + private: - void content_changed (boost::weak_ptr, int); + void content_changed (boost::weak_ptr, int, bool); void reconnect (); + /** List of content. Kept sorted in position order. */ ContentList _content; - int _loop; bool _sequence_video; bool _sequencing_video; std::list _content_connections;