| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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 "base/system_monitor/system_monitor.h" | 5 #include "base/power_monitor/power_monitor.h" |
| 6 | 6 |
| 7 #include <utility> | |
| 8 | |
| 9 #include "base/logging.h" | |
| 10 #include "base/message_loop.h" | |
| 11 #include "base/time.h" | 7 #include "base/time.h" |
| 12 | 8 |
| 13 namespace base { | 9 namespace base { |
| 14 | 10 |
| 15 static SystemMonitor* g_system_monitor = NULL; | 11 static PowerMonitor* g_power_monitor = NULL; |
| 16 | 12 |
| 17 #if defined(ENABLE_BATTERY_MONITORING) | 13 #if defined(ENABLE_BATTERY_MONITORING) |
| 18 // The amount of time (in ms) to wait before running the initial | 14 // The amount of time (in ms) to wait before running the initial |
| 19 // battery check. | 15 // battery check. |
| 20 static int kDelayedBatteryCheckMs = 10 * 1000; | 16 static int kDelayedBatteryCheckMs = 10 * 1000; |
| 21 #endif // defined(ENABLE_BATTERY_MONITORING) | 17 #endif // defined(ENABLE_BATTERY_MONITORING) |
| 22 | 18 |
| 23 SystemMonitor::SystemMonitor() | 19 PowerMonitor::PowerMonitor() |
| 24 : power_observer_list_(new ObserverListThreadSafe<PowerObserver>()), | 20 : observers_(new ObserverListThreadSafe<PowerObserver>()), |
| 25 devices_changed_observer_list_( | |
| 26 new ObserverListThreadSafe<DevicesChangedObserver>()), | |
| 27 battery_in_use_(false), | 21 battery_in_use_(false), |
| 28 suspended_(false) { | 22 suspended_(false) { |
| 29 DCHECK(!g_system_monitor); | 23 DCHECK(!g_power_monitor); |
| 30 g_system_monitor = this; | 24 g_power_monitor = this; |
| 31 | 25 |
| 32 DCHECK(MessageLoop::current()); | 26 DCHECK(MessageLoop::current()); |
| 33 #if defined(ENABLE_BATTERY_MONITORING) | 27 #if defined(ENABLE_BATTERY_MONITORING) |
| 34 delayed_battery_check_.Start(FROM_HERE, | 28 delayed_battery_check_.Start(FROM_HERE, |
| 35 base::TimeDelta::FromMilliseconds(kDelayedBatteryCheckMs), this, | 29 base::TimeDelta::FromMilliseconds(kDelayedBatteryCheckMs), this, |
| 36 &SystemMonitor::BatteryCheck); | 30 &PowerMonitor::BatteryCheck); |
| 37 #endif // defined(ENABLE_BATTERY_MONITORING) | 31 #endif // defined(ENABLE_BATTERY_MONITORING) |
| 38 #if defined(OS_MACOSX) | 32 #if defined(OS_MACOSX) |
| 39 PlatformInit(); | 33 PlatformInit(); |
| 40 #endif | 34 #endif |
| 41 } | 35 } |
| 42 | 36 |
| 43 SystemMonitor::~SystemMonitor() { | 37 PowerMonitor::~PowerMonitor() { |
| 44 #if defined(OS_MACOSX) | 38 #if defined(OS_MACOSX) |
| 45 PlatformDestroy(); | 39 PlatformDestroy(); |
| 46 #endif | 40 #endif |
| 47 DCHECK_EQ(this, g_system_monitor); | 41 DCHECK_EQ(this, g_power_monitor); |
| 48 g_system_monitor = NULL; | 42 g_power_monitor = NULL; |
| 49 } | 43 } |
| 50 | 44 |
| 51 // static | 45 // static |
| 52 SystemMonitor* SystemMonitor::Get() { | 46 PowerMonitor* PowerMonitor::Get() { |
| 53 return g_system_monitor; | 47 return g_power_monitor; |
| 54 } | 48 } |
| 55 | 49 |
| 56 void SystemMonitor::ProcessPowerMessage(PowerEvent event_id) { | 50 void PowerMonitor::AddObserver(PowerObserver* obs) { |
| 51 observers_->AddObserver(obs); |
| 52 } |
| 53 |
| 54 void PowerMonitor::RemoveObserver(PowerObserver* obs) { |
| 55 observers_->RemoveObserver(obs); |
| 56 } |
| 57 |
| 58 void PowerMonitor::ProcessPowerEvent(PowerEvent event_id) { |
| 57 // Suppress duplicate notifications. Some platforms may | 59 // Suppress duplicate notifications. Some platforms may |
| 58 // send multiple notifications of the same event. | 60 // send multiple notifications of the same event. |
| 59 switch (event_id) { | 61 switch (event_id) { |
| 60 case POWER_STATE_EVENT: | 62 case POWER_STATE_EVENT: |
| 61 { | 63 { |
| 62 bool on_battery = IsBatteryPower(); | 64 bool on_battery = IsBatteryPower(); |
| 63 if (on_battery != battery_in_use_) { | 65 if (on_battery != battery_in_use_) { |
| 64 battery_in_use_ = on_battery; | 66 battery_in_use_ = on_battery; |
| 65 NotifyPowerStateChange(); | 67 NotifyPowerStateChange(); |
| 66 } | 68 } |
| 67 } | 69 } |
| 68 break; | 70 break; |
| 69 case RESUME_EVENT: | 71 case RESUME_EVENT: |
| 70 if (suspended_) { | 72 if (suspended_) { |
| 71 suspended_ = false; | 73 suspended_ = false; |
| 72 NotifyResume(); | 74 NotifyResume(); |
| 73 } | 75 } |
| 74 break; | 76 break; |
| 75 case SUSPEND_EVENT: | 77 case SUSPEND_EVENT: |
| 76 if (!suspended_) { | 78 if (!suspended_) { |
| 77 suspended_ = true; | 79 suspended_ = true; |
| 78 NotifySuspend(); | 80 NotifySuspend(); |
| 79 } | 81 } |
| 80 break; | 82 break; |
| 81 } | 83 } |
| 82 } | 84 } |
| 83 | 85 |
| 84 void SystemMonitor::ProcessDevicesChanged(DeviceType device_type) { | 86 void PowerMonitor::BatteryCheck() { |
| 85 NotifyDevicesChanged(device_type); | 87 ProcessPowerEvent(PowerMonitor::POWER_STATE_EVENT); |
| 86 } | 88 } |
| 87 | 89 |
| 88 void SystemMonitor::AddPowerObserver(PowerObserver* obs) { | 90 void PowerMonitor::NotifyPowerStateChange() { |
| 89 power_observer_list_->AddObserver(obs); | 91 DVLOG(1) << "PowerStateChange: " << (BatteryPower() ? "On" : "Off") |
| 92 << " battery"; |
| 93 observers_->Notify(&PowerObserver::OnPowerStateChange, BatteryPower()); |
| 90 } | 94 } |
| 91 | 95 |
| 92 void SystemMonitor::RemovePowerObserver(PowerObserver* obs) { | 96 void PowerMonitor::NotifySuspend() { |
| 93 power_observer_list_->RemoveObserver(obs); | 97 DVLOG(1) << "Power Suspending"; |
| 98 observers_->Notify(&PowerObserver::OnSuspend); |
| 94 } | 99 } |
| 95 | 100 |
| 96 void SystemMonitor::AddDevicesChangedObserver(DevicesChangedObserver* obs) { | 101 void PowerMonitor::NotifyResume() { |
| 97 devices_changed_observer_list_->AddObserver(obs); | |
| 98 } | |
| 99 | |
| 100 void SystemMonitor::RemoveDevicesChangedObserver(DevicesChangedObserver* obs) { | |
| 101 devices_changed_observer_list_->RemoveObserver(obs); | |
| 102 } | |
| 103 | |
| 104 void SystemMonitor::NotifyDevicesChanged(DeviceType device_type) { | |
| 105 DVLOG(1) << "DevicesChanged with device type " << device_type; | |
| 106 devices_changed_observer_list_->Notify( | |
| 107 &DevicesChangedObserver::OnDevicesChanged, device_type); | |
| 108 } | |
| 109 | |
| 110 void SystemMonitor::NotifyPowerStateChange() { | |
| 111 DVLOG(1) << "PowerStateChange: " << (BatteryPower() ? "On" : "Off") | |
| 112 << " battery"; | |
| 113 power_observer_list_->Notify(&PowerObserver::OnPowerStateChange, | |
| 114 BatteryPower()); | |
| 115 } | |
| 116 | |
| 117 void SystemMonitor::NotifySuspend() { | |
| 118 DVLOG(1) << "Power Suspending"; | |
| 119 power_observer_list_->Notify(&PowerObserver::OnSuspend); | |
| 120 } | |
| 121 | |
| 122 void SystemMonitor::NotifyResume() { | |
| 123 DVLOG(1) << "Power Resuming"; | 102 DVLOG(1) << "Power Resuming"; |
| 124 power_observer_list_->Notify(&PowerObserver::OnResume); | 103 observers_->Notify(&PowerObserver::OnResume); |
| 125 } | |
| 126 | |
| 127 void SystemMonitor::BatteryCheck() { | |
| 128 ProcessPowerMessage(SystemMonitor::POWER_STATE_EVENT); | |
| 129 } | 104 } |
| 130 | 105 |
| 131 } // namespace base | 106 } // namespace base |
| OLD | NEW |