| 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 "chromecast/renderer/cast_render_thread_observer.h" | 5 #include "chromecast/renderer/cast_render_thread_observer.h" |
| 6 | 6 |
| 7 #include "build/build_config.h" | 7 #include "build/build_config.h" |
| 8 #include "chromecast/renderer/media/capabilities_message_filter.h" | 8 #include "chromecast/renderer/media/capabilities_message_filter.h" |
| 9 #include "chromecast/renderer/media/cma_message_filter_proxy.h" | 9 #include "chromecast/renderer/media/cma_message_filter_proxy.h" |
| 10 #include "content/public/renderer/render_thread.h" | 10 #include "content/public/renderer/render_thread.h" |
| 11 | 11 |
| 12 namespace chromecast { | 12 namespace chromecast { |
| 13 namespace shell { | 13 namespace shell { |
| 14 | 14 |
| 15 CastRenderThreadObserver::CastRenderThreadObserver() { | 15 CastRenderThreadObserver::CastRenderThreadObserver() { |
| 16 content::RenderThread* thread = content::RenderThread::Get(); | 16 content::RenderThread* thread = content::RenderThread::Get(); |
| 17 thread->AddObserver(this); | 17 thread->AddObserver(this); |
| 18 CreateCustomFilters(); | 18 CreateCustomFilters(); |
| 19 } | 19 } |
| 20 | 20 |
| 21 CastRenderThreadObserver::~CastRenderThreadObserver() { | 21 CastRenderThreadObserver::~CastRenderThreadObserver() { |
| 22 // CastRenderThreadObserver outlives content::RenderThread. | 22 // CastRenderThreadObserver outlives content::RenderThread. |
| 23 // No need to explicitly call RemoveObserver in teardown. | 23 // No need to explicitly call RemoveObserver in teardown. |
| 24 } | 24 } |
| 25 | 25 |
| 26 void CastRenderThreadObserver::CreateCustomFilters() { | 26 void CastRenderThreadObserver::CreateCustomFilters() { |
| 27 content::RenderThread* thread = content::RenderThread::Get(); | 27 content::RenderThread* thread = content::RenderThread::Get(); |
| 28 #if !defined(OS_ANDROID) | 28 #if !defined(OS_ANDROID) |
| 29 cma_message_filter_proxy_ = | 29 cma_message_filter_proxy_ = |
| 30 new media::CmaMessageFilterProxy(thread->GetIOMessageLoopProxy()); | 30 new media::CmaMessageFilterProxy(thread->GetIOTaskRunner()); |
| 31 thread->AddFilter(cma_message_filter_proxy_.get()); | 31 thread->AddFilter(cma_message_filter_proxy_.get()); |
| 32 #endif // !defined(OS_ANDROID) | 32 #endif // !defined(OS_ANDROID) |
| 33 capabilities_message_filter_ = new CapabilitiesMessageFilter; | 33 capabilities_message_filter_ = new CapabilitiesMessageFilter; |
| 34 thread->AddFilter(capabilities_message_filter_.get()); | 34 thread->AddFilter(capabilities_message_filter_.get()); |
| 35 } | 35 } |
| 36 | 36 |
| 37 void CastRenderThreadObserver::OnRenderProcessShutdown() { | 37 void CastRenderThreadObserver::OnRenderProcessShutdown() { |
| 38 content::RenderThread* thread = content::RenderThread::Get(); | 38 content::RenderThread* thread = content::RenderThread::Get(); |
| 39 #if !defined(OS_ANDROID) | 39 #if !defined(OS_ANDROID) |
| 40 if (cma_message_filter_proxy_.get()) { | 40 if (cma_message_filter_proxy_.get()) { |
| 41 thread->RemoveFilter(cma_message_filter_proxy_.get()); | 41 thread->RemoveFilter(cma_message_filter_proxy_.get()); |
| 42 cma_message_filter_proxy_ = nullptr; | 42 cma_message_filter_proxy_ = nullptr; |
| 43 } | 43 } |
| 44 #endif // !defined(OS_ANDROID) | 44 #endif // !defined(OS_ANDROID) |
| 45 if (capabilities_message_filter_.get()) { | 45 if (capabilities_message_filter_.get()) { |
| 46 thread->RemoveFilter(capabilities_message_filter_.get()); | 46 thread->RemoveFilter(capabilities_message_filter_.get()); |
| 47 capabilities_message_filter_ = nullptr; | 47 capabilities_message_filter_ = nullptr; |
| 48 } | 48 } |
| 49 } | 49 } |
| 50 | 50 |
| 51 } // namespace shell | 51 } // namespace shell |
| 52 } // namespace chromecast | 52 } // namespace chromecast |
| OLD | NEW |