Index: chromecast/renderer/media/cma_media_renderer_factory.cc |
diff --git a/chromecast/renderer/media/cma_media_renderer_factory.cc b/chromecast/renderer/media/cma_media_renderer_factory.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ee7543c147c40ddb18245f3e3dda943d0ad5e39c |
--- /dev/null |
+++ b/chromecast/renderer/media/cma_media_renderer_factory.cc |
@@ -0,0 +1,40 @@ |
+// Copyright 2014 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 "chromecast/renderer/media/cma_media_renderer_factory.h" |
+ |
+#include "base/command_line.h" |
+#include "chromecast/media/cma/filters/cma_renderer.h" |
+#include "chromecast/renderer/media/media_pipeline_proxy.h" |
+#include "content/public/renderer/render_thread.h" |
+ |
+namespace chromecast { |
+namespace media { |
+ |
+CmaMediaRendererFactory::CmaMediaRendererFactory(int render_frame_id) |
+ : render_frame_id_(render_frame_id) { |
+} |
+ |
+CmaMediaRendererFactory::~CmaMediaRendererFactory() { |
+} |
+ |
+scoped_ptr<::media::Renderer> CmaMediaRendererFactory::CreateRenderer( |
+ const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner, |
+ ::media::AudioRendererSink* audio_renderer_sink) { |
+ // TODO(erickung): Need to provide right chromecast::media::LoadType. |
gunsch
2014/12/20 22:41:33
Link to the crbug discussing this issue
erickung1
2014/12/21 11:10:47
Done.
|
+ chromecast::media::LoadType cma_load_type = |
+ chromecast::media::kLoadTypeMediaSource; |
+ scoped_ptr<chromecast::media::MediaPipeline> cma_media_pipeline( |
+ new chromecast::cma::MediaPipelineProxy( |
+ render_frame_id_, |
+ content::RenderThread::Get()->GetIOMessageLoopProxy(), |
+ cma_load_type)); |
+ // TODO(gunsch): investigate calling SetCdm here if available. |
gunsch
2014/12/20 22:41:33
this TODO is obsolete due to xhwang@ having wired
erickung1
2014/12/21 11:10:47
Done.
|
+ |
+ return scoped_ptr<::media::Renderer>( |
gunsch
2014/12/20 22:41:33
check this CL for "<::" ; it should always be "< :
erickung1
2014/12/21 11:10:46
Done.
|
+ new chromecast::media::CmaRenderer(cma_media_pipeline.Pass())); |
+} |
+ |
+} // namespace media |
+} // namespace chromecast |