Chromium Code Reviews| Index: content/browser/media/audio_output_impl.cc |
| diff --git a/content/browser/media/audio_output_impl.cc b/content/browser/media/audio_output_impl.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..a00070700be099f99ddf4ab3061158ada32b1303 |
| --- /dev/null |
| +++ b/content/browser/media/audio_output_impl.cc |
| @@ -0,0 +1,90 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "content/browser/media/audio_output_impl.h" |
| +#include "content/browser/media/audio_output_stream_impl.h" |
| + |
| +namespace content { |
| + |
| +AudioOutputImpl::AudioOutputImpl( |
| + RenderProcessHost* process, |
| + int render_frame_id, |
| + media::mojom::AudioOutputRequest request) |
| + : process_(process), |
| + render_frame_id_(render_frame_id), |
| + binding_(this) { |
| + DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| + binding_.Bind(std::move(request)); |
| + LOG(ERROR) << "AudioOutputImpl"; |
|
tommi (sloooow) - chröme
2016/05/20 13:26:12
?
rchtara
2016/05/27 15:24:36
Done.
|
| + factory_ = base::Bind(AudioOutputStreamFactory::Factory); |
|
Henrik Grunell
2016/05/20 13:35:39
I suppose |factory_| is needed for being modified
rchtara
2016/05/27 15:24:36
it's removed: not needed for the new tests
|
| +} |
| + |
| +AudioOutputImpl::~AudioOutputImpl() { |
| + LOG(ERROR) << "~AudioOutputImpl"; |
|
tommi (sloooow) - chröme
2016/05/20 13:26:12
please remove all of these
rchtara
2016/05/27 15:24:36
Done.
|
| +} |
| + |
| +// static |
| +void AudioOutputImpl::CreateService( |
| + RenderProcessHost* process, |
| + int render_frame_id, |
| + media::mojom::AudioOutputRequest request) { |
| + DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| + |
| + BrowserThread::PostTask( |
| + BrowserThread::IO, FROM_HERE, |
| + base::Bind(&AudioOutputImpl::CreateServiceOnIOThread, process, |
| + render_frame_id, base::Passed(&request))); |
| +} |
| + |
| +// static |
| +void AudioOutputImpl::CreateServiceOnIOThread( |
| + RenderProcessHost* process, |
| + int render_frame_id, |
| + media::mojom::AudioOutputRequest request) { |
| + if (request.is_pending()) { |
| + DCHECK_CURRENTLY_ON(BrowserThread::IO); |
|
tommi (sloooow) - chröme
2016/05/20 13:26:12
why would we only be on the io thread if the reque
Henrik Grunell
2016/05/20 13:35:39
Why can it be called on another thread if not pend
rchtara
2016/05/27 15:24:36
Done.
rchtara
2016/05/27 15:24:36
Done.
|
| + } |
| + |
| + auto service = new AudioOutputImpl(process, render_frame_id, |
| + std::move(request)); |
| + |
| + process->audio_renderer_host()->set_audio_output_impl(render_frame_id, service); |
|
tommi (sloooow) - chröme
2016/05/20 13:26:12
please run git cl format
Henrik Grunell
2016/05/20 13:35:39
This is what we talked about offline, right? It wo
rchtara
2016/05/27 15:24:36
yes. exactly
rchtara
2016/05/27 15:24:36
Done.
rchtara
2016/05/27 15:24:36
Done.
|
| +} |
| + |
| +void AudioOutputImpl::CreateStream(int stream_id, |
| + const media::AudioParameters& params, |
| + const CreateStreamCallback& callback) { |
| + DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| + media::mojom::AudioOutputStreamPtr stream; |
| + process_->audio_renderer_host()->CreateStream(stream_id, render_frame_id_, |
| + params, callback); |
| +} |
| + |
| +media::mojom::AudioOutputStreamPtr AudioOutputImpl::StreamFactory( |
|
Henrik Grunell
2016/05/20 13:35:39
It seems to be unnecessarily complicated to call t
rchtara
2016/05/27 15:24:36
Yes, but dale wants to removes code from the ARH.
|
| + int stream_id, |
| + int render_frame_id, |
| + AudioRendererHost* audio_renderer_host) { |
| + DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| + |
| + media::mojom::AudioOutputStreamPtr stream = |
| + media::mojom::AudioOutputStreamPtr(); |
| + std::unique_ptr<AudioOutputStreamImpl> stream_ptr( |
| + factory_.Run(mojo::GetProxy(&stream), stream_id, render_frame_id, |
| + audio_renderer_host)); |
| + |
| + auto ret = |
| + stream_impls_.insert(std::make_pair(stream_id, std::move(stream_ptr))); |
| + DCHECK(ret.second); |
|
tommi (sloooow) - chröme
2016/05/20 13:26:12
do you get a build error for official builds? (re
rchtara
2016/05/27 15:24:36
On 2016/05/20 13:26:12, tommi-chrömium wrote:
> do
|
| + return stream; |
| +} |
| + |
| +bool AudioOutputImpl::RemoveStream(int stream_id) { |
| + LOG(ERROR) << "rm stream_id" << stream_id; |
| + if (stream_impls_.erase(stream_id)) |
| + return true; |
| + else |
| + return false; |
|
tommi (sloooow) - chröme
2016/05/20 13:26:12
please just do:
return stream_impls_.erase(stream
rchtara
2016/05/27 15:24:36
Done.
|
| +} |
| + |
| +} // namespace content |