Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(689)

Side by Side Diff: content/renderer/media/media_stream_audio_track.cc

Issue 1721273002: MediaStream audio object graph untangling and clean-ups. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed o1ka's 2nd round of comments. Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698