| Index: content/renderer/media/media_stream_dependency_factory.cc
|
| diff --git a/content/renderer/media/media_stream_dependency_factory.cc b/content/renderer/media/media_stream_dependency_factory.cc
|
| index 4f4d6f11e90e2e68cbeb00fe4ba909db021f5a71..f1da360c8c4cf9d40092065bba8ea53fa1a73f2a 100644
|
| --- a/content/renderer/media/media_stream_dependency_factory.cc
|
| +++ b/content/renderer/media/media_stream_dependency_factory.cc
|
| @@ -364,7 +364,7 @@ void MediaStreamDependencyFactory::CreateNativeMediaSources(
|
| }
|
|
|
| scoped_refptr<WebRtcAudioCapturer> capturer(
|
| - MaybeCreateAudioCapturer(render_view_id, device_info));
|
| + CreateAudioCapturer(render_view_id, device_info));
|
| if (!capturer.get()) {
|
| DLOG(WARNING) << "Failed to create the capturer for device "
|
| << device_info.device.id;
|
| @@ -459,14 +459,9 @@ MediaStreamDependencyFactory::CreateNativeAudioMediaStreamTrack(
|
| }
|
| }
|
|
|
| - std::string track_id = base::UTF16ToUTF8(track.id());
|
| - scoped_refptr<WebRtcAudioCapturer> capturer;
|
| - if (GetWebRtcAudioDevice())
|
| - capturer = GetWebRtcAudioDevice()->GetDefaultCapturer();
|
| -
|
| scoped_refptr<webrtc::AudioTrackInterface> audio_track(
|
| - CreateLocalAudioTrack(track_id,
|
| - capturer,
|
| + CreateLocalAudioTrack(track.id().utf8(),
|
| + source_data->GetAudioCapturer(),
|
| webaudio_source.get(),
|
| source_data->local_audio_source(),
|
| &track_constraints));
|
| @@ -927,43 +922,15 @@ void MediaStreamDependencyFactory::CleanupPeerConnectionFactory() {
|
| }
|
|
|
| scoped_refptr<WebRtcAudioCapturer>
|
| -MediaStreamDependencyFactory::MaybeCreateAudioCapturer(
|
| +MediaStreamDependencyFactory::CreateAudioCapturer(
|
| int render_view_id,
|
| const StreamDeviceInfo& device_info) {
|
| // TODO(xians): Handle the cases when gUM is called without a proper render
|
| // view, for example, by an extension.
|
| DCHECK_GE(render_view_id, 0);
|
|
|
| - scoped_refptr<WebRtcAudioCapturer> capturer =
|
| - GetWebRtcAudioDevice()->GetDefaultCapturer();
|
| -
|
| - // If the default capturer does not exist or |render_view_id| == -1, create
|
| - // a new capturer.
|
| - bool is_new_capturer = false;
|
| - if (!capturer.get()) {
|
| - capturer = WebRtcAudioCapturer::CreateCapturer();
|
| - is_new_capturer = true;
|
| - }
|
| -
|
| - if (!capturer->Initialize(
|
| - render_view_id,
|
| - static_cast<media::ChannelLayout>(
|
| - device_info.device.input.channel_layout),
|
| - device_info.device.input.sample_rate,
|
| - device_info.device.input.frames_per_buffer,
|
| - device_info.session_id,
|
| - device_info.device.id,
|
| - device_info.device.matched_output.sample_rate,
|
| - device_info.device.matched_output.frames_per_buffer,
|
| - device_info.device.input.effects)) {
|
| - return NULL;
|
| - }
|
| -
|
| - // Add the capturer to the WebRtcAudioDeviceImpl if it is a new capturer.
|
| - if (is_new_capturer)
|
| - GetWebRtcAudioDevice()->AddAudioCapturer(capturer);
|
| -
|
| - return capturer;
|
| + return WebRtcAudioCapturer::CreateCapturer(render_view_id, device_info,
|
| + GetWebRtcAudioDevice());
|
| }
|
|
|
| void MediaStreamDependencyFactory::AddNativeTrackToBlinkTrack(
|
|
|