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

Side by Side Diff: chromeos/power/power_data_collector.cc

Issue 134623002: [chromeos] Limit the data samples stored by PowerDataCollector. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 11 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 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 "chromeos/power/power_data_collector.h" 5 #include "chromeos/power/power_data_collector.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "chromeos/dbus/dbus_thread_manager.h" 8 #include "chromeos/dbus/dbus_thread_manager.h"
9 #include "chromeos/dbus/power_manager/power_supply_properties.pb.h" 9 #include "chromeos/dbus/power_manager/power_supply_properties.pb.h"
10 10
11 namespace chromeos { 11 namespace chromeos {
12 12
13 namespace { 13 namespace {
14 14
15 // The global PowerDataCollector instance. 15 // The global PowerDataCollector instance.
16 PowerDataCollector* g_power_data_collector = NULL; 16 PowerDataCollector* g_power_data_collector = NULL;
17 17
18 } // namespace 18 } // namespace
19 19
20 const unsigned int PowerDataCollector::kSampleCountTimeLimitSec =
21 24 * 60 * 60;
22
20 // static 23 // static
21 void PowerDataCollector::Initialize() { 24 void PowerDataCollector::Initialize() {
22 // Check that power data collector is initialized only after the 25 // Check that power data collector is initialized only after the
23 // DBusThreadManager is initialized. 26 // DBusThreadManager is initialized.
24 CHECK(DBusThreadManager::Get()); 27 CHECK(DBusThreadManager::Get());
25 CHECK(g_power_data_collector == NULL); 28 CHECK(g_power_data_collector == NULL);
26 g_power_data_collector = new PowerDataCollector(); 29 g_power_data_collector = new PowerDataCollector();
27 } 30 }
28 31
29 // static 32 // static
(...skipping 10 matching lines...) Expand all
40 return g_power_data_collector; 43 return g_power_data_collector;
41 } 44 }
42 45
43 void PowerDataCollector::PowerChanged( 46 void PowerDataCollector::PowerChanged(
44 const power_manager::PowerSupplyProperties& prop) { 47 const power_manager::PowerSupplyProperties& prop) {
45 PowerSupplySnapshot snapshot; 48 PowerSupplySnapshot snapshot;
46 snapshot.time = base::TimeTicks::Now(); 49 snapshot.time = base::TimeTicks::Now();
47 snapshot.external_power = (prop.external_power() != 50 snapshot.external_power = (prop.external_power() !=
48 power_manager::PowerSupplyProperties::DISCONNECTED); 51 power_manager::PowerSupplyProperties::DISCONNECTED);
49 snapshot.battery_percent = prop.battery_percent(); 52 snapshot.battery_percent = prop.battery_percent();
50 53 AddSnapshot(snapshot);
51 power_supply_data_.push_back(snapshot);
52 } 54 }
53 55
54 PowerDataCollector::PowerDataCollector() { 56 PowerDataCollector::PowerDataCollector() {
55 DBusThreadManager::Get()->GetPowerManagerClient()->AddObserver(this); 57 DBusThreadManager::Get()->GetPowerManagerClient()->AddObserver(this);
56 } 58 }
57 59
58 PowerDataCollector::~PowerDataCollector() { 60 PowerDataCollector::~PowerDataCollector() {
59 DBusThreadManager* dbus_manager = DBusThreadManager::Get(); 61 DBusThreadManager* dbus_manager = DBusThreadManager::Get();
60 CHECK(dbus_manager); 62 CHECK(dbus_manager);
61 dbus_manager->GetPowerManagerClient()->RemoveObserver(this); 63 dbus_manager->GetPowerManagerClient()->RemoveObserver(this);
62 } 64 }
63 65
66 void PowerDataCollector::AddSnapshot(const PowerSupplySnapshot& snapshot) {
67 while (power_supply_data_.size() > 0) {
68 PowerSupplySnapshot first = power_supply_data_.front();
69 if (snapshot.time - first.time >=
70 base::TimeDelta::FromSeconds(kSampleCountTimeLimitSec)) {
71 power_supply_data_.pop_front();
72 } else {
73 break;
74 }
75 }
76 power_supply_data_.push_back(snapshot);
77 }
78
64 PowerDataCollector::PowerSupplySnapshot::PowerSupplySnapshot() 79 PowerDataCollector::PowerSupplySnapshot::PowerSupplySnapshot()
65 : time(base::TimeTicks::Now()), 80 : time(base::TimeTicks::Now()),
66 external_power(false), 81 external_power(false),
67 battery_percent(0) { 82 battery_percent(0) {
68 } 83 }
69 84
70 } // namespace chromeos 85 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698