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

Unified Diff: chrome/browser/chromeos/extensions/power/power_api_manager.cc

Issue 12576018: Add chrome.power extension API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: add copyright notice to example extension 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/extensions/power/power_api_manager.cc
diff --git a/chrome/browser/chromeos/extensions/power/power_api_manager.cc b/chrome/browser/chromeos/extensions/power/power_api_manager.cc
deleted file mode 100644
index f5627ab5b9b699b33351ae3a72a44ed531d4513b..0000000000000000000000000000000000000000
--- a/chrome/browser/chromeos/extensions/power/power_api_manager.cc
+++ /dev/null
@@ -1,69 +0,0 @@
-// Copyright (c) 2012 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 "chrome/browser/chromeos/extensions/power/power_api_manager.h"
-
-#include "chrome/common/chrome_notification_types.h"
-#include "chrome/common/extensions/extension.h"
-#include "chromeos/power/power_state_override.h"
-#include "content/public/browser/notification_service.h"
-
-namespace extensions {
-namespace power {
-
-// static
-PowerApiManager* PowerApiManager::GetInstance() {
- return Singleton<PowerApiManager>::get();
-}
-
-void PowerApiManager::AddExtensionLock(const std::string& extension_id) {
- extension_ids_set_.insert(extension_id);
- UpdatePowerSettings();
-}
-
-void PowerApiManager::RemoveExtensionLock(const std::string& extension_id) {
- extension_ids_set_.erase(extension_id);
- UpdatePowerSettings();
-}
-
-void PowerApiManager::Observe(int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) {
- if (type == chrome::NOTIFICATION_EXTENSION_UNLOADED) {
- RemoveExtensionLock(
- content::Details<extensions::UnloadedExtensionInfo>(details)->
- extension->id());
- UpdatePowerSettings();
- } else if (type == chrome::NOTIFICATION_APP_TERMINATING) {
- // If the Chrome app is terminating, ensure we release our power overrides.
- power_state_override_ = NULL;
- } else {
- NOTREACHED() << "Unexpected notification " << type;
- }
-}
-
-PowerApiManager::PowerApiManager()
- : power_state_override_(NULL) {
- registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_UNLOADED,
- content::NotificationService::AllSources());
- registrar_.Add(this, chrome::NOTIFICATION_APP_TERMINATING,
- content::NotificationService::AllSources());
- UpdatePowerSettings();
-}
-
-PowerApiManager::~PowerApiManager() {}
-
-void PowerApiManager::UpdatePowerSettings() {
- // If we have a wake lock and don't have the power state overriden.
- if (extension_ids_set_.size() && !power_state_override_.get()) {
- power_state_override_ = new chromeos::PowerStateOverride(
- chromeos::PowerStateOverride::BLOCK_DISPLAY_SLEEP);
- // else, if we don't have any wake locks and do have a power override.
- } else if (extension_ids_set_.empty() && power_state_override_.get()) {
- power_state_override_ = NULL;
- }
-}
-
-} // namespace power
-} // namespace extensions
« no previous file with comments | « chrome/browser/chromeos/extensions/power/power_api_manager.h ('k') | chrome/browser/extensions/api/power/power_api.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698