Index: media/base/audio_renderer_mixer.h |
diff --git a/media/base/audio_renderer_mixer.h b/media/base/audio_renderer_mixer.h |
index 942c61fe8495cd3b0a921bf0a12dc7da10269b29..4b0af9b4e3f60034098d9fa3dcb19f597a3d9795 100644 |
--- a/media/base/audio_renderer_mixer.h |
+++ b/media/base/audio_renderer_mixer.h |
@@ -26,10 +26,15 @@ class MEDIA_EXPORT AudioRendererMixer |
virtual ~AudioRendererMixer(); |
// Add or remove a mixer input from mixing; called by AudioRendererMixerInput. |
- void AddMixerInput(AudioConverter::InputCallback* input, |
- const base::Closure& error_cb); |
+ void AddMixerInput(AudioConverter::InputCallback* input); |
void RemoveMixerInput(AudioConverter::InputCallback* input); |
+ // Since errors may occur even when no inputs are playing, an error callback |
+ // must be registered separately from adding a mixer input. The same callback |
+ // must be given to both the functions. |
+ void AddErrorCallback(const base::Closure& error_cb); |
+ void RemoveErrorCallback(const base::Closure& error_cb); |
+ |
void set_pause_delay_for_testing(base::TimeDelta delay) { |
pause_delay_ = delay; |
} |
@@ -43,12 +48,12 @@ class MEDIA_EXPORT AudioRendererMixer |
// Output sink for this mixer. |
scoped_refptr<AudioRendererSink> audio_sink_; |
- // Set of mixer inputs to be mixed by this mixer. Access is thread-safe |
- // through |mixer_inputs_lock_|. |
- typedef std::map<AudioConverter::InputCallback*, base::Closure> |
- AudioRendererMixerInputSet; |
- AudioRendererMixerInputSet mixer_inputs_; |
- base::Lock mixer_inputs_lock_; |
+ // ---------------[ All variables below protected by |lock_| ]--------------- |
+ base::Lock lock_; |
+ |
+ // List of error callbacks used by this mixer. |
+ typedef std::list<base::Closure> ErrorCallbackList; |
+ ErrorCallbackList error_callbacks_; |
// Handles mixing and resampling between input and output parameters. |
AudioConverter audio_converter_; |