OLD | NEW |
---|---|
(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 | |
OLD | NEW |