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

Side by Side Diff: content/browser/power_monitor_message_broadcaster.cc

Issue 17074009: Created multi-process-friendly PowerMonitor interface. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Wired up to all child processes, as requested by @jam Created 7 years, 4 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
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "content/browser/power_monitor_message_broadcaster.h"
6
7 #include "base/power_monitor/power_monitor.h"
8 #include "content/common/power_monitor_messages.h"
9 #include "ipc/ipc_sender.h"
10
11 namespace content {
12
13 PowerMonitorMessageFilter::PowerMonitorMessageFilter() {
14 BrowserThread::PostTask(
15 BrowserThread::UI,
16 FROM_HERE,
17 base::Bind(
18 &PowerMonitorMessageFilter::CreateBroadcaster,
19 base::Unretained(this)));
piman 2013/07/29 21:18:18 What prevents the filter from being destroyed befo
20 }
21
22 PowerMonitorMessageFilter::~PowerMonitorMessageFilter() {
23 }
24
25 void PowerMonitorMessageFilter::OnChannelClosing() {
26 BrowserMessageFilter::OnChannelClosing();
27
28 BrowserThread::PostTask(
29 BrowserThread::UI,
30 FROM_HERE,
31 base::Bind(
32 &PowerMonitorMessageFilter::DisableBroadcaster,
33 base::Unretained(this)));
piman 2013/07/29 21:18:18 What prevents the filter from being destroyed befo
bajones 2013/07/29 21:33:36 I'll switch this and the prior post task over to p
piman 2013/07/29 21:40:50 That won't work. WeakPtrs are only safe if the ins
34 }
35
36 bool PowerMonitorMessageFilter::OnMessageReceived(
37 const IPC::Message& message,
38 bool* message_was_ok) {
39 return false; // No messages to handle
40 }
41
42 void PowerMonitorMessageFilter::CreateBroadcaster() {
43 broadcaster_ = new PowerMonitorMessageBroadcaster(this);
44 }
45
46 void PowerMonitorMessageFilter::DisableBroadcaster() {
47 broadcaster_->RemoveSender();
48 }
49
50 PowerMonitorMessageBroadcaster::PowerMonitorMessageBroadcaster(
51 IPC::Sender* sender)
52 : sender_(sender) {
53 base::PowerMonitor* power_monitor = base::PowerMonitor::Get();
54 if (power_monitor)
55 power_monitor->AddObserver(this);
56 }
57
58 PowerMonitorMessageBroadcaster::~PowerMonitorMessageBroadcaster() {
59 base::PowerMonitor* power_monitor = base::PowerMonitor::Get();
60 if (power_monitor)
61 power_monitor->RemoveObserver(this);
piman 2013/07/29 21:18:18 Because this class is refcounted, it may be destro
bajones 2013/07/29 21:33:36 Please see the class declaration. The RefCountedTh
62 }
63
64 void PowerMonitorMessageBroadcaster::RemoveSender() {
65 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
66 sender_ = NULL;
67 }
68
69 void PowerMonitorMessageBroadcaster::OnPowerStateChange(bool on_battery_power) {
70 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
71 if (sender_)
72 sender_->Send(new PowerMonitorMsg_PowerStateChange(on_battery_power));
piman 2013/07/29 21:18:18 This is unsafe: sender_ is the message filter, whi
bajones 2013/07/29 21:33:36 I just realized that by allowing the constructor t
73 }
74
75 void PowerMonitorMessageBroadcaster::OnSuspend() {
76 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
77 if (sender_)
78 sender_->Send(new PowerMonitorMsg_Suspend());
79 }
80
81 void PowerMonitorMessageBroadcaster::OnResume() {
82 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
83 if (sender_)
84 sender_->Send(new PowerMonitorMsg_Resume());
85 }
86
87 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698