Index: content/common/power_monitor_broadcast_source.h |
diff --git a/content/common/power_monitor_broadcast_source.h b/content/common/power_monitor_broadcast_source.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..86c63561855c26a51a2eb6f5c07edc4ffac46b3d |
--- /dev/null |
+++ b/content/common/power_monitor_broadcast_source.h |
@@ -0,0 +1,59 @@ |
+// 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. |
+ |
+#ifndef CONTENT_COMMON_POWER_MONITOR_BROADCAST_SOURCE_H_ |
+#define CONTENT_COMMON_POWER_MONITOR_BROADCAST_SOURCE_H_ |
+ |
+#include "base/memory/weak_ptr.h" |
+#include "base/power_monitor/power_monitor_source.h" |
+#include "ipc/ipc_channel.h" |
+#include "ipc/ipc_channel_proxy.h" |
+ |
+namespace content { |
+ |
+class PowerMonitorBroadcastSource : public base::PowerMonitorSource { |
vandebo (ex-Chrome)
2013/07/09 22:22:08
Definitely need a comment on this class. It's a P
|
+ public: |
+ PowerMonitorBroadcastSource(); |
+ virtual ~PowerMonitorBroadcastSource(); |
+ |
+ IPC::ChannelProxy::MessageFilter* MessageFilter(); |
+ |
+ private: |
+ friend class PowerMonitorMessageFilter; |
+ |
+ class PowerMessageFilter : public IPC::ChannelProxy::MessageFilter { |
+ public: |
+ explicit PowerMessageFilter( |
+ base::WeakPtr<PowerMonitorBroadcastSource> source); |
+ |
+ virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE; |
+ |
+ private: |
+ friend class base::RefCounted<PowerMessageFilter>; |
+ |
+ virtual ~PowerMessageFilter(); |
+ |
+ void OnPowerStateChange(bool on_battery_power); |
+ void OnSuspend(); |
+ void OnResume(); |
+ |
+ base::WeakPtr<PowerMonitorBroadcastSource> source_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(PowerMessageFilter); |
+ }; |
+ |
+ virtual bool IsBatteryPower() OVERRIDE; |
+ |
+ void OnPowerStateChange(bool on_battery_power); |
+ void OnSuspend(); |
+ void OnResume(); |
+ |
+ bool on_battery_power_; |
vandebo (ex-Chrome)
2013/07/09 22:22:08
Oh man, this is confusing... Is there a name that
|
+ scoped_refptr<PowerMessageFilter> message_filter_; |
+ base::WeakPtrFactory<PowerMonitorBroadcastSource> weak_factory_; |
+}; |
+ |
+} // namespace content |
+ |
+#endif // CONTENT_COMMON_POWER_MONITOR_MESSAGE_FILTER_H_ |