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

Side by Side Diff: chromeos/dbus/power_policy_controller.h

Issue 129303003: Revert of Revert of chromeos: Don't send empty power management policies. (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
« no previous file with comments | « chromeos/dbus/fake_power_manager_client.cc ('k') | chromeos/dbus/power_policy_controller.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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 #ifndef CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_ 5 #ifndef CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_
6 #define CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_ 6 #define CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_
7 7
8 #include <map> 8 #include <map>
9 #include <string> 9 #include <string>
10 10
11 #include "base/basictypes.h" 11 #include "base/basictypes.h"
12 #include "base/compiler_specific.h" 12 #include "base/compiler_specific.h"
13 #include "chromeos/chromeos_export.h" 13 #include "chromeos/chromeos_export.h"
14 #include "chromeos/dbus/dbus_thread_manager_observer.h"
15 #include "chromeos/dbus/power_manager/policy.pb.h" 14 #include "chromeos/dbus/power_manager/policy.pb.h"
16 #include "chromeos/dbus/power_manager_client.h" 15 #include "chromeos/dbus/power_manager_client.h"
17 16
18 namespace chromeos { 17 namespace chromeos {
19 18
20 class DBusThreadManager; 19 class DBusThreadManager;
21 20
22 // PowerPolicyController is responsible for sending Chrome's assorted power 21 // PowerPolicyController is responsible for sending Chrome's assorted power
23 // management preferences to the Chrome OS power manager. 22 // management preferences to the Chrome OS power manager.
24 class CHROMEOS_EXPORT PowerPolicyController 23 class CHROMEOS_EXPORT PowerPolicyController
25 : public DBusThreadManagerObserver, 24 : public PowerManagerClient::Observer {
26 public PowerManagerClient::Observer {
27 public: 25 public:
28 // Note: Do not change these values; they are used by preferences. 26 // Note: Do not change these values; they are used by preferences.
29 enum Action { 27 enum Action {
30 ACTION_SUSPEND = 0, 28 ACTION_SUSPEND = 0,
31 ACTION_STOP_SESSION = 1, 29 ACTION_STOP_SESSION = 1,
32 ACTION_SHUT_DOWN = 2, 30 ACTION_SHUT_DOWN = 2,
33 ACTION_DO_NOTHING = 3, 31 ACTION_DO_NOTHING = 3,
34 }; 32 };
35 33
36 // Values of various power-management-related preferences. 34 // Values of various power-management-related preferences.
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
72 static const int kScreenLockAfterOffDelayMs; 70 static const int kScreenLockAfterOffDelayMs;
73 71
74 PowerPolicyController(); 72 PowerPolicyController();
75 virtual ~PowerPolicyController(); 73 virtual ~PowerPolicyController();
76 74
77 void Init(DBusThreadManager* manager); 75 void Init(DBusThreadManager* manager);
78 76
79 // Updates |prefs_policy_| with |values| and sends an updated policy. 77 // Updates |prefs_policy_| with |values| and sends an updated policy.
80 void ApplyPrefs(const PrefValues& values); 78 void ApplyPrefs(const PrefValues& values);
81 79
82 // Resets |prefs_policy_| to its defaults and sends an updated policy.
83 void ClearPrefs();
84
85 // Registers a request to temporarily prevent the screen from getting 80 // Registers a request to temporarily prevent the screen from getting
86 // dimmed or turned off or the system from suspending in response to user 81 // dimmed or turned off or the system from suspending in response to user
87 // inactivity and sends an updated policy. |reason| is a human-readable 82 // inactivity and sends an updated policy. |reason| is a human-readable
88 // description of the reason the lock was created. Returns a unique ID 83 // description of the reason the lock was created. Returns a unique ID
89 // that can be passed to RemoveWakeLock() later. 84 // that can be passed to RemoveWakeLock() later.
90 int AddScreenWakeLock(const std::string& reason); 85 int AddScreenWakeLock(const std::string& reason);
91 int AddSystemWakeLock(const std::string& reason); 86 int AddSystemWakeLock(const std::string& reason);
92 87
93 // Unregisters a request previously created via AddScreenWakeLock() or 88 // Unregisters a request previously created via AddScreenWakeLock() or
94 // AddSystemWakeLock() and sends an updated policy. 89 // AddSystemWakeLock() and sends an updated policy.
95 void RemoveWakeLock(int id); 90 void RemoveWakeLock(int id);
96 91
97 // DBusThreadManagerObserver implementation:
98 virtual void OnDBusThreadManagerDestroying(DBusThreadManager* manager)
99 OVERRIDE;
100
101 // PowerManagerClient::Observer implementation: 92 // PowerManagerClient::Observer implementation:
102 virtual void PowerManagerRestarted() OVERRIDE; 93 virtual void PowerManagerRestarted() OVERRIDE;
103 94
104 private: 95 private:
105 friend class PowerPrefsTest; 96 friend class PowerPrefsTest;
106 97
107 typedef std::map<int, std::string> WakeLockMap; 98 typedef std::map<int, std::string> WakeLockMap;
108 99
109 // Sends a policy based on |prefs_policy_| to the power manager. 100 // Sends a policy based on |prefs_policy_| to the power manager.
110 void SendCurrentPolicy(); 101 void SendCurrentPolicy();
111 102
112 // Sends an empty policy to the power manager to reset its configuration. 103 PowerManagerClient* client_; // weak
113 void SendEmptyPolicy();
114
115 DBusThreadManager* manager_; // not owned
116 PowerManagerClient* client_; // not owned
117 104
118 // Policy derived from values passed to ApplyPrefs(). 105 // Policy derived from values passed to ApplyPrefs().
119 power_manager::PowerManagementPolicy prefs_policy_; 106 power_manager::PowerManagementPolicy prefs_policy_;
120 107
121 // Was ApplyPrefs() called? 108 // Was ApplyPrefs() called?
122 bool prefs_were_set_; 109 bool prefs_were_set_;
123 110
124 // Maps from an ID representing a request to prevent the screen from 111 // Maps from an ID representing a request to prevent the screen from
125 // getting dimmed or turned off or to prevent the system from suspending 112 // getting dimmed or turned off or to prevent the system from suspending
126 // to the reason for the request. 113 // to the reason for the request.
127 WakeLockMap screen_wake_locks_; 114 WakeLockMap screen_wake_locks_;
128 WakeLockMap system_wake_locks_; 115 WakeLockMap system_wake_locks_;
129 116
130 // Should entries in |screen_wake_locks_| be honored? If false, screen 117 // Should entries in |screen_wake_locks_| be honored? If false, screen
131 // wake locks are just treated as system wake locks instead. 118 // wake locks are just treated as system wake locks instead.
132 bool honor_screen_wake_locks_; 119 bool honor_screen_wake_locks_;
133 120
134 // Next ID to be used by AddScreenWakeLock() or AddSystemWakeLock(). 121 // Next ID to be used by AddScreenWakeLock() or AddSystemWakeLock().
135 int next_wake_lock_id_; 122 int next_wake_lock_id_;
136 123
137 DISALLOW_COPY_AND_ASSIGN(PowerPolicyController); 124 DISALLOW_COPY_AND_ASSIGN(PowerPolicyController);
138 }; 125 };
139 126
140 } // namespace chromeos 127 } // namespace chromeos
141 128
142 #endif // CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_ 129 #endif // CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_
OLDNEW
« no previous file with comments | « chromeos/dbus/fake_power_manager_client.cc ('k') | chromeos/dbus/power_policy_controller.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698