summaryrefslogtreecommitdiff
path: root/src/lib/audio_source.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2013-04-29 14:46:20 +0100
committerCarl Hetherington <cth@carlh.net>2013-04-29 14:46:20 +0100
commitdbc43b6e3021e34875d7d5bba04abf7ad1fc8633 (patch)
tree38258ef9b5f844e62c6060499f3a2a5cb60b4aa9 /src/lib/audio_source.cc
parent28dbf4fd074d2046a3c8ddebac9a537a80fd457a (diff)
More cycle-breaking of shared_ptr for decoder / player.
Diffstat (limited to 'src/lib/audio_source.cc')
-rw-r--r--src/lib/audio_source.cc18
1 files changed, 14 insertions, 4 deletions
diff --git a/src/lib/audio_source.cc b/src/lib/audio_source.cc
index 32b3deccf..2867bcc24 100644
--- a/src/lib/audio_source.cc
+++ b/src/lib/audio_source.cc
@@ -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));
}
+