Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #ifndef CHROME_BROWSER_BATTERY_STATUS_BATTERY_STATUS_MANAGER_H_ | 5 #ifndef CHROME_BROWSER_BATTERY_STATUS_BATTERY_STATUS_MANAGER_H_ |
| 6 #define CHROME_BROWSER_BATTERY_STATUS_BATTERY_STATUS_MANAGER_H_ | 6 #define CHROME_BROWSER_BATTERY_STATUS_BATTERY_STATUS_MANAGER_H_ |
| 7 | 7 |
| 8 #include "build/build_config.h" | 8 #include "build/build_config.h" |
| 9 | 9 |
| 10 #if defined(OS_ANDROID) | 10 #if defined(OS_ANDROID) |
| 11 #include "base/android/scoped_java_ref.h" | 11 #include "base/android/scoped_java_ref.h" |
| 12 #endif | 12 #endif |
| 13 | 13 |
| 14 #include "content/browser/battery_status/battery_status_update_callback.h" | 14 #include "content/browser/battery_status/battery_status_service.h" |
| 15 #include "content/common/content_export.h" | |
| 16 | 15 |
| 17 namespace content { | 16 namespace content { |
| 18 | 17 |
| 19 // Platform specific manager class for fetching battery status data. | 18 // Platform specific manager class for fetching battery status data. |
| 20 class CONTENT_EXPORT BatteryStatusManager { | 19 class BatteryStatusManager { |
| 21 public: | 20 public: |
| 22 explicit BatteryStatusManager(const BatteryStatusUpdateCallback& callback); | 21 explicit BatteryStatusManager( |
| 23 virtual ~BatteryStatusManager(); | 22 const BatteryStatusService::BatteryUpdateCallback& callback); |
| 23 virtual ~BatteryStatusManager() { } | |
|
jochen (gone - plz use gerrit)
2014/05/23 08:13:36
please keep non-trivial dtors in the .cc file (it'
timvolodine
2014/05/27 12:32:05
Done.
| |
| 24 | |
| 25 // Methods from BatteryStatusManagerInterface. | |
|
Michael van Ouwerkerk
2014/05/22 10:36:52
Nit: does this comment still apply?
timvolodine
2014/05/27 12:32:05
Done.
| |
| 24 | 26 |
| 25 // Start listening for battery status changes. New updates are signalled | 27 // Start listening for battery status changes. New updates are signalled |
| 26 // by invoking the callback provided at construction time. | 28 // by invoking the callback provided at construction time. |
| 27 bool StartListeningBatteryChange(); | 29 virtual bool StartListeningBatteryChange(); |
| 28 | 30 |
| 29 // Stop listenting for battery status changes. | 31 // Stop listening for battery status changes. |
| 30 void StopListeningBatteryChange(); | 32 virtual void StopListeningBatteryChange(); |
| 31 | 33 |
| 32 #if defined(OS_ANDROID) | 34 #if defined(OS_ANDROID) |
| 33 // Must be called at startup. | 35 // Must be called at startup. |
| 34 static bool Register(JNIEnv* env); | 36 static bool Register(JNIEnv* env); |
| 35 | 37 |
| 36 // Called from Java via JNI. | 38 // Called from Java via JNI. |
| 37 void GotBatteryStatus(JNIEnv*, jobject, jboolean charging, | 39 void GotBatteryStatus(JNIEnv*, jobject, jboolean charging, |
| 38 jdouble charging_time, jdouble discharging_time, | 40 jdouble charging_time, jdouble discharging_time, |
| 39 jdouble level); | 41 jdouble level); |
| 40 #endif | 42 #endif |
| 41 | 43 |
| 44 protected: | |
| 45 BatteryStatusManager() { } | |
| 46 BatteryStatusService::BatteryUpdateCallback callback_; | |
| 47 | |
| 42 private: | 48 private: |
| 43 #if defined(OS_ANDROID) | 49 #if defined(OS_ANDROID) |
| 44 // Java provider of battery status info. | 50 // Java provider of battery status info. |
| 45 base::android::ScopedJavaGlobalRef<jobject> j_manager_; | 51 base::android::ScopedJavaGlobalRef<jobject> j_manager_; |
| 46 #endif | 52 #endif |
| 47 BatteryStatusUpdateCallback callback_; | |
| 48 | 53 |
| 49 DISALLOW_COPY_AND_ASSIGN(BatteryStatusManager); | 54 DISALLOW_COPY_AND_ASSIGN(BatteryStatusManager); |
| 50 }; | 55 }; |
| 51 | 56 |
| 52 } // namespace content | 57 } // namespace content |
| 53 | 58 |
| 54 #endif // CHROME_BROWSER_BATTERY_STATUS_BATTERY_STATUS_MANAGER_H_ | 59 #endif // CHROME_BROWSER_BATTERY_STATUS_BATTERY_STATUS_MANAGER_H_ |
| OLD | NEW |