OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "content/renderer/media/media_stream_audio_track.h" | 5 #include "content/renderer/media/media_stream_audio_track.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h" | 8 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h" |
9 #include "third_party/webrtc/api/mediastreaminterface.h" | 9 #include "third_party/webrtc/api/mediastreaminterface.h" |
10 | 10 |
11 namespace content { | 11 namespace content { |
12 | 12 |
13 MediaStreamAudioTrack::MediaStreamAudioTrack(bool is_local_track) | 13 MediaStreamAudioTrack::MediaStreamAudioTrack(bool is_local_track) |
14 : MediaStreamTrack(is_local_track) { | 14 : MediaStreamTrack(is_local_track) { |
15 DVLOG(1) << "MediaStreamAudioTrack::MediaStreamAudioTrack(is a " | |
16 << (is_local_track ? "local" : "remote") << " track)"; | |
15 } | 17 } |
16 | 18 |
17 MediaStreamAudioTrack::~MediaStreamAudioTrack() { | 19 MediaStreamAudioTrack::~MediaStreamAudioTrack() { |
20 DCHECK(main_render_thread_checker_.CalledOnValidThread()); | |
21 DVLOG(1) << "MediaStreamAudioTrack::~MediaStreamAudioTrack()"; | |
22 DCHECK(stop_callback_.is_null()) | |
23 << "BUG: Subclass must ensure Stop() is called."; | |
18 } | 24 } |
19 | 25 |
20 // static | 26 // static |
21 MediaStreamAudioTrack* MediaStreamAudioTrack::GetTrack( | 27 MediaStreamAudioTrack* MediaStreamAudioTrack::From( |
22 const blink::WebMediaStreamTrack& track) { | 28 const blink::WebMediaStreamTrack& track) { |
23 if (track.isNull() || | 29 if (track.isNull() || |
24 track.source().type() != blink::WebMediaStreamSource::TypeAudio) { | 30 track.source().type() != blink::WebMediaStreamSource::TypeAudio) { |
25 return nullptr; | 31 return nullptr; |
26 } | 32 } |
27 return static_cast<MediaStreamAudioTrack*>(track.extraData()); | 33 return static_cast<MediaStreamAudioTrack*>(track.extraData()); |
28 } | 34 } |
29 | 35 |
36 void MediaStreamAudioTrack::Start(const base::Closure& stop_callback) { | |
37 DCHECK(main_render_thread_checker_.CalledOnValidThread()); | |
38 DCHECK(stop_callback_.is_null()); | |
39 DVLOG(1) << "MediaStreamAudioTrack::Start()"; | |
40 stop_callback_ = stop_callback; | |
o1ka
2016/03/02 16:31:14
Do you intentionally allow passing null as stop_ca
miu
2016/03/02 23:38:10
Done. Added DCHECK.
| |
41 } | |
42 | |
43 void MediaStreamAudioTrack::Stop() { | |
44 DCHECK(main_render_thread_checker_.CalledOnValidThread()); | |
45 DVLOG(1) << "MediaStreamAudioTrack::Stop()"; | |
46 if (!stop_callback_.is_null()) | |
47 stop_callback_.Run(); | |
o1ka
2016/03/02 16:31:14
Do you want to reset the callback probably?
miu
2016/03/02 23:38:10
Good catch! Yes, I do. Done.
| |
48 OnStop(); | |
49 } | |
50 | |
51 void MediaStreamAudioTrack::OnStop() {} | |
52 | |
30 webrtc::AudioTrackInterface* MediaStreamAudioTrack::GetAudioAdapter() { | 53 webrtc::AudioTrackInterface* MediaStreamAudioTrack::GetAudioAdapter() { |
31 NOTREACHED(); | 54 NOTREACHED(); |
32 return nullptr; | 55 return nullptr; |
33 } | 56 } |
34 | 57 |
35 } // namespace content | 58 } // namespace content |
OLD | NEW |