summaryrefslogtreecommitdiffstats
path: root/chrome/browser/power_save_blocker_common.cc
diff options
context:
space:
mode:
authormark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-23 04:18:05 +0000
committermark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-23 04:18:05 +0000
commit36e93a7796e1551fafeaaed832f166a2a6d9bb2b (patch)
tree6653c08fae8302920cc2bae5c5a67a0b1f586bcc /chrome/browser/power_save_blocker_common.cc
parentb384d90d7713768c2eb9191ea0d2410f9c9ac0fc (diff)
downloadchromium_src-36e93a7796e1551fafeaaed832f166a2a6d9bb2b.zip
chromium_src-36e93a7796e1551fafeaaed832f166a2a6d9bb2b.tar.gz
chromium_src-36e93a7796e1551fafeaaed832f166a2a6d9bb2b.tar.bz2
Disable system suspend while downloading files on win32.
If the system goes into power-save sleep mode while downloading files, the download fails. So, prevent sleep mode until the download finishes. This patch introduces a new RAII class to request that the system's power-save mode be disabled - PowerSaveBlocker. This is only implemented for win32; other platforms are stubbed out. This only partially implements bug 25420 it only attempts to handle the downloading case. Patch by Bryan Donlan <bdonlan@gmail.com> BUG=25420 TEST=Download a large file with the system sleep timeout set to a short interval. Review URL: http://codereview.chromium.org/287017 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@29873 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/power_save_blocker_common.cc')
-rw-r--r--chrome/browser/power_save_blocker_common.cc58
1 files changed, 58 insertions, 0 deletions
diff --git a/chrome/browser/power_save_blocker_common.cc b/chrome/browser/power_save_blocker_common.cc
new file mode 100644
index 0000000..b6ff2ac
--- /dev/null
+++ b/chrome/browser/power_save_blocker_common.cc
@@ -0,0 +1,58 @@
+// Copyright (c) 2009 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/power_save_blocker.h"
+#include "chrome/browser/chrome_thread.h"
+
+// Accessed only from the UI thread.
+int PowerSaveBlocker::blocker_count_ = 0;
+
+PowerSaveBlocker::PowerSaveBlocker(bool enable) : enabled_(false) {
+ if (enable)
+ Enable();
+}
+
+PowerSaveBlocker::~PowerSaveBlocker(void) {
+ Disable();
+}
+
+void PowerSaveBlocker::Enable() {
+ if (enabled_)
+ return;
+
+ enabled_ = true;
+ PostAdjustBlockCount(1);
+}
+
+void PowerSaveBlocker::Disable() {
+ if (!enabled_)
+ return;
+
+ enabled_ = false;
+ PostAdjustBlockCount(-1);
+}
+
+
+void PowerSaveBlocker::PostAdjustBlockCount(int delta) {
+ MessageLoop *ml = ChromeThread::GetMessageLoop(ChromeThread::UI);
+
+ ml->PostTask(FROM_HERE,
+ NewRunnableFunction(&PowerSaveBlocker::AdjustBlockCount, delta));
+}
+
+// Called only from UI thread.
+void PowerSaveBlocker::AdjustBlockCount(int delta) {
+ DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI));
+
+ bool was_blocking = (blocker_count_ != 0);
+
+ blocker_count_ += delta;
+
+ bool is_blocking = (blocker_count_ != 0);
+
+ DCHECK_GE(blocker_count_, 0);
+
+ if (is_blocking != was_blocking)
+ ApplyBlock(is_blocking);
+}