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

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: update PermissionsTest.PermissionMessages 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) 2012 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 "chrome/common/chrome_notification_types.h"
8 #include "chrome/common/extensions/extension.h"
9 #include "content/public/browser/notification_service.h"
10
11 namespace extensions {
12
13 namespace {
14
15 const char kPowerSaveBlockerReason[] = "extension";
16
17 content::PowerSaveBlocker::PowerSaveBlockerType
18 LevelToPowerSaveBlockerType(PowerApiManager::Level level) {
19 switch (level) {
20 case PowerApiManager::LEVEL_SYSTEM:
21 return content::PowerSaveBlocker::kPowerSaveBlockPreventAppSuspension;
22 case PowerApiManager::LEVEL_DISPLAY:
23 return content::PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep;
24 }
25 NOTREACHED() << "Unhandled level " << level;
26 return content::PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep;
27 }
28
29 } // namespace
30
31 // static
32 PowerApiManager* PowerApiManager::GetInstance() {
33 return Singleton<PowerApiManager>::get();
34 }
35
36 void PowerApiManager::AddRequest(const std::string& extension_id, Level level) {
37 extension_levels_[extension_id] = level;
38 UpdatePowerSaveBlocker();
39 }
40
41 void PowerApiManager::RemoveRequest(const std::string& extension_id) {
42 extension_levels_.erase(extension_id);
43 UpdatePowerSaveBlocker();
44 }
45
46 void PowerApiManager::Observe(int type,
47 const content::NotificationSource& source,
48 const content::NotificationDetails& details) {
49 if (type == chrome::NOTIFICATION_EXTENSION_UNLOADED) {
not at google - send to devlin 2013/03/19 21:16:39 prefer switch
Daniel Erat 2013/03/19 23:39:38 Done.
50 RemoveRequest(content::Details<extensions::UnloadedExtensionInfo>(details)->
51 extension->id());
52 UpdatePowerSaveBlocker();
53 } else if (type == chrome::NOTIFICATION_APP_TERMINATING) {
54 power_save_blocker_.reset();
55 } else {
56 NOTREACHED() << "Unexpected notification " << type;
57 }
58 }
59
60 PowerApiManager::PowerApiManager() : current_level_(LEVEL_SYSTEM) {
61 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_UNLOADED,
62 content::NotificationService::AllSources());
63 registrar_.Add(this, chrome::NOTIFICATION_APP_TERMINATING,
64 content::NotificationService::AllSources());
65 }
66
67 PowerApiManager::~PowerApiManager() {}
68
69 void PowerApiManager::UpdatePowerSaveBlocker() {
70 if (extension_levels_.empty()) {
71 power_save_blocker_.reset();
not at google - send to devlin 2013/03/19 21:16:39 nit: early return
Daniel Erat 2013/03/19 23:39:38 Done.
72 } else {
73 Level new_level = LEVEL_SYSTEM;
74 for (ExtensionLevelMap::const_iterator it = extension_levels_.begin();
75 it != extension_levels_.end(); ++it) {
76 if (it->second > new_level)
77 new_level = it->second;
78 }
79
80 // If the level changed and we need to create a new blocker, do a swap
81 // to ensure that there isn't a brief period where power management is
82 // unblocked.
83 if (!power_save_blocker_.get() || new_level != current_level_) {
not at google - send to devlin 2013/03/19 21:16:39 .get() unnecessary
Daniel Erat 2013/03/19 23:39:38 Done.
84 content::PowerSaveBlocker::PowerSaveBlockerType type =
85 LevelToPowerSaveBlockerType(new_level);
86 scoped_ptr<content::PowerSaveBlocker> new_blocker(
87 create_blocker_function_.get() ?
not at google - send to devlin 2013/03/19 21:16:39 .get() unnecessary
Daniel Erat 2013/03/19 23:39:38 Done.
88 create_blocker_function_->Run(type, kPowerSaveBlockerReason) :
89 content::PowerSaveBlocker::Create(type, kPowerSaveBlockerReason));
not at google - send to devlin 2013/03/19 21:16:39 could you initialize create_blocker_function_ to c
Daniel Erat 2013/03/19 23:39:38 Done.
90 power_save_blocker_.swap(new_blocker);
91 current_level_ = new_level;
92 }
93 }
94 }
95
96 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698