| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/profiles/profile_impl.h" | 5 #include "chrome/browser/profiles/profile_impl.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
| 9 #include "base/environment.h" | 9 #include "base/environment.h" |
| 10 #include "base/file_path.h" | 10 #include "base/file_path.h" |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 #include "chrome/browser/browser_signin.h" | 24 #include "chrome/browser/browser_signin.h" |
| 25 #include "chrome/browser/content_settings/host_content_settings_map.h" | 25 #include "chrome/browser/content_settings/host_content_settings_map.h" |
| 26 #include "chrome/browser/custom_handlers/protocol_handler_registry.h" | 26 #include "chrome/browser/custom_handlers/protocol_handler_registry.h" |
| 27 #include "chrome/browser/defaults.h" | 27 #include "chrome/browser/defaults.h" |
| 28 #include "chrome/browser/download/download_manager.h" | 28 #include "chrome/browser/download/download_manager.h" |
| 29 #include "chrome/browser/extensions/default_apps.h" | 29 #include "chrome/browser/extensions/default_apps.h" |
| 30 #include "chrome/browser/extensions/extension_devtools_manager.h" | 30 #include "chrome/browser/extensions/extension_devtools_manager.h" |
| 31 #include "chrome/browser/extensions/extension_error_reporter.h" | 31 #include "chrome/browser/extensions/extension_error_reporter.h" |
| 32 #include "chrome/browser/extensions/extension_event_router.h" | 32 #include "chrome/browser/extensions/extension_event_router.h" |
| 33 #include "chrome/browser/extensions/extension_info_map.h" | 33 #include "chrome/browser/extensions/extension_info_map.h" |
| 34 #include "chrome/browser/extensions/extension_io_event_router.h" | |
| 35 #include "chrome/browser/extensions/extension_message_service.h" | 34 #include "chrome/browser/extensions/extension_message_service.h" |
| 36 #include "chrome/browser/extensions/extension_pref_store.h" | 35 #include "chrome/browser/extensions/extension_pref_store.h" |
| 37 #include "chrome/browser/extensions/extension_process_manager.h" | 36 #include "chrome/browser/extensions/extension_process_manager.h" |
| 38 #include "chrome/browser/extensions/extension_service.h" | 37 #include "chrome/browser/extensions/extension_service.h" |
| 39 #include "chrome/browser/extensions/user_script_master.h" | 38 #include "chrome/browser/extensions/user_script_master.h" |
| 40 #include "chrome/browser/favicon_service.h" | 39 #include "chrome/browser/favicon_service.h" |
| 41 #include "chrome/browser/geolocation/geolocation_content_settings_map.h" | 40 #include "chrome/browser/geolocation/geolocation_content_settings_map.h" |
| 42 #include "chrome/browser/geolocation/geolocation_permission_context.h" | 41 #include "chrome/browser/geolocation/geolocation_permission_context.h" |
| 43 #include "chrome/browser/history/history.h" | 42 #include "chrome/browser/history/history.h" |
| 44 #include "chrome/browser/history/top_sites.h" | 43 #include "chrome/browser/history/top_sites.h" |
| (...skipping 259 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 304 // ChromeOS because Chrome is always running (no need for special keep-alive | 303 // ChromeOS because Chrome is always running (no need for special keep-alive |
| 305 // or launch-on-startup support). | 304 // or launch-on-startup support). |
| 306 #if !defined(OS_CHROMEOS) | 305 #if !defined(OS_CHROMEOS) |
| 307 background_mode_manager_.reset(new BackgroundModeManager(this, | 306 background_mode_manager_.reset(new BackgroundModeManager(this, |
| 308 CommandLine::ForCurrentProcess())); | 307 CommandLine::ForCurrentProcess())); |
| 309 #endif | 308 #endif |
| 310 | 309 |
| 311 background_contents_service_.reset( | 310 background_contents_service_.reset( |
| 312 new BackgroundContentsService(this, CommandLine::ForCurrentProcess())); | 311 new BackgroundContentsService(this, CommandLine::ForCurrentProcess())); |
| 313 | 312 |
| 314 extension_io_event_router_ = new ExtensionIOEventRouter(this); | |
| 315 extension_info_map_ = new ExtensionInfoMap(); | 313 extension_info_map_ = new ExtensionInfoMap(); |
| 316 | 314 |
| 317 InitRegisteredProtocolHandlers(); | 315 InitRegisteredProtocolHandlers(); |
| 318 | 316 |
| 319 clear_local_state_on_exit_ = prefs->GetBoolean(prefs::kClearSiteDataOnExit); | 317 clear_local_state_on_exit_ = prefs->GetBoolean(prefs::kClearSiteDataOnExit); |
| 320 | 318 |
| 321 // Log the profile size after a reasonable startup delay. | 319 // Log the profile size after a reasonable startup delay. |
| 322 BrowserThread::PostDelayedTask(BrowserThread::FILE, FROM_HERE, | 320 BrowserThread::PostDelayedTask(BrowserThread::FILE, FROM_HERE, |
| 323 new ProfileSizeTask(path_), 112000); | 321 new ProfileSizeTask(path_), 112000); |
| 324 | 322 |
| (...skipping 30 matching lines...) Expand all Loading... |
| 355 return; // Already initialized. | 353 return; // Already initialized. |
| 356 | 354 |
| 357 const CommandLine* command_line = CommandLine::ForCurrentProcess(); | 355 const CommandLine* command_line = CommandLine::ForCurrentProcess(); |
| 358 if (command_line->HasSwitch( | 356 if (command_line->HasSwitch( |
| 359 switches::kEnableExtensionTimelineApi)) { | 357 switches::kEnableExtensionTimelineApi)) { |
| 360 extension_devtools_manager_ = new ExtensionDevToolsManager(this); | 358 extension_devtools_manager_ = new ExtensionDevToolsManager(this); |
| 361 } | 359 } |
| 362 | 360 |
| 363 extension_process_manager_.reset(ExtensionProcessManager::Create(this)); | 361 extension_process_manager_.reset(ExtensionProcessManager::Create(this)); |
| 364 extension_event_router_.reset(new ExtensionEventRouter(this)); | 362 extension_event_router_.reset(new ExtensionEventRouter(this)); |
| 365 extension_io_event_router_ = new ExtensionIOEventRouter(this); | |
| 366 extension_message_service_ = new ExtensionMessageService(this); | 363 extension_message_service_ = new ExtensionMessageService(this); |
| 367 | 364 |
| 368 ExtensionErrorReporter::Init(true); // allow noisy errors. | 365 ExtensionErrorReporter::Init(true); // allow noisy errors. |
| 369 | 366 |
| 370 FilePath script_dir; // Don't look for user scripts in any directory. | 367 FilePath script_dir; // Don't look for user scripts in any directory. |
| 371 // TODO(aa): We should just remove this functionality, | 368 // TODO(aa): We should just remove this functionality, |
| 372 // since it isn't used anymore. | 369 // since it isn't used anymore. |
| 373 user_script_master_ = new UserScriptMaster(script_dir, this); | 370 user_script_master_ = new UserScriptMaster(script_dir, this); |
| 374 | 371 |
| 375 extensions_service_ = new ExtensionService( | 372 extensions_service_ = new ExtensionService( |
| (...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 577 // HistoryService will join with HistoryService's backend thread so that | 574 // HistoryService will join with HistoryService's backend thread so that |
| 578 // by the time the destructor has finished we're sure it will no longer call | 575 // by the time the destructor has finished we're sure it will no longer call |
| 579 // into the BookmarkModel. | 576 // into the BookmarkModel. |
| 580 history_service_ = NULL; | 577 history_service_ = NULL; |
| 581 bookmark_bar_model_.reset(); | 578 bookmark_bar_model_.reset(); |
| 582 | 579 |
| 583 // FaviconService depends on HistoryServce so make sure we delete | 580 // FaviconService depends on HistoryServce so make sure we delete |
| 584 // HistoryService first. | 581 // HistoryService first. |
| 585 favicon_service_ = NULL; | 582 favicon_service_ = NULL; |
| 586 | 583 |
| 587 if (extension_io_event_router_) | |
| 588 extension_io_event_router_->DestroyingProfile(); | |
| 589 | |
| 590 if (extension_message_service_) | 584 if (extension_message_service_) |
| 591 extension_message_service_->DestroyingProfile(); | 585 extension_message_service_->DestroyingProfile(); |
| 592 | 586 |
| 593 if (extensions_service_) | 587 if (extensions_service_) |
| 594 extensions_service_->DestroyingProfile(); | 588 extensions_service_->DestroyingProfile(); |
| 595 | 589 |
| 596 if (pref_proxy_config_tracker_) | 590 if (pref_proxy_config_tracker_) |
| 597 pref_proxy_config_tracker_->DetachFromPrefService(); | 591 pref_proxy_config_tracker_->DetachFromPrefService(); |
| 598 | 592 |
| 599 // This causes the Preferences file to be written to disk. | 593 // This causes the Preferences file to be written to disk. |
| (...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 698 } | 692 } |
| 699 | 693 |
| 700 ExtensionMessageService* ProfileImpl::GetExtensionMessageService() { | 694 ExtensionMessageService* ProfileImpl::GetExtensionMessageService() { |
| 701 return extension_message_service_.get(); | 695 return extension_message_service_.get(); |
| 702 } | 696 } |
| 703 | 697 |
| 704 ExtensionEventRouter* ProfileImpl::GetExtensionEventRouter() { | 698 ExtensionEventRouter* ProfileImpl::GetExtensionEventRouter() { |
| 705 return extension_event_router_.get(); | 699 return extension_event_router_.get(); |
| 706 } | 700 } |
| 707 | 701 |
| 708 ExtensionIOEventRouter* ProfileImpl::GetExtensionIOEventRouter() { | |
| 709 return extension_io_event_router_.get(); | |
| 710 } | |
| 711 | |
| 712 SSLHostState* ProfileImpl::GetSSLHostState() { | 702 SSLHostState* ProfileImpl::GetSSLHostState() { |
| 713 if (!ssl_host_state_.get()) | 703 if (!ssl_host_state_.get()) |
| 714 ssl_host_state_.reset(new SSLHostState()); | 704 ssl_host_state_.reset(new SSLHostState()); |
| 715 | 705 |
| 716 DCHECK(ssl_host_state_->CalledOnValidThread()); | 706 DCHECK(ssl_host_state_->CalledOnValidThread()); |
| 717 return ssl_host_state_.get(); | 707 return ssl_host_state_.get(); |
| 718 } | 708 } |
| 719 | 709 |
| 720 net::TransportSecurityState* | 710 net::TransportSecurityState* |
| 721 ProfileImpl::GetTransportSecurityState() { | 711 ProfileImpl::GetTransportSecurityState() { |
| (...skipping 796 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1518 return pref_proxy_config_tracker_; | 1508 return pref_proxy_config_tracker_; |
| 1519 } | 1509 } |
| 1520 | 1510 |
| 1521 prerender::PrerenderManager* ProfileImpl::GetPrerenderManager() { | 1511 prerender::PrerenderManager* ProfileImpl::GetPrerenderManager() { |
| 1522 if (!prerender::PrerenderManager::IsPrerenderingEnabled()) | 1512 if (!prerender::PrerenderManager::IsPrerenderingEnabled()) |
| 1523 return NULL; | 1513 return NULL; |
| 1524 if (!prerender_manager_) | 1514 if (!prerender_manager_) |
| 1525 prerender_manager_ = new prerender::PrerenderManager(this); | 1515 prerender_manager_ = new prerender::PrerenderManager(this); |
| 1526 return prerender_manager_; | 1516 return prerender_manager_; |
| 1527 } | 1517 } |
| OLD | NEW |