OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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_renderer_factory.h" | 5 #include "media/mojo/services/mojo_renderer_factory.h" |
6 | 6 |
7 #include "base/single_thread_task_runner.h" | 7 #include "base/single_thread_task_runner.h" |
| 8 #include "media/mojo/interfaces/service_factory.mojom.h" |
8 #include "media/mojo/services/mojo_renderer_impl.h" | 9 #include "media/mojo/services/mojo_renderer_impl.h" |
9 #include "mojo/application/public/cpp/connect.h" | 10 #include "third_party/mojo/src/mojo/public/cpp/bindings/interface_request.h" |
10 | 11 |
11 namespace media { | 12 namespace media { |
12 | 13 |
13 MojoRendererFactory::MojoRendererFactory( | 14 MojoRendererFactory::MojoRendererFactory( |
14 mojo::ServiceProvider* service_provider) | 15 interfaces::ServiceFactory* service_factory) |
15 : service_provider_(service_provider) { | 16 : service_factory_(service_factory) { |
16 DCHECK(service_provider_); | 17 DCHECK(service_factory_); |
17 } | 18 } |
18 | 19 |
19 MojoRendererFactory::~MojoRendererFactory() { | 20 MojoRendererFactory::~MojoRendererFactory() { |
20 } | 21 } |
21 | 22 |
22 scoped_ptr<Renderer> MojoRendererFactory::CreateRenderer( | 23 scoped_ptr<Renderer> MojoRendererFactory::CreateRenderer( |
23 const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner, | 24 const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner, |
24 AudioRendererSink* /* audio_renderer_sink */, | 25 AudioRendererSink* /* audio_renderer_sink */, |
25 VideoRendererSink* /* video_renderer_sink */) { | 26 VideoRendererSink* /* video_renderer_sink */) { |
26 DCHECK(service_provider_); | 27 DCHECK(service_factory_); |
27 | 28 |
28 interfaces::MediaRendererPtr mojo_media_renderer; | 29 interfaces::MediaRendererPtr mojo_media_renderer; |
29 mojo::ConnectToService(service_provider_, &mojo_media_renderer); | 30 service_factory_->CreateRenderer(mojo::GetProxy(&mojo_media_renderer)); |
30 | 31 |
31 return scoped_ptr<Renderer>( | 32 return scoped_ptr<Renderer>( |
32 new MojoRendererImpl(media_task_runner, mojo_media_renderer.Pass())); | 33 new MojoRendererImpl(media_task_runner, mojo_media_renderer.Pass())); |
33 } | 34 } |
34 | 35 |
35 } // namespace media | 36 } // namespace media |
OLD | NEW |