Index: apps/shell/browser/shell_content_browser_client.cc |
diff --git a/apps/shell/browser/shell_content_browser_client.cc b/apps/shell/browser/shell_content_browser_client.cc |
deleted file mode 100644 |
index 5dfc3171e54e858df396bcb04f7be2603b82cf6b..0000000000000000000000000000000000000000 |
--- a/apps/shell/browser/shell_content_browser_client.cc |
+++ /dev/null |
@@ -1,190 +0,0 @@ |
-// Copyright 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 "apps/shell/browser/shell_content_browser_client.h" |
- |
-#include "apps/shell/browser/shell_browser_context.h" |
-#include "apps/shell/browser/shell_browser_main_parts.h" |
-#include "apps/shell/browser/shell_extension_system.h" |
-#include "base/command_line.h" |
-#include "content/public/browser/browser_thread.h" |
-#include "content/public/browser/render_process_host.h" |
-#include "content/public/browser/site_instance.h" |
-#include "content/public/common/content_switches.h" |
-#include "content/public/common/url_constants.h" |
-#include "content/shell/browser/shell_browser_context.h" |
-#include "extensions/browser/extension_message_filter.h" |
-#include "extensions/browser/extension_protocols.h" |
-#include "extensions/browser/extension_registry.h" |
-#include "extensions/browser/info_map.h" |
-#include "extensions/browser/process_map.h" |
-#include "extensions/common/constants.h" |
-#include "extensions/common/extension.h" |
-#include "extensions/common/switches.h" |
-#include "url/gurl.h" |
- |
-using content::BrowserThread; |
-using extensions::ExtensionRegistry; |
- |
-namespace apps { |
-namespace { |
- |
-ShellContentBrowserClient* g_instance = NULL; |
- |
-} // namespace |
- |
-ShellContentBrowserClient::ShellContentBrowserClient( |
- ShellBrowserMainDelegate* browser_main_delegate) |
- : browser_main_parts_(NULL), browser_main_delegate_(browser_main_delegate) { |
- DCHECK(!g_instance); |
- g_instance = this; |
-} |
- |
-ShellContentBrowserClient::~ShellContentBrowserClient() { g_instance = NULL; } |
- |
-// static |
-ShellContentBrowserClient* ShellContentBrowserClient::Get() { |
- return g_instance; |
-} |
- |
-content::BrowserContext* ShellContentBrowserClient::GetBrowserContext() { |
- return browser_main_parts_->browser_context(); |
-} |
- |
-content::BrowserMainParts* ShellContentBrowserClient::CreateBrowserMainParts( |
- const content::MainFunctionParams& parameters) { |
- browser_main_parts_ = |
- new ShellBrowserMainParts(parameters, browser_main_delegate_); |
- return browser_main_parts_; |
-} |
- |
-void ShellContentBrowserClient::RenderProcessWillLaunch( |
- content::RenderProcessHost* host) { |
- int render_process_id = host->GetID(); |
- host->AddFilter(new extensions::ExtensionMessageFilter( |
- render_process_id, browser_main_parts_->browser_context())); |
-} |
- |
-bool ShellContentBrowserClient::ShouldUseProcessPerSite( |
- content::BrowserContext* browser_context, |
- const GURL& effective_url) { |
- // This ensures that all render views created for a single app will use the |
- // same render process (see content::SiteInstance::GetProcess). Otherwise the |
- // default behavior of ContentBrowserClient will lead to separate render |
- // processes for the background page and each app window view. |
- return true; |
-} |
- |
-net::URLRequestContextGetter* ShellContentBrowserClient::CreateRequestContext( |
- content::BrowserContext* content_browser_context, |
- content::ProtocolHandlerMap* protocol_handlers, |
- content::URLRequestInterceptorScopedVector request_interceptors) { |
- // Handle only chrome-extension:// requests. app_shell does not support |
- // chrome-extension-resource:// requests (it does not store shared extension |
- // data in its installation directory). |
- extensions::InfoMap* extension_info_map = |
- browser_main_parts_->extension_system()->info_map(); |
- (*protocol_handlers)[extensions::kExtensionScheme] = |
- linked_ptr<net::URLRequestJobFactory::ProtocolHandler>( |
- extensions::CreateExtensionProtocolHandler(false /* is_incognito */, |
- extension_info_map)); |
- // Let content::ShellBrowserContext handle the rest of the setup. |
- return browser_main_parts_->browser_context()->CreateRequestContext( |
- protocol_handlers, request_interceptors.Pass()); |
-} |
- |
-bool ShellContentBrowserClient::IsHandledURL(const GURL& url) { |
- if (!url.is_valid()) |
- return false; |
- // Keep in sync with ProtocolHandlers added in CreateRequestContext() and in |
- // content::ShellURLRequestContextGetter::GetURLRequestContext(). |
- static const char* const kProtocolList[] = { |
- url::kBlobScheme, |
- content::kChromeDevToolsScheme, |
- content::kChromeUIScheme, |
- url::kDataScheme, |
- url::kFileScheme, |
- url::kFileSystemScheme, |
- extensions::kExtensionScheme, |
- extensions::kExtensionResourceScheme, |
- }; |
- for (size_t i = 0; i < arraysize(kProtocolList); ++i) { |
- if (url.scheme() == kProtocolList[i]) |
- return true; |
- } |
- return false; |
-} |
- |
-void ShellContentBrowserClient::SiteInstanceGotProcess( |
- content::SiteInstance* site_instance) { |
- // If this isn't an extension renderer there's nothing to do. |
- const extensions::Extension* extension = GetExtension(site_instance); |
- if (!extension) |
- return; |
- |
- extensions::ProcessMap::Get(browser_main_parts_->browser_context()) |
- ->Insert(extension->id(), |
- site_instance->GetProcess()->GetID(), |
- site_instance->GetId()); |
- |
- BrowserThread::PostTask( |
- BrowserThread::IO, |
- FROM_HERE, |
- base::Bind(&extensions::InfoMap::RegisterExtensionProcess, |
- browser_main_parts_->extension_system()->info_map(), |
- extension->id(), |
- site_instance->GetProcess()->GetID(), |
- site_instance->GetId())); |
-} |
- |
-void ShellContentBrowserClient::SiteInstanceDeleting( |
- content::SiteInstance* site_instance) { |
- // If this isn't an extension renderer there's nothing to do. |
- const extensions::Extension* extension = GetExtension(site_instance); |
- if (!extension) |
- return; |
- |
- extensions::ProcessMap::Get(browser_main_parts_->browser_context()) |
- ->Remove(extension->id(), |
- site_instance->GetProcess()->GetID(), |
- site_instance->GetId()); |
- |
- BrowserThread::PostTask( |
- BrowserThread::IO, |
- FROM_HERE, |
- base::Bind(&extensions::InfoMap::UnregisterExtensionProcess, |
- browser_main_parts_->extension_system()->info_map(), |
- extension->id(), |
- site_instance->GetProcess()->GetID(), |
- site_instance->GetId())); |
-} |
- |
-void ShellContentBrowserClient::AppendExtraCommandLineSwitches( |
- CommandLine* command_line, int child_process_id) { |
- std::string process_type = |
- command_line->GetSwitchValueASCII(switches::kProcessType); |
- if (process_type == switches::kRendererProcess) { |
- // TODO(jamescook): Should we check here if the process is in the extension |
- // service process map, or can we assume all renderers are extension |
- // renderers? |
- command_line->AppendSwitch(extensions::switches::kExtensionProcess); |
- } |
-} |
- |
-void ShellContentBrowserClient::GetAdditionalAllowedSchemesForFileSystem( |
- std::vector<std::string>* additional_allowed_schemes) { |
- ContentBrowserClient::GetAdditionalAllowedSchemesForFileSystem( |
- additional_allowed_schemes); |
- additional_allowed_schemes->push_back(extensions::kExtensionScheme); |
-} |
- |
-const extensions::Extension* ShellContentBrowserClient::GetExtension( |
- content::SiteInstance* site_instance) { |
- ExtensionRegistry* registry = |
- ExtensionRegistry::Get(site_instance->GetBrowserContext()); |
- return registry->enabled_extensions().GetExtensionOrAppByURL( |
- site_instance->GetSiteURL()); |
-} |
- |
-} // namespace apps |