More cycle-breaking of shared_ptr for decoder / player.
authorCarl Hetherington <cth@carlh.net>
Mon, 29 Apr 2013 13:46:20 +0000 (14:46 +0100)
committerCarl Hetherington <cth@carlh.net>
Mon, 29 Apr 2013 13:46:20 +0000 (14:46 +0100)
src/lib/audio_source.cc
src/lib/video_source.cc

index 32b3deccfa4a887384d7c834eb1d9d2bcf0c039b..2867bcc244795216412446481b7ea790def7652d 100644 (file)
@@ -40,13 +40,23 @@ AudioSource::connect_audio (shared_ptr<AudioSink> s)
 }
 
 void
-TimedAudioSource::connect_audio (shared_ptr<TimedAudioSink> s)
+TimedAudioSource::connect_audio (shared_ptr<AudioSink> s)
+{
+       Audio.connect (bind (process_audio_proxy, weak_ptr<AudioSink> (s), _1));
+}
+
+static void
+timed_process_audio_proxy (weak_ptr<TimedAudioSink> sink, shared_ptr<const AudioBuffers> audio, double t)
 {
-       Audio.connect (bind (&TimedAudioSink::process_audio, s, _1, _2));
+       shared_ptr<TimedAudioSink> p = sink.lock ();
+       if (p) {
+               p->process_audio (audio, t);
+       }
 }
 
 void
-TimedAudioSource::connect_audio (shared_ptr<AudioSink> s)
+TimedAudioSource::connect_audio (shared_ptr<TimedAudioSink> s)
 {
-       Audio.connect (bind (&AudioSink::process_audio, s, _1));
+       Audio.connect (bind (timed_process_audio_proxy, weak_ptr<TimedAudioSink> (s), _1, _2));
 }
+
index 2de4db68d75657a55a2a05f49a0a86914781f908..4d505f9fea647687c48396235b1bc0dae520a86c 100644 (file)
@@ -36,22 +36,29 @@ process_video_proxy (weak_ptr<VideoSink> sink, shared_ptr<const Image> i, bool 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<TimedVideoSink> s)
+TimedVideoSource::connect_video (shared_ptr<VideoSink> s)
 {
-       Video.connect (bind (&TimedVideoSink::process_video, s, _1, _2, _3, _4));
+       Video.connect (bind (process_video_proxy, weak_ptr<VideoSink> (s), _1, _2, _3));
 }
 
-void
-TimedVideoSource::connect_video (shared_ptr<VideoSink> s)
+static void
+timed_process_video_proxy (weak_ptr<TimedVideoSink> sink, shared_ptr<const Image> i, bool same, shared_ptr<Subtitle> s, double t)
 {
-       Video.connect (bind (&VideoSink::process_video, s, _1, _2, _3));
+       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));
+}