Chromium Code Reviews| Index: content/renderer/media/media_stream_audio_track.cc |
| diff --git a/content/renderer/media/media_stream_audio_track.cc b/content/renderer/media/media_stream_audio_track.cc |
| index 278ab05bb107369cdd23614565470e40846a3518..587b68214331954d652deecebfc7bc3eaf3dc5e8 100644 |
| --- a/content/renderer/media/media_stream_audio_track.cc |
| +++ b/content/renderer/media/media_stream_audio_track.cc |
| @@ -12,13 +12,19 @@ namespace content { |
| MediaStreamAudioTrack::MediaStreamAudioTrack(bool is_local_track) |
| : MediaStreamTrack(is_local_track) { |
| + DVLOG(1) << "MediaStreamAudioTrack::MediaStreamAudioTrack(is a " |
| + << (is_local_track ? "local" : "remote") << " track)"; |
| } |
| MediaStreamAudioTrack::~MediaStreamAudioTrack() { |
| + DCHECK(main_render_thread_checker_.CalledOnValidThread()); |
| + DVLOG(1) << "MediaStreamAudioTrack::~MediaStreamAudioTrack()"; |
| + Stop(); |
|
o1ka
2016/02/29 14:28:04
If you add a method of a child class as a stop obs
miu
2016/03/01 09:43:54
Yes, you're right. I had mitigated that by having
o1ka
2016/03/01 14:18:58
Though I had the same idea initially, the more I l
miu
2016/03/02 01:12:50
Done. I also re-evaluated why I needed to add mul
o1ka
2016/03/02 16:31:13
Looks good!
|
| + DCHECK(stop_callbacks_.empty()); |
| } |
| // static |
| -MediaStreamAudioTrack* MediaStreamAudioTrack::GetTrack( |
| +MediaStreamAudioTrack* MediaStreamAudioTrack::From( |
| const blink::WebMediaStreamTrack& track) { |
| if (track.isNull() || |
| track.source().type() != blink::WebMediaStreamSource::TypeAudio) { |
| @@ -27,6 +33,23 @@ MediaStreamAudioTrack* MediaStreamAudioTrack::GetTrack( |
| return static_cast<MediaStreamAudioTrack*>(track.extraData()); |
| } |
| +void MediaStreamAudioTrack::AddStopObserver( |
| + const base::Closure& stop_callback) { |
| + DCHECK(main_render_thread_checker_.CalledOnValidThread()); |
| + DCHECK(!stop_callback.is_null()); |
| + DVLOG(1) << "MediaStreamAudioTrack::AddStopObserver()"; |
| + stop_callbacks_.push_back(stop_callback); |
| +} |
| + |
| +void MediaStreamAudioTrack::Stop() { |
| + DCHECK(main_render_thread_checker_.CalledOnValidThread()); |
| + DVLOG(1) << "MediaStreamAudioTrack::Stop()"; |
| + std::vector<base::Closure> callbacks_to_run; |
| + callbacks_to_run.swap(stop_callbacks_); |
| + for (const base::Closure& callback : callbacks_to_run) |
| + callback.Run(); |
| +} |
| + |
| webrtc::AudioTrackInterface* MediaStreamAudioTrack::GetAudioAdapter() { |
| NOTREACHED(); |
| return nullptr; |