Add a log message and actually use device_for_write().
[dcpomatic.git] / src / lib / empty.cc
index 1df318b25275a2a634fe45ef21017e28889859cf..c145c231bc02c1cef932282602aa7f8e0b27ce5b 100644 (file)
@@ -34,17 +34,18 @@ using std::list;
 using boost::shared_ptr;
 using boost::dynamic_pointer_cast;
 using boost::function;
+using namespace dcpomatic;
 
-Empty::Empty (shared_ptr<const Film> film, list<shared_ptr<Piece> > pieces, function<bool (shared_ptr<Piece>)> part)
+Empty::Empty (shared_ptr<const Film> film, shared_ptr<const Playlist> playlist, function<bool (shared_ptr<const Content>)> part, DCPTime length)
 {
        list<DCPTimePeriod> full;
-       BOOST_FOREACH (shared_ptr<Piece> i, pieces) {
+       BOOST_FOREACH (shared_ptr<Content> i, playlist->content()) {
                if (part(i)) {
-                       full.push_back (DCPTimePeriod (i->content->position(), i->content->end(film)));
+                       full.push_back (DCPTimePeriod (i->position(), i->end(film)));
                }
        }
 
-       _periods = subtract (DCPTimePeriod(DCPTime(), film->length()), coalesce(full));
+       _periods = subtract (DCPTimePeriod(DCPTime(), length), coalesce(full));
 
        if (!_periods.empty ()) {
                _position = _periods.front().from;