Index: content/renderer/media/rtc_video_decoder_factory.cc |
diff --git a/content/renderer/media/rtc_video_decoder_factory.cc b/content/renderer/media/rtc_video_decoder_factory.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0b0fd5ea70743e449f5c1c359b9c0c661b869de2 |
--- /dev/null |
+++ b/content/renderer/media/rtc_video_decoder_factory.cc |
@@ -0,0 +1,38 @@ |
+// Copyright (c) 2013 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 "content/renderer/media/rtc_video_decoder_factory.h" |
+ |
+#include "base/location.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "content/renderer/media/renderer_gpu_video_decoder_factories.h" |
+#include "content/renderer/media/rtc_video_decoder.h" |
+ |
+namespace content { |
+ |
+RTCVideoDecoderFactory::RTCVideoDecoderFactory( |
+ const scoped_refptr<RendererGpuVideoDecoderFactories>& gpu_factories, |
+ base::Thread* vda_thread) |
+ : gpu_factories_(gpu_factories), |
+ vda_thread_(vda_thread) { |
+} |
+ |
+webrtc::VideoDecoder* RTCVideoDecoderFactory::CreateVideoDecoder( |
+ webrtc::VideoCodecType type) { |
+ // RendererGpuVideoDecoderFactories is not thread-safe. Make a copy. |
+ scoped_ptr<RTCVideoDecoder> decoder( |
+ new RTCVideoDecoder(gpu_factories_->Copy())); |
wuchengli
2013/06/10 15:24:22
This is a little bit ugly. But I think this is the
|
+ vda_thread_->message_loop()->AddDestructionObserver(decoder.get()); |
Ami GONE FROM CHROMIUM
2013/06/11 23:48:05
I think .get() is no longer needed.
Ami GONE FROM CHROMIUM
2013/06/11 23:48:05
Is vda_thread_->message_loop() != gpu_factories_->
wuchengli
2013/06/13 10:28:07
No. We need MessageLoop, not MessageLoopProxy. Onl
wuchengli
2013/06/13 10:28:07
Done. AddDestructionObserver is moved to ctor of R
|
+ if (decoder->Initialize(type)) |
+ return decoder.release(); |
+ // Initialize will fail when the codec is not supported. |
+ return NULL; |
+} |
+ |
+void RTCVideoDecoderFactory::DestroyVideoDecoder( |
+ webrtc::VideoDecoder* decoder) { |
+ gpu_factories_->GetMessageLoop()->DeleteSoon(FROM_HERE, decoder); |
+} |
+ |
+} // namespace content |