Chromium Code Reviews| Index: chromecast/browser/cast_content_browser_client.cc |
| diff --git a/chromecast/browser/cast_content_browser_client.cc b/chromecast/browser/cast_content_browser_client.cc |
| index 3234a597e1b5f7780aa1ac1b484feabeadba41ab..35c6c20f13bc9aaf238ab1758af8031b514013a8 100644 |
| --- a/chromecast/browser/cast_content_browser_client.cc |
| +++ b/chromecast/browser/cast_content_browser_client.cc |
| @@ -39,6 +39,7 @@ |
| #include "content/public/common/url_constants.h" |
| #include "content/public/common/web_preferences.h" |
| #include "gin/v8_initializer.h" |
| +#include "media/base/bind_to_current_loop.h" |
| #include "net/ssl/ssl_cert_request_info.h" |
| #include "ui/gl/gl_switches.h" |
| @@ -74,22 +75,39 @@ content::BrowserMainParts* CastContentBrowserClient::CreateBrowserMainParts( |
| void CastContentBrowserClient::RenderProcessWillLaunch( |
| content::RenderProcessHost* host) { |
| - scoped_refptr<content::BrowserMessageFilter> network_hints_message_filter( |
| - new network_hints::NetworkHintsMessageFilter( |
| - url_request_context_factory_->host_resolver())); |
| - host->AddFilter(network_hints_message_filter.get()); |
| #if !defined(OS_ANDROID) |
| scoped_refptr<media::CmaMessageFilterHost> cma_message_filter( |
| new media::CmaMessageFilterHost(host->GetID())); |
| host->AddFilter(cma_message_filter.get()); |
| #endif // !defined(OS_ANDROID) |
| + content::BrowserThread::PostTaskAndReplyWithResult( |
| + content::BrowserThread::IO, FROM_HERE, |
| + base::Bind(&URLRequestContextFactory::host_resolver, |
| + base::Unretained(url_request_context_factory_.get())), |
| + base::Bind(&CastContentBrowserClient::AddExtraFilter, |
| + base::Unretained(this), host->GetID())); |
|
byungchul
2015/04/17 00:22:20
It changes the order of message filter. Is it okay
gunsch
2015/04/17 01:06:27
Changing order is okay. Order was not so important
|
| + |
| auto extra_filters = PlatformGetBrowserMessageFilters(); |
| for (auto const& filter : extra_filters) { |
| host->AddFilter(filter.get()); |
| } |
| } |
| +void CastContentBrowserClient::AddExtraFilter( |
| + int render_process_id, net::HostResolver* host_resolver) { |
| + DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| + |
| + content::RenderProcessHost* host = |
| + content::RenderProcessHost::FromID(render_process_id); |
| + if (!host) |
| + return; |
| + |
| + scoped_refptr<content::BrowserMessageFilter> network_hints_message_filter( |
| + new network_hints::NetworkHintsMessageFilter(host_resolver)); |
| + host->AddFilter(network_hints_message_filter.get()); |
| +} |
| + |
| net::URLRequestContextGetter* CastContentBrowserClient::CreateRequestContext( |
| content::BrowserContext* browser_context, |
| content::ProtocolHandlerMap* protocol_handlers, |