OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "chrome/browser/chrome_content_browser_client.h" | 5 #include "chrome/browser/chrome_content_browser_client.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <set> | 8 #include <set> |
9 #include <utility> | 9 #include <utility> |
10 #include <vector> | 10 #include <vector> |
(...skipping 179 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
190 #include "net/base/mime_util.h" | 190 #include "net/base/mime_util.h" |
191 #include "net/base/registry_controlled_domains/registry_controlled_domain.h" | 191 #include "net/base/registry_controlled_domains/registry_controlled_domain.h" |
192 #include "net/cookies/canonical_cookie.h" | 192 #include "net/cookies/canonical_cookie.h" |
193 #include "net/cookies/cookie_options.h" | 193 #include "net/cookies/cookie_options.h" |
194 #include "net/ssl/ssl_cert_request_info.h" | 194 #include "net/ssl/ssl_cert_request_info.h" |
195 #include "ppapi/features/features.h" | 195 #include "ppapi/features/features.h" |
196 #include "ppapi/host/ppapi_host.h" | 196 #include "ppapi/host/ppapi_host.h" |
197 #include "printing/features/features.h" | 197 #include "printing/features/features.h" |
198 #include "services/image_decoder/public/interfaces/constants.mojom.h" | 198 #include "services/image_decoder/public/interfaces/constants.mojom.h" |
199 #include "services/preferences/public/interfaces/preferences.mojom.h" | 199 #include "services/preferences/public/interfaces/preferences.mojom.h" |
| 200 #include "services/resource_coordinator/memory/coordinator/coordinator_impl.h" |
200 #include "services/service_manager/public/cpp/interface_provider.h" | 201 #include "services/service_manager/public/cpp/interface_provider.h" |
201 #include "services/service_manager/public/cpp/interface_registry.h" | 202 #include "services/service_manager/public/cpp/interface_registry.h" |
202 #include "services/service_manager/public/cpp/service.h" | 203 #include "services/service_manager/public/cpp/service.h" |
203 #include "storage/browser/fileapi/external_mount_points.h" | 204 #include "storage/browser/fileapi/external_mount_points.h" |
204 #include "third_party/WebKit/public/platform/modules/webshare/webshare.mojom.h" | 205 #include "third_party/WebKit/public/platform/modules/webshare/webshare.mojom.h" |
205 #include "ui/base/l10n/l10n_util.h" | 206 #include "ui/base/l10n/l10n_util.h" |
206 #include "ui/base/resource/resource_bundle.h" | 207 #include "ui/base/resource/resource_bundle.h" |
207 #include "ui/resources/grit/ui_resources.h" | 208 #include "ui/resources/grit/ui_resources.h" |
208 #include "url/gurl.h" | 209 #include "url/gurl.h" |
209 #include "url/origin.h" | 210 #include "url/origin.h" |
(...skipping 2886 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3096 base::Unretained(ModuleDatabase::GetInstance())), | 3097 base::Unretained(ModuleDatabase::GetInstance())), |
3097 ui_task_runner); | 3098 ui_task_runner); |
3098 } | 3099 } |
3099 #endif | 3100 #endif |
3100 | 3101 |
3101 #if defined(OS_CHROMEOS) | 3102 #if defined(OS_CHROMEOS) |
3102 registry->AddInterface<metrics::mojom::LeakDetector>( | 3103 registry->AddInterface<metrics::mojom::LeakDetector>( |
3103 base::Bind(&metrics::LeakDetectorRemoteController::Create), | 3104 base::Bind(&metrics::LeakDetectorRemoteController::Create), |
3104 ui_task_runner); | 3105 ui_task_runner); |
3105 #endif | 3106 #endif |
| 3107 |
| 3108 registry->AddInterface( |
| 3109 base::Bind( |
| 3110 &memory_instrumentation::CoordinatorImpl::BindCoordinatorRequest, |
| 3111 base::Unretained( |
| 3112 memory_instrumentation::CoordinatorImpl::GetInstance())), |
| 3113 ui_task_runner); |
3106 } | 3114 } |
3107 | 3115 |
3108 void ChromeContentBrowserClient::ExposeInterfacesToMediaService( | 3116 void ChromeContentBrowserClient::ExposeInterfacesToMediaService( |
3109 service_manager::InterfaceRegistry* registry, | 3117 service_manager::InterfaceRegistry* registry, |
3110 content::RenderFrameHost* render_frame_host) { | 3118 content::RenderFrameHost* render_frame_host) { |
3111 // TODO(xhwang): Only register this when ENABLE_MOJO_MEDIA. | 3119 // TODO(xhwang): Only register this when ENABLE_MOJO_MEDIA. |
3112 #if defined(OS_CHROMEOS) | 3120 #if defined(OS_CHROMEOS) |
3113 registry->AddInterface( | 3121 registry->AddInterface( |
3114 base::Bind(&chromeos::attestation::PlatformVerificationImpl::Create, | 3122 base::Bind(&chromeos::attestation::PlatformVerificationImpl::Create, |
3115 render_frame_host)); | 3123 render_frame_host)); |
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3193 } | 3201 } |
3194 #endif | 3202 #endif |
3195 } | 3203 } |
3196 | 3204 |
3197 void ChromeContentBrowserClient::ExposeInterfacesToGpuProcess( | 3205 void ChromeContentBrowserClient::ExposeInterfacesToGpuProcess( |
3198 service_manager::InterfaceRegistry* registry, | 3206 service_manager::InterfaceRegistry* registry, |
3199 content::GpuProcessHost* render_process_host) { | 3207 content::GpuProcessHost* render_process_host) { |
3200 registry->AddInterface( | 3208 registry->AddInterface( |
3201 base::Bind(&metrics::CallStackProfileCollector::Create, | 3209 base::Bind(&metrics::CallStackProfileCollector::Create, |
3202 metrics::CallStackProfileParams::GPU_PROCESS)); | 3210 metrics::CallStackProfileParams::GPU_PROCESS)); |
| 3211 |
| 3212 auto ui_task_runner = content::BrowserThread::GetTaskRunnerForThread( |
| 3213 content::BrowserThread::UI); |
| 3214 registry->AddInterface( |
| 3215 base::Bind( |
| 3216 &memory_instrumentation::CoordinatorImpl::BindCoordinatorRequest, |
| 3217 base::Unretained( |
| 3218 memory_instrumentation::CoordinatorImpl::GetInstance())), |
| 3219 ui_task_runner); |
3203 } | 3220 } |
3204 | 3221 |
3205 void ChromeContentBrowserClient::RegisterInProcessServices( | 3222 void ChromeContentBrowserClient::RegisterInProcessServices( |
3206 StaticServiceMap* services) { | 3223 StaticServiceMap* services) { |
3207 #if defined(ENABLE_MOJO_MEDIA_IN_BROWSER_PROCESS) | 3224 #if defined(ENABLE_MOJO_MEDIA_IN_BROWSER_PROCESS) |
3208 content::ServiceInfo info; | 3225 content::ServiceInfo info; |
3209 info.factory = base::Bind(&media::CreateMediaService); | 3226 info.factory = base::Bind(&media::CreateMediaService); |
3210 services->insert(std::make_pair("media", info)); | 3227 services->insert(std::make_pair("media", info)); |
3211 #endif | 3228 #endif |
3212 #if defined(OS_CHROMEOS) | 3229 #if defined(OS_CHROMEOS) |
(...skipping 338 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3551 RedirectNonUINonIOBrowserThreadsToTaskScheduler() { | 3568 RedirectNonUINonIOBrowserThreadsToTaskScheduler() { |
3552 return variations::GetVariationParamValue( | 3569 return variations::GetVariationParamValue( |
3553 "BrowserScheduler", "RedirectNonUINonIOBrowserThreads") == "true"; | 3570 "BrowserScheduler", "RedirectNonUINonIOBrowserThreads") == "true"; |
3554 } | 3571 } |
3555 | 3572 |
3556 // static | 3573 // static |
3557 void ChromeContentBrowserClient::SetDefaultQuotaSettingsForTesting( | 3574 void ChromeContentBrowserClient::SetDefaultQuotaSettingsForTesting( |
3558 const storage::QuotaSettings* settings) { | 3575 const storage::QuotaSettings* settings) { |
3559 g_default_quota_settings = settings; | 3576 g_default_quota_settings = settings; |
3560 } | 3577 } |
OLD | NEW |