Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/android_mojo_media_client.h" | 5 #include "media/mojo/services/android_mojo_media_client.h" |
| 6 | 6 |
| 7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
| 8 #include "media/base/android/android_cdm_factory.h" | 8 #include "media/base/android/android_cdm_factory.h" |
| 9 #include "media/base/audio_decoder.h" | 9 #include "media/base/audio_decoder.h" |
| 10 #include "media/base/cdm_factory.h" | 10 #include "media/base/cdm_factory.h" |
| 11 #include "media/filters/android/media_codec_audio_decoder.h" | 11 #include "media/filters/android/media_codec_audio_decoder.h" |
| 12 #include "media/mojo/interfaces/provision_fetcher.mojom.h" | 12 #include "media/mojo/interfaces/provision_fetcher.mojom.h" |
| 13 #include "media/mojo/services/mojo_provision_fetcher.h" | 13 #include "media/mojo/services/mojo_provision_fetcher.h" |
| 14 #include "services/service_manager/public/cpp/connect.h" | 14 #include "services/service_manager/public/cpp/connect.h" |
| 15 | 15 |
| 16 namespace media { | 16 namespace media { |
| 17 | 17 |
| 18 namespace { | 18 namespace { |
| 19 | 19 |
| 20 std::unique_ptr<ProvisionFetcher> CreateProvisionFetcher( | 20 std::unique_ptr<ProvisionFetcher> CreateProvisionFetcher( |
| 21 service_manager::mojom::InterfaceProvider* interface_provider) { | 21 service_manager::mojom::InterfaceProvider* host_interfaces) { |
| 22 mojom::ProvisionFetcherPtr provision_fetcher_ptr; | 22 mojom::ProvisionFetcherPtr provision_fetcher_ptr; |
| 23 service_manager::GetInterface(interface_provider, &provision_fetcher_ptr); | 23 service_manager::GetInterface(host_interfaces, &provision_fetcher_ptr); |
| 24 return base::MakeUnique<MojoProvisionFetcher>( | 24 return base::MakeUnique<MojoProvisionFetcher>( |
| 25 std::move(provision_fetcher_ptr)); | 25 std::move(provision_fetcher_ptr)); |
| 26 } | 26 } |
| 27 | 27 |
| 28 } // namespace | 28 } // namespace |
| 29 | 29 |
| 30 AndroidMojoMediaClient::AndroidMojoMediaClient() {} | 30 AndroidMojoMediaClient::AndroidMojoMediaClient() {} |
| 31 | 31 |
| 32 AndroidMojoMediaClient::~AndroidMojoMediaClient() {} | 32 AndroidMojoMediaClient::~AndroidMojoMediaClient() {} |
| 33 | 33 |
| 34 // MojoMediaClient overrides. | 34 // MojoMediaClient overrides. |
| 35 | 35 |
| 36 std::unique_ptr<AudioDecoder> AndroidMojoMediaClient::CreateAudioDecoder( | 36 std::unique_ptr<AudioDecoder> AndroidMojoMediaClient::CreateAudioDecoder( |
| 37 scoped_refptr<base::SingleThreadTaskRunner> task_runner) { | 37 scoped_refptr<base::SingleThreadTaskRunner> task_runner) { |
| 38 return base::MakeUnique<MediaCodecAudioDecoder>(task_runner); | 38 return base::MakeUnique<MediaCodecAudioDecoder>(task_runner); |
| 39 } | 39 } |
| 40 | 40 |
| 41 std::unique_ptr<CdmFactory> AndroidMojoMediaClient::CreateCdmFactory( | 41 std::unique_ptr<CdmFactory> AndroidMojoMediaClient::CreateCdmFactory( |
| 42 service_manager::mojom::InterfaceProvider* interface_provider) { | 42 service_manager::mojom::InterfaceProvider* host_interfaces) { |
| 43 // |host_interfaces| is needed for CDM. If it was not bound by the host, | |
| 44 // return nullptr. | |
| 45 if (!host_interfaces) | |
| 46 return nullptr; | |
|
dcheng
2016/12/02 08:52:51
Just trying to understand the change here: does hi
slan
2016/12/02 16:45:53
|host_interfaces| is, at present, used to provide
xhwang
2016/12/02 17:47:48
dcheng: good point. I think when this happens, it'
dcheng
2016/12/02 18:00:30
I feel like a NOTREACHED() will just end up mostly
| |
| 43 return base::MakeUnique<AndroidCdmFactory>( | 47 return base::MakeUnique<AndroidCdmFactory>( |
| 44 base::Bind(&CreateProvisionFetcher, interface_provider)); | 48 base::Bind(&CreateProvisionFetcher, host_interfaces)); |
| 45 } | 49 } |
| 46 | 50 |
| 47 } // namespace media | 51 } // namespace media |
| OLD | NEW |