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

Unified Diff: chromeos/power/power_data_collector.cc

Issue 101963004: [chromeos] New PowerManagerClient observer to collect power data. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chromeos/power/power_data_collector.h ('k') | chromeos/power/power_data_collector_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chromeos/power/power_data_collector.cc
diff --git a/chromeos/power/power_data_collector.cc b/chromeos/power/power_data_collector.cc
new file mode 100644
index 0000000000000000000000000000000000000000..8c614539d368d054498c4674508bc63891578382
--- /dev/null
+++ b/chromeos/power/power_data_collector.cc
@@ -0,0 +1,70 @@
+// Copyright (c) 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chromeos/power/power_data_collector.h"
+
+#include "base/logging.h"
+#include "chromeos/dbus/dbus_thread_manager.h"
+#include "chromeos/dbus/power_manager/power_supply_properties.pb.h"
+
+namespace chromeos {
+
+namespace {
+
+// The global PowerDataCollector instance.
+PowerDataCollector* g_power_data_collector = NULL;
+
+} // namespace
+
+// static
+void PowerDataCollector::Initialize() {
+ // Check that power data collector is initialized only after the
+ // DBusThreadManager is initialized.
+ CHECK(DBusThreadManager::Get());
+ CHECK(g_power_data_collector == NULL);
+ g_power_data_collector = new PowerDataCollector();
+}
+
+// static
+void PowerDataCollector::Shutdown() {
+ // Shutdown only if initialized.
+ CHECK(g_power_data_collector);
+ delete g_power_data_collector;
+ g_power_data_collector = NULL;
+}
+
+// static
+PowerDataCollector* PowerDataCollector::Get() {
+ CHECK(g_power_data_collector);
+ return g_power_data_collector;
+}
+
+void PowerDataCollector::PowerChanged(
+ const power_manager::PowerSupplyProperties& prop) {
+ PowerSupplySnapshot snapshot;
+ snapshot.time = base::TimeTicks::Now();
+ snapshot.external_power = (prop.external_power() !=
+ power_manager::PowerSupplyProperties::DISCONNECTED);
+ snapshot.battery_percent = prop.battery_percent();
+
+ power_supply_data_.push_back(snapshot);
+}
+
+PowerDataCollector::PowerDataCollector() {
+ DBusThreadManager::Get()->GetPowerManagerClient()->AddObserver(this);
+}
+
+PowerDataCollector::~PowerDataCollector() {
+ DBusThreadManager* dbus_manager = DBusThreadManager::Get();
+ CHECK(dbus_manager);
+ dbus_manager->GetPowerManagerClient()->RemoveObserver(this);
+}
+
+PowerDataCollector::PowerSupplySnapshot::PowerSupplySnapshot()
+ : time(base::TimeTicks::Now()),
+ external_power(false),
+ battery_percent(0) {
+}
+
+} // namespace chromeos
« no previous file with comments | « chromeos/power/power_data_collector.h ('k') | chromeos/power/power_data_collector_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698