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

Side by Side Diff: chrome/browser/extensions/api/power/power_api_manager.cc

Issue 12576018: Add chrome.power extension API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: apply review feedback Created 7 years, 9 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 (c) 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 "chrome/browser/extensions/api/power/power_api_manager.h"
6
7 #include "base/bind.h"
8 #include "chrome/common/chrome_notification_types.h"
9 #include "chrome/common/extensions/extension.h"
10 #include "content/public/browser/notification_service.h"
11
12 namespace extensions {
13
14 namespace {
15
16 const char kPowerSaveBlockerReason[] = "extension";
17
18 content::PowerSaveBlocker::PowerSaveBlockerType
19 LevelToPowerSaveBlockerType(api::power::Level level) {
20 switch (level) {
21 case api::power::LEVEL_SYSTEM:
22 return content::PowerSaveBlocker::kPowerSaveBlockPreventAppSuspension;
23 case api::power::LEVEL_DISPLAY: // fallthrough
24 case api::power::LEVEL_NONE:
25 return content::PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep;
26 }
27 NOTREACHED() << "Unhandled level " << level;
28 return content::PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep;
29 }
30
31 } // namespace
32
33 // static
34 PowerApiManager* PowerApiManager::GetInstance() {
35 return Singleton<PowerApiManager>::get();
36 }
37
38 void PowerApiManager::AddRequest(const std::string& extension_id,
39 api::power::Level level) {
40 extension_levels_[extension_id] = level;
41 UpdatePowerSaveBlocker();
42 }
43
44 void PowerApiManager::RemoveRequest(const std::string& extension_id) {
45 extension_levels_.erase(extension_id);
46 UpdatePowerSaveBlocker();
47 }
48
49 void PowerApiManager::SetCreateBlockerFunctionForTesting(
50 CreateBlockerFunction function) {
51 create_blocker_function_ = function;
52 if (create_blocker_function_.is_null())
53 create_blocker_function_ = base::Bind(&content::PowerSaveBlocker::Create);
not at google - send to devlin 2013/03/20 00:25:50 if you like ternary
Daniel Erat 2013/03/20 00:47:46 Done.
54 }
55
56 void PowerApiManager::Observe(int type,
57 const content::NotificationSource& source,
58 const content::NotificationDetails& details) {
59 switch (type) {
60 case chrome::NOTIFICATION_EXTENSION_UNLOADED:
61 RemoveRequest(content::Details<extensions::UnloadedExtensionInfo>(
62 details)->extension->id());
63 UpdatePowerSaveBlocker();
64 break;
65 case chrome::NOTIFICATION_APP_TERMINATING:
66 power_save_blocker_.reset();
67 break;
68 default:
69 NOTREACHED() << "Unexpected notification " << type;
70 }
71 }
72
73 PowerApiManager::PowerApiManager()
74 : create_blocker_function_(base::Bind(&content::PowerSaveBlocker::Create)),
75 current_level_(api::power::LEVEL_SYSTEM) {
76 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_UNLOADED,
77 content::NotificationService::AllSources());
78 registrar_.Add(this, chrome::NOTIFICATION_APP_TERMINATING,
79 content::NotificationService::AllSources());
80 }
81
82 PowerApiManager::~PowerApiManager() {}
83
84 void PowerApiManager::UpdatePowerSaveBlocker() {
85 if (extension_levels_.empty()) {
86 power_save_blocker_.reset();
87 return;
88 }
89
90 api::power::Level new_level = api::power::LEVEL_SYSTEM;
91 for (ExtensionLevelMap::const_iterator it = extension_levels_.begin();
92 it != extension_levels_.end(); ++it) {
93 if (it->second == api::power::LEVEL_DISPLAY)
94 new_level = it->second;
95 }
96
97 // If the level changed and we need to create a new blocker, do a swap
98 // to ensure that there isn't a brief period where power management is
99 // unblocked.
100 if (!power_save_blocker_ || new_level != current_level_) {
101 content::PowerSaveBlocker::PowerSaveBlockerType type =
102 LevelToPowerSaveBlockerType(new_level);
103 scoped_ptr<content::PowerSaveBlocker> new_blocker(
104 create_blocker_function_.Run(type, kPowerSaveBlockerReason));
105 power_save_blocker_.swap(new_blocker);
106 current_level_ = new_level;
107 }
108 }
109
110 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698