Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 "ash/shell.h" | 10 #include "ash/shell.h" |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 50 #include "chrome/browser/chromeos/login/wizard_controller.h" | 50 #include "chrome/browser/chromeos/login/wizard_controller.h" |
| 51 #include "chrome/browser/chromeos/memory/low_memory_observer.h" | 51 #include "chrome/browser/chromeos/memory/low_memory_observer.h" |
| 52 #include "chrome/browser/chromeos/memory/oom_priority_manager.h" | 52 #include "chrome/browser/chromeos/memory/oom_priority_manager.h" |
| 53 #include "chrome/browser/chromeos/net/connectivity_state_helper.h" | 53 #include "chrome/browser/chromeos/net/connectivity_state_helper.h" |
| 54 #include "chrome/browser/chromeos/net/cros_network_change_notifier_factory.h" | 54 #include "chrome/browser/chromeos/net/cros_network_change_notifier_factory.h" |
| 55 #include "chrome/browser/chromeos/net/managed_network_configuration_handler.h" | 55 #include "chrome/browser/chromeos/net/managed_network_configuration_handler.h" |
| 56 #include "chrome/browser/chromeos/net/network_change_notifier_network_library.h" | 56 #include "chrome/browser/chromeos/net/network_change_notifier_network_library.h" |
| 57 #include "chrome/browser/chromeos/net/network_portal_detector.h" | 57 #include "chrome/browser/chromeos/net/network_portal_detector.h" |
| 58 #include "chrome/browser/chromeos/power/brightness_observer.h" | 58 #include "chrome/browser/chromeos/power/brightness_observer.h" |
| 59 #include "chrome/browser/chromeos/power/idle_action_warning_observer.h" | 59 #include "chrome/browser/chromeos/power/idle_action_warning_observer.h" |
| 60 #include "chrome/browser/chromeos/power/peripheral_battery_observer.h" | |
| 60 #include "chrome/browser/chromeos/power/power_button_observer.h" | 61 #include "chrome/browser/chromeos/power/power_button_observer.h" |
| 61 #include "chrome/browser/chromeos/power/resume_observer.h" | 62 #include "chrome/browser/chromeos/power/resume_observer.h" |
| 62 #include "chrome/browser/chromeos/power/screen_lock_observer.h" | 63 #include "chrome/browser/chromeos/power/screen_lock_observer.h" |
| 63 #include "chrome/browser/chromeos/power/suspend_observer.h" | 64 #include "chrome/browser/chromeos/power/suspend_observer.h" |
| 64 #include "chrome/browser/chromeos/power/user_activity_notifier.h" | 65 #include "chrome/browser/chromeos/power/user_activity_notifier.h" |
| 65 #include "chrome/browser/chromeos/power/video_activity_notifier.h" | 66 #include "chrome/browser/chromeos/power/video_activity_notifier.h" |
| 66 #include "chrome/browser/chromeos/screensaver/screensaver_controller.h" | 67 #include "chrome/browser/chromeos/screensaver/screensaver_controller.h" |
| 67 #include "chrome/browser/chromeos/settings/device_settings_service.h" | 68 #include "chrome/browser/chromeos/settings/device_settings_service.h" |
| 68 #include "chrome/browser/chromeos/settings/owner_key_util.h" | 69 #include "chrome/browser/chromeos/settings/owner_key_util.h" |
| 69 #include "chrome/browser/chromeos/system/automatic_reboot_manager.h" | 70 #include "chrome/browser/chromeos/system/automatic_reboot_manager.h" |
| (...skipping 296 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 366 | 367 |
| 367 ChromeBrowserMainPartsChromeos::ChromeBrowserMainPartsChromeos( | 368 ChromeBrowserMainPartsChromeos::ChromeBrowserMainPartsChromeos( |
| 368 const content::MainFunctionParams& parameters) | 369 const content::MainFunctionParams& parameters) |
| 369 : ChromeBrowserMainPartsLinux(parameters) { | 370 : ChromeBrowserMainPartsLinux(parameters) { |
| 370 } | 371 } |
| 371 | 372 |
| 372 ChromeBrowserMainPartsChromeos::~ChromeBrowserMainPartsChromeos() { | 373 ChromeBrowserMainPartsChromeos::~ChromeBrowserMainPartsChromeos() { |
| 373 if (KioskModeSettings::Get()->IsKioskModeEnabled()) | 374 if (KioskModeSettings::Get()->IsKioskModeEnabled()) |
| 374 ShutdownKioskModeScreensaver(); | 375 ShutdownKioskModeScreensaver(); |
| 375 | 376 |
| 377 // PeripheralBatteryObserver needs to be destroyed before DBusServices. | |
| 378 // So release it explicitly here before DBusServices reset. | |
| 379 peripheral_battery_observer_.reset(); | |
|
Daniel Erat
2013/04/10 12:58:21
can this be moved to line 748, where the other dbu
Yufeng Shen (Slow to review)
2013/04/10 18:13:46
Done.
| |
| 376 dbus_services_.reset(); | 380 dbus_services_.reset(); |
| 377 | 381 |
| 378 // To be precise, logout (browser shutdown) is not yet done, but the | 382 // To be precise, logout (browser shutdown) is not yet done, but the |
| 379 // remaining work is negligible, hence we say LogoutDone here. | 383 // remaining work is negligible, hence we say LogoutDone here. |
| 380 BootTimesLoader::Get()->AddLogoutTimeMarker("LogoutDone", false); | 384 BootTimesLoader::Get()->AddLogoutTimeMarker("LogoutDone", false); |
| 381 BootTimesLoader::Get()->WriteLogoutTimes(); | 385 BootTimesLoader::Get()->WriteLogoutTimes(); |
| 382 } | 386 } |
| 383 | 387 |
| 384 // content::BrowserMainParts and ChromeBrowserMainExtraParts overrides --------- | 388 // content::BrowserMainParts and ChromeBrowserMainExtraParts overrides --------- |
| 385 | 389 |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 436 } | 440 } |
| 437 net::NetworkChangeNotifier::SetFactory(network_change_factory); | 441 net::NetworkChangeNotifier::SetFactory(network_change_factory); |
| 438 ChromeBrowserMainPartsLinux::PreMainMessageLoopStart(); | 442 ChromeBrowserMainPartsLinux::PreMainMessageLoopStart(); |
| 439 } | 443 } |
| 440 | 444 |
| 441 void ChromeBrowserMainPartsChromeos::PostMainMessageLoopStart() { | 445 void ChromeBrowserMainPartsChromeos::PostMainMessageLoopStart() { |
| 442 MessageLoopForUI* message_loop = MessageLoopForUI::current(); | 446 MessageLoopForUI* message_loop = MessageLoopForUI::current(); |
| 443 message_loop->AddObserver(g_message_loop_observer.Pointer()); | 447 message_loop->AddObserver(g_message_loop_observer.Pointer()); |
| 444 | 448 |
| 445 dbus_services_.reset(new internal::DBusServices(parameters())); | 449 dbus_services_.reset(new internal::DBusServices(parameters())); |
| 450 // PeripheralBatteryObserver is relying on DBusServices. So initialize it | |
| 451 // after DBusServices' initialization. | |
| 452 peripheral_battery_observer_.reset(new PeripheralBatteryObserver()); | |
|
Daniel Erat
2013/04/10 12:58:21
move to line 641? it's better to wait as long as
Yufeng Shen (Slow to review)
2013/04/10 18:13:46
Done.
| |
| 446 | 453 |
| 447 ChromeBrowserMainPartsLinux::PostMainMessageLoopStart(); | 454 ChromeBrowserMainPartsLinux::PostMainMessageLoopStart(); |
| 448 } | 455 } |
| 449 | 456 |
| 450 // Threads are initialized between MainMessageLoopStart and MainMessageLoopRun. | 457 // Threads are initialized between MainMessageLoopStart and MainMessageLoopRun. |
| 451 // about_flags settings are applied in ChromeBrowserMainParts::PreCreateThreads. | 458 // about_flags settings are applied in ChromeBrowserMainParts::PreCreateThreads. |
| 452 void ChromeBrowserMainPartsChromeos::PreMainMessageLoopRun() { | 459 void ChromeBrowserMainPartsChromeos::PreMainMessageLoopRun() { |
| 453 AudioHandler::Initialize(); | 460 AudioHandler::Initialize(); |
| 454 imageburner::BurnManager::Initialize(); | 461 imageburner::BurnManager::Initialize(); |
| 455 | 462 |
| (...skipping 417 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 873 trial->AppendGroup("4GB_RAM_4GB_swap", zram_group == '4' ? 1 : 0); | 880 trial->AppendGroup("4GB_RAM_4GB_swap", zram_group == '4' ? 1 : 0); |
| 874 trial->AppendGroup("4GB_RAM_6GB_swap", zram_group == '5' ? 1 : 0); | 881 trial->AppendGroup("4GB_RAM_6GB_swap", zram_group == '5' ? 1 : 0); |
| 875 trial->AppendGroup("snow_no_swap", zram_group == '6' ? 1 : 0); | 882 trial->AppendGroup("snow_no_swap", zram_group == '6' ? 1 : 0); |
| 876 trial->AppendGroup("snow_1GB_swap", zram_group == '7' ? 1 : 0); | 883 trial->AppendGroup("snow_1GB_swap", zram_group == '7' ? 1 : 0); |
| 877 trial->AppendGroup("snow_2GB_swap", zram_group == '8' ? 1 : 0); | 884 trial->AppendGroup("snow_2GB_swap", zram_group == '8' ? 1 : 0); |
| 878 // This is necessary to start the experiment as a side effect. | 885 // This is necessary to start the experiment as a side effect. |
| 879 trial->group(); | 886 trial->group(); |
| 880 } | 887 } |
| 881 | 888 |
| 882 } // namespace chromeos | 889 } // namespace chromeos |
| OLD | NEW |