Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(537)

Side by Side Diff: chromeos/dbus/fake_power_manager_client.cc

Issue 1206733002: ChromeOs Power Emulation Impl (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: added local namespace for constants Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « chromeos/dbus/fake_power_manager_client.h ('k') | chromeos/dbus/power_manager_client.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "chromeos/dbus/fake_power_manager_client.h" 5 #include "chromeos/dbus/fake_power_manager_client.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/time/time.h" 9 #include "base/time/time.h"
10 10
11 namespace chromeos { 11 namespace chromeos {
12 namespace {
13
14 const int kDefaultBatteryEmptyTime = 4 * 3600; // 4 hours
15
16 } // namespace
12 17
13 FakePowerManagerClient::FakePowerManagerClient() 18 FakePowerManagerClient::FakePowerManagerClient()
14 : num_request_restart_calls_(0), 19 : is_charging_(false),
20 is_calculating_(false),
21 battery_percentage_(50),
22 power_source_(0),
23 hours_to_empty_full_battery_(kDefaultBatteryEmptyTime),
stevenjb 2015/06/26 21:16:53 This variable name is still confusing. It should e
mozartalouis 2015/06/26 21:29:44 Sorry i didn't see this one. changing now
24 num_request_restart_calls_(0),
15 num_request_shutdown_calls_(0), 25 num_request_shutdown_calls_(0),
16 num_set_policy_calls_(0), 26 num_set_policy_calls_(0),
17 num_set_is_projecting_calls_(0), 27 num_set_is_projecting_calls_(0),
18 num_pending_suspend_readiness_callbacks_(0), 28 num_pending_suspend_readiness_callbacks_(0),
19 is_projecting_(false) { 29 is_projecting_(false),
30 weak_ptr_factory_(this) {
20 } 31 }
21 32
22 FakePowerManagerClient::~FakePowerManagerClient() { 33 FakePowerManagerClient::~FakePowerManagerClient() {
23 } 34 }
24 35
25 void FakePowerManagerClient::Init(dbus::Bus* bus) { 36 void FakePowerManagerClient::Init(dbus::Bus* bus) {
37 UpdatePowerStatus();
26 } 38 }
27 39
28 void FakePowerManagerClient::AddObserver(Observer* observer) { 40 void FakePowerManagerClient::AddObserver(Observer* observer) {
29 observers_.AddObserver(observer); 41 observers_.AddObserver(observer);
30 } 42 }
31 43
32 void FakePowerManagerClient::RemoveObserver(Observer* observer) { 44 void FakePowerManagerClient::RemoveObserver(Observer* observer) {
33 observers_.RemoveObserver(observer); 45 observers_.RemoveObserver(observer);
34 } 46 }
35 47
36 bool FakePowerManagerClient::HasObserver(const Observer* observer) const { 48 bool FakePowerManagerClient::HasObserver(const Observer* observer) const {
37 return false; 49 return observers_.HasObserver(observer);
38 } 50 }
39 51
40 void FakePowerManagerClient::SetRenderProcessManagerDelegate( 52 void FakePowerManagerClient::SetRenderProcessManagerDelegate(
41 base::WeakPtr<RenderProcessManagerDelegate> delegate) { 53 base::WeakPtr<RenderProcessManagerDelegate> delegate) {
42 render_process_manager_delegate_ = delegate; 54 render_process_manager_delegate_ = delegate;
43 } 55 }
44 56
45 void FakePowerManagerClient::DecreaseScreenBrightness(bool allow_off) { 57 void FakePowerManagerClient::DecreaseScreenBrightness(bool allow_off) {
46 } 58 }
47 59
48 void FakePowerManagerClient::IncreaseScreenBrightness() { 60 void FakePowerManagerClient::IncreaseScreenBrightness() {
49 } 61 }
50 62
51 void FakePowerManagerClient::SetScreenBrightnessPercent(double percent, 63 void FakePowerManagerClient::SetScreenBrightnessPercent(double percent,
52 bool gradual) { 64 bool gradual) {
53 } 65 }
54 66
55 void FakePowerManagerClient::GetScreenBrightnessPercent( 67 void FakePowerManagerClient::GetScreenBrightnessPercent(
56 const GetScreenBrightnessPercentCallback& callback) { 68 const GetScreenBrightnessPercentCallback& callback) {
57 } 69 }
58 70
59 void FakePowerManagerClient::DecreaseKeyboardBrightness() { 71 void FakePowerManagerClient::DecreaseKeyboardBrightness() {
60 } 72 }
61 73
62 void FakePowerManagerClient::IncreaseKeyboardBrightness() { 74 void FakePowerManagerClient::IncreaseKeyboardBrightness() {
63 } 75 }
64 76
65 void FakePowerManagerClient::RequestStatusUpdate() { 77 void FakePowerManagerClient::RequestStatusUpdate() {
78 UpdatePowerStatus();
66 } 79 }
67 80
68 void FakePowerManagerClient::RequestSuspend() { 81 void FakePowerManagerClient::RequestSuspend() {
69 } 82 }
70 83
71 void FakePowerManagerClient::RequestRestart() { 84 void FakePowerManagerClient::RequestRestart() {
72 ++num_request_restart_calls_; 85 ++num_request_restart_calls_;
73 } 86 }
74 87
75 void FakePowerManagerClient::RequestShutdown() { 88 void FakePowerManagerClient::RequestShutdown() {
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after
122 FOR_EACH_OBSERVER(Observer, observers_, DarkSuspendImminent()); 135 FOR_EACH_OBSERVER(Observer, observers_, DarkSuspendImminent());
123 } 136 }
124 137
125 void FakePowerManagerClient::SendPowerButtonEvent( 138 void FakePowerManagerClient::SendPowerButtonEvent(
126 bool down, 139 bool down,
127 const base::TimeTicks& timestamp) { 140 const base::TimeTicks& timestamp) {
128 FOR_EACH_OBSERVER(Observer, observers_, 141 FOR_EACH_OBSERVER(Observer, observers_,
129 PowerButtonEventReceived(down, timestamp)); 142 PowerButtonEventReceived(down, timestamp));
130 } 143 }
131 144
145 void FakePowerManagerClient::UpdateBatteryPercentage(int percentage) {
146 battery_percentage_ = percentage;
147 UpdatePowerStatus();
148 }
149
150 void FakePowerManagerClient::UpdateBatteryFullTimeToEmpty(int time_in_hours) {
151 hours_to_empty_full_battery_ = time_in_hours * 3600;
152 UpdatePowerStatus();
153 }
154
155 void FakePowerManagerClient::UpdateExternalPower(int power_source) {
156 power_source_ = power_source;
157 UpdatePowerStatus();
158 }
159
160 void FakePowerManagerClient::UpdateIsBatteryCharging(bool is_charging) {
161 is_charging_ = is_charging;
162 UpdatePowerStatus();
163 }
164
165 void FakePowerManagerClient::UpdateIsCalculatingBatteryTime(
166 bool is_calculating) {
167 is_calculating_ = is_calculating;
168 UpdatePowerStatus();
169 }
170
171 void FakePowerManagerClient::UpdatePowerStatus() {
172 int64 remaining_battery_time =
173 std::max(1, battery_percentage_ * hours_to_empty_full_battery_ / 100);
174
175 props_.Clear();
176
177 switch (power_source_) {
178 case 0:
179 // Say that the system is charging with AC connected or
180 // discharging without any charger connected.
181 props_.set_external_power(
182 !is_charging_
183 ? power_manager::PowerSupplyProperties_ExternalPower_DISCONNECTED
184 : power_manager::PowerSupplyProperties_ExternalPower_AC);
185 break;
186 case 1:
187 // Say that the system is charging on USB if charging is enabled
188 // (i.e. a low-power charger).
189 props_.set_external_power(
190 power_manager::PowerSupplyProperties_ExternalPower_USB);
191 break;
192 case 2:
193 // Say that the system is charging on AC if charging is enabled.
194 props_.set_external_power(
195 power_manager::PowerSupplyProperties_ExternalPower_AC);
196 break;
197 default:
198 NOTREACHED() << "Unhandled power source " << power_source_;
199 }
200
201 if (battery_percentage_ == 100 && is_charging_) {
202 props_.set_battery_state(
203 power_manager::PowerSupplyProperties_BatteryState_FULL);
204 } else if (is_charging_) {
205 props_.set_battery_state(
206 power_manager::PowerSupplyProperties_BatteryState_CHARGING);
207 props_.set_battery_time_to_full_sec(
208 std::max(static_cast<int64>(1),
209 hours_to_empty_full_battery_ - remaining_battery_time));
210 } else {
211 props_.set_battery_state(
212 power_manager::PowerSupplyProperties_BatteryState_DISCHARGING);
213 props_.set_battery_time_to_empty_sec(remaining_battery_time);
214 }
215
216 props_.set_is_calculating_battery_time(is_calculating_);
217 props_.set_battery_percent(battery_percentage_);
218
219 FOR_EACH_OBSERVER(Observer, observers_, PowerChanged(props_));
220 }
221
132 void FakePowerManagerClient::HandleSuspendReadiness() { 222 void FakePowerManagerClient::HandleSuspendReadiness() {
133 CHECK(num_pending_suspend_readiness_callbacks_ > 0); 223 CHECK(num_pending_suspend_readiness_callbacks_ > 0);
134 224
135 --num_pending_suspend_readiness_callbacks_; 225 --num_pending_suspend_readiness_callbacks_;
136 } 226 }
137 227
138 } // namespace chromeos 228 } // namespace chromeos
OLDNEW
« no previous file with comments | « chromeos/dbus/fake_power_manager_client.h ('k') | chromeos/dbus/power_manager_client.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698