| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 "media/mojo/services/mojo_audio_output_stream_provider.h" | 5 #include "media/mojo/services/mojo_audio_output_stream_provider.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 namespace media { | 9 namespace media { |
| 10 | 10 |
| 11 MojoAudioOutputStreamProvider::MojoAudioOutputStreamProvider( | 11 MojoAudioOutputStreamProvider::MojoAudioOutputStreamProvider( |
| 12 mojom::AudioOutputStreamProviderRequest request, | 12 mojom::AudioOutputStreamProviderRequest request, |
| 13 CreateDelegateCallback create_delegate_callback, | 13 CreateDelegateCallback create_delegate_callback, |
| 14 DeleterCallback deleter_callback) | 14 DeleterCallback deleter_callback) |
| 15 : binding_(this, std::move(request)), | 15 : binding_(this, std::move(request)), |
| 16 create_delegate_callback_(std::move(create_delegate_callback)), | 16 create_delegate_callback_(std::move(create_delegate_callback)), |
| 17 deleter_callback_(base::Bind(std::move(deleter_callback), this)) { | 17 deleter_callback_(std::move(deleter_callback)) { |
| 18 DCHECK(thread_checker_.CalledOnValidThread()); | 18 DCHECK(thread_checker_.CalledOnValidThread()); |
| 19 binding_.set_connection_error_handler(deleter_callback_); | 19 binding_.set_connection_error_handler(base::Bind( |
| 20 &MojoAudioOutputStreamProvider::OnError, base::Unretained(this))); |
| 20 DCHECK(create_delegate_callback_); | 21 DCHECK(create_delegate_callback_); |
| 21 DCHECK(deleter_callback_); | 22 DCHECK(deleter_callback_); |
| 22 } | 23 } |
| 23 | 24 |
| 24 MojoAudioOutputStreamProvider::~MojoAudioOutputStreamProvider() { | 25 MojoAudioOutputStreamProvider::~MojoAudioOutputStreamProvider() { |
| 25 DCHECK(thread_checker_.CalledOnValidThread()); | 26 DCHECK(thread_checker_.CalledOnValidThread()); |
| 26 } | 27 } |
| 27 | 28 |
| 28 void MojoAudioOutputStreamProvider::Acquire( | 29 void MojoAudioOutputStreamProvider::Acquire( |
| 29 mojom::AudioOutputStreamRequest stream_request, | 30 mojom::AudioOutputStreamRequest stream_request, |
| 30 const AudioParameters& params, | 31 const AudioParameters& params, |
| 31 const AcquireCallback& callback) { | 32 const AcquireCallback& callback) { |
| 32 DCHECK(thread_checker_.CalledOnValidThread()); | 33 DCHECK(thread_checker_.CalledOnValidThread()); |
| 33 if (audio_output_) { | 34 if (audio_output_) { |
| 34 LOG(ERROR) << "Output acquired twice."; | 35 LOG(ERROR) << "Output acquired twice."; |
| 35 binding_.Unbind(); | 36 binding_.Unbind(); |
| 36 deleter_callback_.Run(); // deletes |this|. | 37 std::move(deleter_callback_).Run(this); // deletes |this|. |
| 37 return; | 38 return; |
| 38 } | 39 } |
| 39 | 40 |
| 40 audio_output_.emplace( | 41 audio_output_.emplace( |
| 41 std::move(stream_request), | 42 std::move(stream_request), |
| 42 base::BindOnce(std::move(create_delegate_callback_), params), | 43 base::BindOnce(std::move(create_delegate_callback_), params), |
| 43 std::move(callback), deleter_callback_); | 44 std::move(callback), |
| 45 base::BindOnce(&MojoAudioOutputStreamProvider::OnError, |
| 46 base::Unretained(this))); |
| 47 } |
| 48 |
| 49 void MojoAudioOutputStreamProvider::OnError() { |
| 50 // Deletes |this|: |
| 51 std::move(deleter_callback_).Run(this); |
| 44 } | 52 } |
| 45 | 53 |
| 46 } // namespace media | 54 } // namespace media |
| OLD | NEW |