| 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/chromeos/chrome_browser_main_chromeos.h" | 5 #include "chrome/browser/chromeos/chrome_browser_main_chromeos.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 43 #include "chrome/browser/chromeos/power/brightness_observer.h" | 43 #include "chrome/browser/chromeos/power/brightness_observer.h" |
| 44 #include "chrome/browser/chromeos/power/output_observer.h" | 44 #include "chrome/browser/chromeos/power/output_observer.h" |
| 45 #include "chrome/browser/chromeos/power/power_button_controller_delegate_chromeo
s.h" | 45 #include "chrome/browser/chromeos/power/power_button_controller_delegate_chromeo
s.h" |
| 46 #include "chrome/browser/chromeos/power/power_button_observer.h" | 46 #include "chrome/browser/chromeos/power/power_button_observer.h" |
| 47 #include "chrome/browser/chromeos/power/power_state_override.h" | 47 #include "chrome/browser/chromeos/power/power_state_override.h" |
| 48 #include "chrome/browser/chromeos/power/resume_observer.h" | 48 #include "chrome/browser/chromeos/power/resume_observer.h" |
| 49 #include "chrome/browser/chromeos/power/screen_dimming_observer.h" | 49 #include "chrome/browser/chromeos/power/screen_dimming_observer.h" |
| 50 #include "chrome/browser/chromeos/power/screen_lock_observer.h" | 50 #include "chrome/browser/chromeos/power/screen_lock_observer.h" |
| 51 #include "chrome/browser/chromeos/power/user_activity_notifier.h" | 51 #include "chrome/browser/chromeos/power/user_activity_notifier.h" |
| 52 #include "chrome/browser/chromeos/power/video_activity_notifier.h" | 52 #include "chrome/browser/chromeos/power/video_activity_notifier.h" |
| 53 #include "chrome/browser/chromeos/settings/device_settings_service.h" | 53 #include "chrome/browser/chromeos/settings/ownership_service.h" |
| 54 #include "chrome/browser/chromeos/settings/owner_key_util.h" | 54 #include "chrome/browser/chromeos/settings/session_manager_observer.h" |
| 55 #include "chrome/browser/chromeos/system/statistics_provider.h" | 55 #include "chrome/browser/chromeos/system/statistics_provider.h" |
| 56 #include "chrome/browser/chromeos/system_key_event_listener.h" | 56 #include "chrome/browser/chromeos/system_key_event_listener.h" |
| 57 #include "chrome/browser/chromeos/upgrade_detector_chromeos.h" | 57 #include "chrome/browser/chromeos/upgrade_detector_chromeos.h" |
| 58 #include "chrome/browser/chromeos/web_socket_proxy_controller.h" | 58 #include "chrome/browser/chromeos/web_socket_proxy_controller.h" |
| 59 #include "chrome/browser/chromeos/xinput_hierarchy_changed_event_listener.h" | 59 #include "chrome/browser/chromeos/xinput_hierarchy_changed_event_listener.h" |
| 60 #include "chrome/browser/defaults.h" | 60 #include "chrome/browser/defaults.h" |
| 61 #include "chrome/browser/media_gallery/media_device_notifications_chromeos.h" | 61 #include "chrome/browser/media_gallery/media_device_notifications_chromeos.h" |
| 62 #include "chrome/browser/metrics/metrics_service.h" | 62 #include "chrome/browser/metrics/metrics_service.h" |
| 63 #include "chrome/browser/net/chrome_network_delegate.h" | 63 #include "chrome/browser/net/chrome_network_delegate.h" |
| 64 #include "chrome/browser/policy/browser_policy_connector.h" | 64 #include "chrome/browser/policy/browser_policy_connector.h" |
| (...skipping 222 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 287 | 287 |
| 288 // Initialize DBusThreadManager for the browser. This must be done after | 288 // Initialize DBusThreadManager for the browser. This must be done after |
| 289 // the main message loop is started, as it uses the message loop. | 289 // the main message loop is started, as it uses the message loop. |
| 290 chromeos::DBusThreadManager::Initialize(); | 290 chromeos::DBusThreadManager::Initialize(); |
| 291 // Add observers for WallpaperManager. WallpaperManager is initialized before | 291 // Add observers for WallpaperManager. WallpaperManager is initialized before |
| 292 // DBusThreadManager. | 292 // DBusThreadManager. |
| 293 chromeos::WallpaperManager::Get()->AddObservers(); | 293 chromeos::WallpaperManager::Get()->AddObservers(); |
| 294 | 294 |
| 295 chromeos::CrosDBusService::Initialize(); | 295 chromeos::CrosDBusService::Initialize(); |
| 296 | 296 |
| 297 // Initialize the device settings service so that we'll take actions per | 297 // Initialize the session manager observer so that we'll take actions |
| 298 // signals sent from the session manager. | 298 // per signals sent from the session manager. |
| 299 chromeos::DeviceSettingsService::Get()->Initialize( | 299 session_manager_observer_.reset(new chromeos::SessionManagerObserver); |
| 300 chromeos::DBusThreadManager::Get()->GetSessionManagerClient(), | |
| 301 chromeos::OwnerKeyUtil::Create()); | |
| 302 | 300 |
| 303 chromeos::disks::DiskMountManager::Initialize(); | 301 chromeos::disks::DiskMountManager::Initialize(); |
| 304 chromeos::mtp::MediaTransferProtocolManager::Initialize(); | 302 chromeos::mtp::MediaTransferProtocolManager::Initialize(); |
| 305 cryptohome::AsyncMethodCaller::Initialize(); | 303 cryptohome::AsyncMethodCaller::Initialize(); |
| 306 | 304 |
| 307 // Initialize the network change notifier for Chrome OS. The network | 305 // Initialize the network change notifier for Chrome OS. The network |
| 308 // change notifier starts to monitor changes from the power manager and | 306 // change notifier starts to monitor changes from the power manager and |
| 309 // the network manager. | 307 // the network manager. |
| 310 chromeos::CrosNetworkChangeNotifierFactory::GetInstance()->Init(); | 308 chromeos::CrosNetworkChangeNotifierFactory::GetInstance()->Init(); |
| 311 | 309 |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 344 } | 342 } |
| 345 | 343 |
| 346 void ChromeBrowserMainPartsChromeos::PreProfileInit() { | 344 void ChromeBrowserMainPartsChromeos::PreProfileInit() { |
| 347 // -- This used to be in ChromeBrowserMainParts::PreMainMessageLoopRun() | 345 // -- This used to be in ChromeBrowserMainParts::PreMainMessageLoopRun() |
| 348 // -- immediately before Profile creation(). | 346 // -- immediately before Profile creation(). |
| 349 | 347 |
| 350 // Now that the file thread exists we can record our stats. | 348 // Now that the file thread exists we can record our stats. |
| 351 chromeos::BootTimesLoader::Get()->RecordChromeMainStats(); | 349 chromeos::BootTimesLoader::Get()->RecordChromeMainStats(); |
| 352 | 350 |
| 353 // Trigger prefetching of ownership status. | 351 // Trigger prefetching of ownership status. |
| 354 chromeos::DeviceSettingsService::Get()->Load(); | 352 chromeos::OwnershipService::GetSharedInstance()->Prewarm(); |
| 355 | 353 |
| 356 // -- This used to be in ChromeBrowserMainParts::PreMainMessageLoopRun() | 354 // -- This used to be in ChromeBrowserMainParts::PreMainMessageLoopRun() |
| 357 // -- just before CreateProfile(). | 355 // -- just before CreateProfile(). |
| 358 | 356 |
| 359 // Initialize the screen locker now so that it can receive | 357 // Initialize the screen locker now so that it can receive |
| 360 // LOGIN_USER_CHANGED notification from UserManager. | 358 // LOGIN_USER_CHANGED notification from UserManager. |
| 361 if (chromeos::KioskModeSettings::Get()->IsKioskModeEnabled()) { | 359 if (chromeos::KioskModeSettings::Get()->IsKioskModeEnabled()) { |
| 362 chromeos::KioskModeIdleLogout::Initialize(); | 360 chromeos::KioskModeIdleLogout::Initialize(); |
| 363 } else { | 361 } else { |
| 364 chromeos::ScreenLocker::InitClass(); | 362 chromeos::ScreenLocker::InitClass(); |
| (...skipping 150 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 515 // stops monitoring changes from the update engine. | 513 // stops monitoring changes from the update engine. |
| 516 if (UpgradeDetectorChromeos::GetInstance()) | 514 if (UpgradeDetectorChromeos::GetInstance()) |
| 517 UpgradeDetectorChromeos::GetInstance()->Shutdown(); | 515 UpgradeDetectorChromeos::GetInstance()->Shutdown(); |
| 518 | 516 |
| 519 // Shutdown the network change notifier for Chrome OS. The network | 517 // Shutdown the network change notifier for Chrome OS. The network |
| 520 // change notifier stops monitoring changes from the power manager and | 518 // change notifier stops monitoring changes from the power manager and |
| 521 // the network manager. | 519 // the network manager. |
| 522 if (chromeos::CrosNetworkChangeNotifierFactory::GetInstance()) | 520 if (chromeos::CrosNetworkChangeNotifierFactory::GetInstance()) |
| 523 chromeos::CrosNetworkChangeNotifierFactory::GetInstance()->Shutdown(); | 521 chromeos::CrosNetworkChangeNotifierFactory::GetInstance()->Shutdown(); |
| 524 | 522 |
| 525 // Tell DeviceSettingsService to stop talking to session_manager. | |
| 526 chromeos::DeviceSettingsService::Get()->Shutdown(); | |
| 527 | |
| 528 // We should remove observers attached to D-Bus clients before | 523 // We should remove observers attached to D-Bus clients before |
| 529 // DBusThreadManager is shut down. | 524 // DBusThreadManager is shut down. |
| 525 session_manager_observer_.reset(); |
| 530 screen_lock_observer_.reset(); | 526 screen_lock_observer_.reset(); |
| 531 resume_observer_.reset(); | 527 resume_observer_.reset(); |
| 532 brightness_observer_.reset(); | 528 brightness_observer_.reset(); |
| 533 output_observer_.reset(); | 529 output_observer_.reset(); |
| 534 | 530 |
| 535 // The XInput2 event listener needs to be shut down earlier than when | 531 // The XInput2 event listener needs to be shut down earlier than when |
| 536 // Singletons are finally destroyed in AtExitManager. | 532 // Singletons are finally destroyed in AtExitManager. |
| 537 chromeos::XInputHierarchyChangedEventListener::GetInstance()->Stop(); | 533 chromeos::XInputHierarchyChangedEventListener::GetInstance()->Stop(); |
| 538 | 534 |
| 539 // chromeos::SystemKeyEventListener::Shutdown() is always safe to call, | 535 // chromeos::SystemKeyEventListener::Shutdown() is always safe to call, |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 603 LOG(WARNING) << "low_mem: Part of '100MB' experiment"; | 599 LOG(WARNING) << "low_mem: Part of '100MB' experiment"; |
| 604 chromeos::LowMemoryObserver::SetLowMemoryMargin(100); | 600 chromeos::LowMemoryObserver::SetLowMemoryMargin(100); |
| 605 } else if (trial->group() == margin_200mb) { | 601 } else if (trial->group() == margin_200mb) { |
| 606 LOG(WARNING) << "low_mem: Part of '200MB' experiment"; | 602 LOG(WARNING) << "low_mem: Part of '200MB' experiment"; |
| 607 chromeos::LowMemoryObserver::SetLowMemoryMargin(200); | 603 chromeos::LowMemoryObserver::SetLowMemoryMargin(200); |
| 608 } else { | 604 } else { |
| 609 LOG(WARNING) << "low_mem: Part of 'default' experiment"; | 605 LOG(WARNING) << "low_mem: Part of 'default' experiment"; |
| 610 } | 606 } |
| 611 } | 607 } |
| 612 } | 608 } |
| OLD | NEW |