Merge master.
[dcpomatic.git] / src / lib / video_source.cc
index 1c4d6466cbd5c159bbcdd81de23745821b700080..4d505f9fea647687c48396235b1bc0dae520a86c 100644 (file)
@@ -25,7 +25,7 @@ using boost::weak_ptr;
 using boost::bind;
 
 static void
-process_video_proxy (weak_ptr<VideoSink> sink, shared_ptr<Image> i, bool same, shared_ptr<Subtitle> s)
+process_video_proxy (weak_ptr<VideoSink> sink, shared_ptr<const Image> i, bool same, shared_ptr<Subtitle> s)
 {
        shared_ptr<VideoSink> p = sink.lock ();
        if (p) {
@@ -36,8 +36,29 @@ process_video_proxy (weak_ptr<VideoSink> sink, shared_ptr<Image> i, bool same, s
 void
 VideoSource::connect_video (shared_ptr<VideoSink> s)
 {
-       /* If we bind, say, a Playlist (as the VideoSink) to a Decoder (which is owned
-          by the Playlist) we create a cycle.  Use a weak_ptr to break it.
+       /* If we bind, say, a Player (as the VideoSink) to a Decoder (which is owned
+          by the Player) we create a cycle.  Use a weak_ptr to break it.
        */
-       Video.connect (bind (process_video_proxy, boost::weak_ptr<VideoSink> (s), _1, _2, _3));
+       Video.connect (bind (process_video_proxy, weak_ptr<VideoSink> (s), _1, _2, _3));
+}
+
+void
+TimedVideoSource::connect_video (shared_ptr<VideoSink> s)
+{
+       Video.connect (bind (process_video_proxy, weak_ptr<VideoSink> (s), _1, _2, _3));
+}
+
+static void
+timed_process_video_proxy (weak_ptr<TimedVideoSink> sink, shared_ptr<const Image> i, bool same, shared_ptr<Subtitle> s, double t)
+{
+       shared_ptr<TimedVideoSink> p = sink.lock ();
+       if (p) {
+               p->process_video (i, same, s, t);
+       }
+}
+
+void
+TimedVideoSource::connect_video (shared_ptr<TimedVideoSink> s)
+{
+       Video.connect (bind (timed_process_video_proxy, weak_ptr<TimedVideoSink> (s), _1, _2, _3, _4));
 }