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

Side by Side Diff: media/mojo/services/service_factory_impl.cc

Issue 1529063004: Pass MojoMediaClient instance to MojoMediaApplication constructor. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: added bug number Created 5 years 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
« no previous file with comments | « media/mojo/services/service_factory_impl.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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/service_factory_impl.h" 5 #include "media/mojo/services/service_factory_impl.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "media/base/cdm_factory.h" 8 #include "media/base/cdm_factory.h"
9 #include "media/base/media_log.h" 9 #include "media/base/media_log.h"
10 #include "media/base/renderer_factory.h" 10 #include "media/base/renderer_factory.h"
11 #include "media/mojo/services/mojo_cdm_service.h" 11 #include "media/mojo/services/mojo_cdm_service.h"
12 #include "media/mojo/services/mojo_media_client.h" 12 #include "media/mojo/services/mojo_media_client.h"
13 #include "media/mojo/services/mojo_renderer_service.h" 13 #include "media/mojo/services/mojo_renderer_service.h"
14 #include "mojo/application/public/cpp/app_lifetime_helper.h" 14 #include "mojo/application/public/cpp/app_lifetime_helper.h"
15 #include "mojo/application/public/interfaces/service_provider.mojom.h" 15 #include "mojo/application/public/interfaces/service_provider.mojom.h"
16 16
17 namespace media { 17 namespace media {
18 18
19 ServiceFactoryImpl::ServiceFactoryImpl( 19 ServiceFactoryImpl::ServiceFactoryImpl(
20 mojo::InterfaceRequest<interfaces::ServiceFactory> request, 20 mojo::InterfaceRequest<interfaces::ServiceFactory> request,
21 mojo::ServiceProvider* service_provider, 21 mojo::ServiceProvider* service_provider,
22 scoped_refptr<MediaLog> media_log, 22 scoped_refptr<MediaLog> media_log,
23 scoped_ptr<mojo::AppRefCount> parent_app_refcount) 23 scoped_ptr<mojo::AppRefCount> parent_app_refcount,
24 MojoMediaClient* mojo_media_client)
24 : binding_(this, std::move(request)), 25 : binding_(this, std::move(request)),
25 service_provider_(service_provider), 26 service_provider_(service_provider),
26 media_log_(media_log), 27 media_log_(media_log),
27 parent_app_refcount_(std::move(parent_app_refcount)) { 28 parent_app_refcount_(std::move(parent_app_refcount)),
29 mojo_media_client_(mojo_media_client) {
28 DVLOG(1) << __FUNCTION__; 30 DVLOG(1) << __FUNCTION__;
29 } 31 }
30 32
31 ServiceFactoryImpl::~ServiceFactoryImpl() { 33 ServiceFactoryImpl::~ServiceFactoryImpl() {
32 DVLOG(1) << __FUNCTION__; 34 DVLOG(1) << __FUNCTION__;
33 } 35 }
34 36
35 // interfaces::ServiceFactory implementation. 37 // interfaces::ServiceFactory implementation.
36 void ServiceFactoryImpl::CreateRenderer( 38 void ServiceFactoryImpl::CreateRenderer(
37 mojo::InterfaceRequest<interfaces::Renderer> request) { 39 mojo::InterfaceRequest<interfaces::Renderer> request) {
38 // The created object is owned by the pipe. 40 // The created object is owned by the pipe.
39 scoped_refptr<base::SingleThreadTaskRunner> task_runner( 41 scoped_refptr<base::SingleThreadTaskRunner> task_runner(
40 base::MessageLoop::current()->task_runner()); 42 base::MessageLoop::current()->task_runner());
41 MojoMediaClient* mojo_media_client = MojoMediaClient::Get();
42 scoped_refptr<AudioRendererSink> audio_renderer_sink = 43 scoped_refptr<AudioRendererSink> audio_renderer_sink =
43 mojo_media_client->CreateAudioRendererSink(); 44 mojo_media_client_->CreateAudioRendererSink();
44 scoped_ptr<VideoRendererSink> video_renderer_sink = 45 scoped_ptr<VideoRendererSink> video_renderer_sink =
45 mojo_media_client->CreateVideoRendererSink(task_runner); 46 mojo_media_client_->CreateVideoRendererSink(task_runner);
46 scoped_ptr<Renderer> renderer = GetRendererFactory()->CreateRenderer( 47 scoped_ptr<Renderer> renderer = GetRendererFactory()->CreateRenderer(
47 task_runner, task_runner, audio_renderer_sink.get(), 48 task_runner, task_runner, audio_renderer_sink.get(),
48 video_renderer_sink.get()); 49 video_renderer_sink.get());
49 50
50 new MojoRendererService(cdm_service_context_.GetWeakPtr(), 51 new MojoRendererService(cdm_service_context_.GetWeakPtr(),
51 std::move(renderer), std::move(request)); 52 std::move(renderer), std::move(request));
52 } 53 }
53 54
54 void ServiceFactoryImpl::CreateCdm( 55 void ServiceFactoryImpl::CreateCdm(
55 mojo::InterfaceRequest<interfaces::ContentDecryptionModule> request) { 56 mojo::InterfaceRequest<interfaces::ContentDecryptionModule> request) {
56 // The created object is owned by the pipe. 57 // The created object is owned by the pipe.
57 new MojoCdmService(cdm_service_context_.GetWeakPtr(), service_provider_, 58 new MojoCdmService(cdm_service_context_.GetWeakPtr(), service_provider_,
58 GetCdmFactory(), std::move(request)); 59 GetCdmFactory(), std::move(request));
59 } 60 }
60 61
61 RendererFactory* ServiceFactoryImpl::GetRendererFactory() { 62 RendererFactory* ServiceFactoryImpl::GetRendererFactory() {
62 if (!renderer_factory_) 63 if (!renderer_factory_)
63 renderer_factory_ = 64 renderer_factory_ = mojo_media_client_->CreateRendererFactory(media_log_);
64 MojoMediaClient::Get()->CreateRendererFactory(media_log_);
65 return renderer_factory_.get(); 65 return renderer_factory_.get();
66 } 66 }
67 67
68 CdmFactory* ServiceFactoryImpl::GetCdmFactory() { 68 CdmFactory* ServiceFactoryImpl::GetCdmFactory() {
69 if (!cdm_factory_) 69 if (!cdm_factory_)
70 cdm_factory_ = MojoMediaClient::Get()->CreateCdmFactory(service_provider_); 70 cdm_factory_ = mojo_media_client_->CreateCdmFactory(service_provider_);
71 return cdm_factory_.get(); 71 return cdm_factory_.get();
72 } 72 }
73 73
74 } // namespace media 74 } // namespace media
OLDNEW
« no previous file with comments | « media/mojo/services/service_factory_impl.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698