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

Unified Diff: extensions/browser/api/power/power_api_manager.cc

Issue 958313002: [CleanUp] Move PowerApiManager to power_api and Rename (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rename to PowerAPI Created 5 years, 10 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 side-by-side diff with in-line comments
Download patch
Index: extensions/browser/api/power/power_api_manager.cc
diff --git a/extensions/browser/api/power/power_api_manager.cc b/extensions/browser/api/power/power_api_manager.cc
deleted file mode 100644
index 642e794978792ac462c894b091e6b53064ab6a86..0000000000000000000000000000000000000000
--- a/extensions/browser/api/power/power_api_manager.cc
+++ /dev/null
@@ -1,116 +0,0 @@
-// Copyright 2014 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "extensions/browser/api/power/power_api_manager.h"
-
-#include "base/bind.h"
-#include "base/lazy_instance.h"
-#include "extensions/browser/extension_registry.h"
-#include "extensions/common/extension.h"
-
-namespace extensions {
-
-namespace {
-
-const char kPowerSaveBlockerDescription[] = "extension";
-
-content::PowerSaveBlocker::PowerSaveBlockerType
-LevelToPowerSaveBlockerType(core_api::power::Level level) {
- switch (level) {
- case core_api::power::LEVEL_SYSTEM:
- return content::PowerSaveBlocker::kPowerSaveBlockPreventAppSuspension;
- case core_api::power::LEVEL_DISPLAY: // fallthrough
- case core_api::power::LEVEL_NONE:
- return content::PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep;
- }
- NOTREACHED() << "Unhandled level " << level;
- return content::PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep;
-}
-
-base::LazyInstance<BrowserContextKeyedAPIFactory<PowerApiManager> > g_factory =
- LAZY_INSTANCE_INITIALIZER;
-
-} // namespace
-
-// static
-PowerApiManager* PowerApiManager::Get(content::BrowserContext* context) {
- return BrowserContextKeyedAPIFactory<PowerApiManager>::Get(context);
-}
-
-// static
-BrowserContextKeyedAPIFactory<PowerApiManager>*
-PowerApiManager::GetFactoryInstance() {
- return g_factory.Pointer();
-}
-
-void PowerApiManager::AddRequest(const std::string& extension_id,
- core_api::power::Level level) {
- extension_levels_[extension_id] = level;
- UpdatePowerSaveBlocker();
-}
-
-void PowerApiManager::RemoveRequest(const std::string& extension_id) {
- extension_levels_.erase(extension_id);
- UpdatePowerSaveBlocker();
-}
-
-void PowerApiManager::SetCreateBlockerFunctionForTesting(
- CreateBlockerFunction function) {
- create_blocker_function_ = !function.is_null() ? function :
- base::Bind(&content::PowerSaveBlocker::Create);
-}
-
-void PowerApiManager::OnExtensionUnloaded(
- content::BrowserContext* browser_context,
- const Extension* extension,
- UnloadedExtensionInfo::Reason reason) {
- RemoveRequest(extension->id());
- UpdatePowerSaveBlocker();
-}
-
-PowerApiManager::PowerApiManager(content::BrowserContext* context)
- : browser_context_(context),
- create_blocker_function_(base::Bind(&content::PowerSaveBlocker::Create)),
- current_level_(core_api::power::LEVEL_SYSTEM) {
- ExtensionRegistry::Get(browser_context_)->AddObserver(this);
-}
-
-PowerApiManager::~PowerApiManager() {}
-
-void PowerApiManager::UpdatePowerSaveBlocker() {
- if (extension_levels_.empty()) {
- power_save_blocker_.reset();
- return;
- }
-
- core_api::power::Level new_level = core_api::power::LEVEL_SYSTEM;
- for (ExtensionLevelMap::const_iterator it = extension_levels_.begin();
- it != extension_levels_.end(); ++it) {
- if (it->second == core_api::power::LEVEL_DISPLAY)
- new_level = it->second;
- }
-
- // If the level changed and we need to create a new blocker, do a swap
- // to ensure that there isn't a brief period where power management is
- // unblocked.
- if (!power_save_blocker_ || new_level != current_level_) {
- content::PowerSaveBlocker::PowerSaveBlockerType type =
- LevelToPowerSaveBlockerType(new_level);
- scoped_ptr<content::PowerSaveBlocker> new_blocker(
- create_blocker_function_.Run(type,
- content::PowerSaveBlocker::kReasonOther,
- kPowerSaveBlockerDescription));
- power_save_blocker_.swap(new_blocker);
- current_level_ = new_level;
- }
-}
-
-void PowerApiManager::Shutdown() {
- // Unregister here rather than in the d'tor; otherwise this call will recreate
- // the already-deleted ExtensionRegistry.
- ExtensionRegistry::Get(browser_context_)->RemoveObserver(this);
- power_save_blocker_.reset();
-}
-
-} // namespace extensions
« no previous file with comments | « extensions/browser/api/power/power_api_manager.h ('k') | extensions/browser/api/power/power_api_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698