X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fplaylist.cc;h=7c8ca0530a8f357f911df8d5b96e0b502a1ca3a8;hb=bdbe925a467f9b7149322ad8d1c090d4c1e6d5c3;hp=89421097cd26829647ebf079e3805dcd4916a08d;hpb=14e4bc18e65378332604016bd6239861a083d5bf;p=dcpomatic.git diff --git a/src/lib/playlist.cc b/src/lib/playlist.cc index 89421097c..7c8ca0530 100644 --- a/src/lib/playlist.cc +++ b/src/lib/playlist.cc @@ -32,6 +32,8 @@ #include #include #include +#include +#include #include "i18n.h" @@ -87,8 +89,8 @@ Playlist::maybe_sequence_video () DCPTime next_left; DCPTime next_right; - for (ContentList::iterator i = _content.begin(); i != _content.end(); ++i) { - shared_ptr vc = dynamic_pointer_cast (*i); + BOOST_FOREACH (shared_ptr i, _content) { + shared_ptr vc = dynamic_pointer_cast (i); if (!vc) { continue; } @@ -112,9 +114,9 @@ Playlist::video_identifier () const { string t; - for (ContentList::const_iterator i = _content.begin(); i != _content.end(); ++i) { - shared_ptr vc = dynamic_pointer_cast (*i); - shared_ptr sc = dynamic_pointer_cast (*i); + BOOST_FOREACH (shared_ptr i, _content) { + shared_ptr vc = dynamic_pointer_cast (i); + shared_ptr sc = dynamic_pointer_cast (i); if (vc) { t += vc->identifier (); } else if (sc && sc->burn_subtitles ()) { @@ -131,9 +133,8 @@ Playlist::video_identifier () const void Playlist::set_from_xml (shared_ptr film, cxml::ConstNodePtr node, int version, list& notes) { - list c = node->node_children ("Content"); - for (list::iterator i = c.begin(); i != c.end(); ++i) { - _content.push_back (content_factory (film, *i, version, notes)); + BOOST_FOREACH (cxml::NodePtr i, node->node_children ("Content")) { + _content.push_back (content_factory (film, i, version, notes)); } sort (_content.begin(), _content.end(), ContentSorter ()); @@ -145,8 +146,8 @@ Playlist::set_from_xml (shared_ptr film, cxml::ConstNodePtr node, in void Playlist::as_xml (xmlpp::Node* node) { - for (ContentList::iterator i = _content.begin(); i != _content.end(); ++i) { - (*i)->as_xml (node->add_child ("Content")); + BOOST_FOREACH (shared_ptr i, _content) { + i->as_xml (node->add_child ("Content")); } } @@ -178,9 +179,9 @@ Playlist::remove (shared_ptr c) void Playlist::remove (ContentList c) { - for (ContentList::iterator i = c.begin(); i != c.end(); ++i) { + BOOST_FOREACH (shared_ptr i, c) { ContentList::iterator j = _content.begin (); - while (j != _content.end() && *j != *i) { + while (j != _content.end() && *j != i) { ++j; } @@ -232,8 +233,8 @@ Playlist::best_dcp_frame_rate () const while (i != candidates.end()) { float this_error = 0; - for (ContentList::const_iterator j = _content.begin(); j != _content.end(); ++j) { - shared_ptr vc = dynamic_pointer_cast (*j); + BOOST_FOREACH (shared_ptr j, _content) { + shared_ptr vc = dynamic_pointer_cast (j); if (!vc) { continue; } @@ -263,17 +264,34 @@ Playlist::best_dcp_frame_rate () const return best->dcp; } +/** @return length of the playlist from time 0 to the last thing on the playlist */ DCPTime Playlist::length () const { DCPTime len; - for (ContentList::const_iterator i = _content.begin(); i != _content.end(); ++i) { - len = max (len, (*i)->end()); + BOOST_FOREACH (shared_ptr i, _content) { + len = max (len, i->end()); } return len; } +/** @return position of the first thing on the playlist, if it's not empty */ +optional +Playlist::start () const +{ + if (_content.empty ()) { + return optional (); + } + + DCPTime start = DCPTime::max (); + BOOST_FOREACH (shared_ptr i, _content) { + start = min (start, i->position ()); + } + + return start; +} + void Playlist::reconnect () { @@ -283,8 +301,8 @@ Playlist::reconnect () _content_connections.clear (); - for (ContentList::iterator i = _content.begin(); i != _content.end(); ++i) { - _content_connections.push_back ((*i)->Changed.connect (bind (&Playlist::content_changed, this, _1, _2, _3))); + BOOST_FOREACH (shared_ptr i, _content) { + _content_connections.push_back (i->Changed.connect (bind (&Playlist::content_changed, this, _1, _2, _3))); } } @@ -292,9 +310,9 @@ DCPTime Playlist::video_end () const { DCPTime end; - for (ContentList::const_iterator i = _content.begin(); i != _content.end(); ++i) { - if (dynamic_pointer_cast (*i)) { - end = max (end, (*i)->end ()); + BOOST_FOREACH (shared_ptr i, _content) { + if (dynamic_pointer_cast (i)) { + end = max (end, i->end ()); } } @@ -344,17 +362,17 @@ void Playlist::repeat (ContentList c, int n) { pair range (DCPTime::max (), DCPTime ()); - for (ContentList::iterator i = c.begin(); i != c.end(); ++i) { - range.first = min (range.first, (*i)->position ()); - range.second = max (range.second, (*i)->position ()); - range.first = min (range.first, (*i)->end ()); - range.second = max (range.second, (*i)->end ()); + BOOST_FOREACH (shared_ptr i, c) { + range.first = min (range.first, i->position ()); + range.second = max (range.second, i->position ()); + range.first = min (range.first, i->end ()); + range.second = max (range.second, i->end ()); } DCPTime pos = range.second; for (int i = 0; i < n; ++i) { - for (ContentList::iterator i = c.begin(); i != c.end(); ++i) { - shared_ptr copy = (*i)->clone (); + BOOST_FOREACH (shared_ptr j, c) { + shared_ptr copy = j->clone (); copy->set_position (pos + copy->position() - range.first); _content.push_back (copy); }