/* Copyright (C) 2013-2016 Carl Hetherington This file is part of DCP-o-matic. DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with DCP-o-matic. If not, see . */ #ifndef DCPOMATIC_PLAYLIST_H #define DCPOMATIC_PLAYLIST_H #include "util.h" #include "frame_rate_change.h" #include #include #include #include class Film; struct ContentSorter { bool operator() (boost::shared_ptr a, boost::shared_ptr b); }; /** @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 (); void as_xml (xmlpp::Node *, bool with_content_paths); void set_from_xml (boost::shared_ptr film, cxml::ConstNodePtr node, int version, std::list& notes); 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); ContentList content () const; std::string video_identifier () const; DCPTime length () const; boost::optional start () const; int64_t required_disk_space (int j2k_bandwidth, int audio_channels, int audio_frame_rate) const; int best_video_frame_rate () const; DCPTime video_end () const; DCPTime subtitle_end () const; FrameRateChange active_frame_rate_change (DCPTime, int dcp_frame_rate) const; std::string content_summary (DCPTimePeriod period) const; std::pair speed_up_range (int dcp_video_frame_rate) const; void set_sequence (bool); void maybe_sequence (); void repeat (ContentList, int); /** Emitted when content has been added to or removed from the playlist; implies OrderChanged */ mutable boost::signals2::signal Changed; mutable boost::signals2::signal OrderChanged; /** 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, bool); void reconnect (); /** List of content. Kept sorted in position order. */ ContentList _content; bool _sequence; bool _sequencing; std::list _content_connections; }; #endif