summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--base/base.gyp14
-rw-r--r--base/idle_timer.cc161
-rw-r--r--base/idle_timer.h96
-rw-r--r--base/idle_timer_none.cc25
-rw-r--r--base/idletimer_unittest.cc240
-rw-r--r--chrome/browser/browser.cc1
6 files changed, 0 insertions, 537 deletions
diff --git a/base/base.gyp b/base/base.gyp
index 4e09866..a7860c2 100644
--- a/base/base.gyp
+++ b/base/base.gyp
@@ -147,9 +147,6 @@
'iat_patch.h',
'icu_util.cc',
'icu_util.h',
- 'idle_timer.cc',
- 'idle_timer.h',
- 'idle_timer_none.cc',
'id_map.h',
'image_util.cc',
'image_util.h',
@@ -375,12 +372,6 @@
},
'sources/': [ ['exclude', '_(mac|win|chromeos)\\.cc$'],
['exclude', '\\.mm?$' ] ],
- 'sources!': [
- # Linux has an implementation of idle_timer that depends
- # on XScreenSaver, but it's unclear if we want it yet,
- # so use idle_timer_none.cc instead.
- 'idle_timer.cc',
- ],
'conditions': [
[ 'chromeos==1', {
'sources/': [ ['include', '_chromeos\\.cc$'] ]
@@ -422,7 +413,6 @@
'atomicops_internals_x86_gcc.cc',
'directory_watcher_inotify.cc',
'hmac_nss.cc',
- 'idle_timer_none.cc',
'linux_util.cc',
'message_pump_glib.cc',
'nss_init.cc',
@@ -618,7 +608,6 @@
'gmock_unittest.cc',
'histogram_unittest.cc',
'hmac_unittest.cc',
- 'idletimer_unittest.cc',
'id_map_unittest.cc',
'json_reader_unittest.cc',
'json_writer_unittest.cc',
@@ -693,9 +682,6 @@
['OS == "linux" or OS == "freebsd"', {
'sources!': [
'file_version_info_unittest.cc',
- # Linux has an implementation of idle_timer, but it's unclear
- # if we want it yet, so leave it 'unported' for now.
- 'idletimer_unittest.cc',
'worker_pool_linux_unittest.cc',
],
'dependencies': [
diff --git a/base/idle_timer.cc b/base/idle_timer.cc
deleted file mode 100644
index de980f1..0000000
--- a/base/idle_timer.cc
+++ /dev/null
@@ -1,161 +0,0 @@
-// Copyright (c) 2006-2008 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 "base/idle_timer.h"
-
-// We may not want to port idle_timer to Linux, but we have implemented it
-// anyway. Define this to 1 to enable the Linux idle timer and then add the
-// libs that need to be linked (Xss).
-#define ENABLE_XSS_SUPPORT 0
-
-#if defined(OS_MACOSX)
-#include <ApplicationServices/ApplicationServices.h>
-#endif
-
-#if defined(OS_LINUX) && ENABLE_XSS_SUPPORT
-// We may not want to port idle_timer to Linux, but we have implemented it
-// anyway. Remove the 0 above if we want it.
-#include <gdk/gdkx.h>
-#include <X11/extensions/scrnsaver.h>
-#include "base/lazy_instance.h"
-#include "base/thread_local.h"
-#endif
-
-#include "base/message_loop.h"
-#include "base/time.h"
-
-namespace base {
-
-#if defined(OS_WIN)
-bool OSIdleTimeSource(int32 *milliseconds_interval_since_last_event) {
- LASTINPUTINFO lastInputInfo;
- lastInputInfo.cbSize = sizeof(lastInputInfo);
- if (GetLastInputInfo(&lastInputInfo) == 0) {
- return false;
- }
- int32 last_input_time = lastInputInfo.dwTime;
-
- // Note: On Windows GetLastInputInfo returns a 32bit value which rolls over
- // ~49days.
- int32 current_time = GetTickCount();
- int32 delta = current_time - last_input_time;
- // delta will go negative if we've been idle for 2GB of ticks.
- if (delta < 0)
- delta = -delta;
- *milliseconds_interval_since_last_event = delta;
- return true;
-}
-#elif defined(OS_MACOSX)
-bool OSIdleTimeSource(int32 *milliseconds_interval_since_last_event) {
- *milliseconds_interval_since_last_event =
- CGEventSourceSecondsSinceLastEventType(
- kCGEventSourceStateCombinedSessionState,
- kCGAnyInputEventType) * 1000.0;
- return true;
-}
-#elif defined(OS_LINUX) && ENABLE_XSS_SUPPORT
-class IdleState {
- public:
- IdleState() {
- int event_base, error_base;
- have_idle_info_ = XScreenSaverQueryExtension(GDK_DISPLAY(), &event_base,
- &error_base);
- if (have_idle_info_)
- idle_info_.Set(XScreenSaverAllocInfo());
- }
-
- ~IdleState() {
- if (idle_info_.Get()) {
- XFree(idle_info_.Get());
- idle_info_.~ThreadLocalPointer();
- }
- }
-
- int32 IdleTime() {
- if (have_idle_info_ && idle_info_.Get()) {
- XScreenSaverQueryInfo(GDK_DISPLAY(), GDK_ROOT_WINDOW(),
- idle_info_.Get());
- return idle_info_.Get()->idle;
- }
- return -1;
- }
-
- private:
- bool have_idle_info_;
- ThreadLocalPointer<XScreenSaverInfo> idle_info_;
-
- DISALLOW_COPY_AND_ASSIGN(IdleState);
-};
-
-bool OSIdleTimeSource(int32* milliseconds_interval_since_last_event) {
- static LazyInstance<IdleState> state_instance(base::LINKER_INITIALIZED);
- IdleState* state = state_instance.Pointer();
- int32 idle_time = state->IdleTime();
- if (0 < idle_time) {
- *milliseconds_interval_since_last_event = idle_time;
- return true;
- }
- return false;
-}
-#endif
-
-IdleTimer::IdleTimer(TimeDelta idle_time, bool repeat)
- : idle_interval_(idle_time),
- repeat_(repeat),
- idle_time_source_(OSIdleTimeSource) {
- DCHECK_EQ(MessageLoop::TYPE_UI, MessageLoop::current()->type()) <<
- "Requires a thread that processes Windows UI events";
-}
-
-IdleTimer::~IdleTimer() {
- Stop();
-}
-
-void IdleTimer::Start() {
- StartTimer();
-}
-
-void IdleTimer::Stop() {
- timer_.Stop();
-}
-
-void IdleTimer::Run() {
- // Verify we can fire the idle timer.
- if (TimeUntilIdle().InMilliseconds() <= 0) {
- OnIdle();
- last_time_fired_ = Time::Now();
- }
- Stop();
- StartTimer(); // Restart the timer for next run.
-}
-
-void IdleTimer::StartTimer() {
- DCHECK(!timer_.IsRunning());
- TimeDelta delay = TimeUntilIdle();
- if (delay.InMilliseconds() < 0)
- delay = TimeDelta();
- timer_.Start(delay, this, &IdleTimer::Run);
-}
-
-TimeDelta IdleTimer::CurrentIdleTime() {
- int32 interval = 0;
- if (idle_time_source_(&interval)) {
- return TimeDelta::FromMilliseconds(interval);
- }
- NOTREACHED();
- return TimeDelta::FromMilliseconds(0);
-}
-
-TimeDelta IdleTimer::TimeUntilIdle() {
- TimeDelta time_since_last_fire = Time::Now() - last_time_fired_;
- TimeDelta current_idle_time = CurrentIdleTime();
- if (current_idle_time > time_since_last_fire) {
- if (repeat_)
- return idle_interval_ - time_since_last_fire;
- return idle_interval_;
- }
- return idle_interval_ - current_idle_time;
-}
-
-} // namespace base
diff --git a/base/idle_timer.h b/base/idle_timer.h
deleted file mode 100644
index 1f6c08c..0000000
--- a/base/idle_timer.h
+++ /dev/null
@@ -1,96 +0,0 @@
-// Copyright (c) 2006-2008 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.
-
-// IdleTimer is a recurring Timer which runs only when the system is idle.
-// System Idle time is defined as not having any user keyboard or mouse
-// activity for some period of time. Because the timer is user dependant, it
-// is possible for the timer to never fire.
-//
-// Usage should be for low-priority work, and may look like this:
-//
-// class MyIdleTimer : public IdleTimer {
-// public:
-// // This timer will run repeatedly after 5 seconds of idle time
-// MyIdleTimer() : IdleTimer(TimeDelta::FromSeconds(5), true) {};
-// virtual void OnIdle() { do something };
-// }
-//
-// MyIdleTimer *timer = new MyIdleTimer();
-// timer->Start();
-//
-// // As with all Timers, the caller must dispose the object.
-// delete timer; // Will Stop the timer and cleanup.
-//
-// NOTE: An IdleTimer can only be used on a thread that processes UI events.
-// Such a thread should be running a MessageLoopForUI.
-
-#ifndef BASE_IDLE_TIMER_H_
-#define BASE_IDLE_TIMER_H_
-
-#if defined(OS_WIN)
-#include <windows.h>
-#endif
-
-#include "base/basictypes.h"
-#include "base/timer.h"
-
-namespace base {
-
-// Function prototype - Get the number of milliseconds that the user has been
-// idle.
-typedef bool (*IdleTimeSource)(int32 *milliseconds_interval_since_last_event);
-
-class IdleTimer {
- public:
- // Create an IdleTimer.
- // idle_time: idle time required before this timer can run.
- // repeat: true if the timer should fire multiple times per idle,
- // false to fire once per idle.
- IdleTimer(TimeDelta idle_time, bool repeat);
-
- // On destruction, the IdleTimer will Stop itself.
- virtual ~IdleTimer();
-
- // Start the IdleTimer.
- void Start();
-
- // Stop the IdleTimer.
- void Stop();
-
- // The method to run when the timer elapses.
- virtual void OnIdle() = 0;
-
- protected:
- // Override the IdleTimeSource.
- void set_idle_time_source(IdleTimeSource idle_time_source) {
- idle_time_source_ = idle_time_source;
- }
-
- private:
- // Called when timer_ expires.
- void Run();
-
- // Start the timer.
- void StartTimer();
-
- // Gets the number of milliseconds since the last input event.
- TimeDelta CurrentIdleTime();
-
- // Compute time until idle. Returns 0 if we are now idle.
- TimeDelta TimeUntilIdle();
-
- TimeDelta idle_interval_;
- bool repeat_;
- Time last_time_fired_; // The last time the idle timer fired.
- // will be 0 until the timer fires the first time.
- OneShotTimer<IdleTimer> timer_;
-
- IdleTimeSource idle_time_source_;
-
- DISALLOW_COPY_AND_ASSIGN(IdleTimer);
-};
-
-} // namespace base
-
-#endif // BASE_IDLE_TIMER_H_
diff --git a/base/idle_timer_none.cc b/base/idle_timer_none.cc
deleted file mode 100644
index 946535e..0000000
--- a/base/idle_timer_none.cc
+++ /dev/null
@@ -1,25 +0,0 @@
-// Copyright (c) 2006-2008 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.
-
-// A stub implementation of IdleTimer used to provide symbols needed by Chrome.
-// It's unclear whether we need the idle timer in the linux port, so we're
-// leaving it unported for now.
-
-#include "base/idle_timer.h"
-
-namespace base {
-
-IdleTimer::IdleTimer(TimeDelta idle_time, bool repeat) {
-}
-
-IdleTimer::~IdleTimer() {
-}
-
-void IdleTimer::Start() {
-}
-
-void IdleTimer::Stop() {
-}
-
-} // namespace base
diff --git a/base/idletimer_unittest.cc b/base/idletimer_unittest.cc
deleted file mode 100644
index 07a8bbd..0000000
--- a/base/idletimer_unittest.cc
+++ /dev/null
@@ -1,240 +0,0 @@
-// Copyright (c) 2006-2008 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 "base/idle_timer.h"
-#include "base/message_loop.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-using base::Time;
-using base::TimeDelta;
-using base::IdleTimer;
-
-
-// If the timers fire too quickly, it can be tricky to make timer tests
-// reliable on all buildbots. This constant sets a minimum timer delta where
-// we expect that we should be able to reliably count timers without problems
-// due to slight clock/scheduling variances.
-const int kSafeTestIntervalMs = 500;
-
-namespace {
-
-// We Mock the GetLastInputInfo function to return
-// the time stored here.
-static Time mock_timer_started;
-
-bool MockIdleTimeSource(int32 *milliseconds_interval_since_last_event) {
- TimeDelta delta = Time::Now() - mock_timer_started;
- *milliseconds_interval_since_last_event =
- static_cast<int32>(delta.InMilliseconds());
- return true;
-}
-
-// TestIdle task fires after 100ms of idle time.
-class TestIdleTask : public IdleTimer {
- public:
- TestIdleTask(bool repeat)
- : IdleTimer(TimeDelta::FromMilliseconds(kSafeTestIntervalMs), repeat),
- idle_counter_(0) {
- set_idle_time_source(MockIdleTimeSource);
- }
-
- int get_idle_counter() { return idle_counter_; }
-
- virtual void OnIdle() {
- idle_counter_++;
- }
-
- private:
- int idle_counter_;
-};
-
-// A task to help us quit the test.
-class TestFinishedTask {
- public:
- TestFinishedTask() {}
- void Run() {
- MessageLoop::current()->Quit();
- }
-};
-
-// A timer which resets the idle clock.
-class ResetIdleTask {
- public:
- ResetIdleTask() {}
- void Run() {
- mock_timer_started = Time::Now();
- }
-};
-
-class IdleTimerTest : public testing::Test {
- private:
- // IdleTimer requires a UI message loop on the current thread.
- MessageLoopForUI message_loop_;
-};
-
-///////////////////////////////////////////////////////////////////////////////
-// NoRepeat tests:
-// A non-repeating idle timer will fire once on idle, and
-// then will not fire again unless it goes non-idle first.
-
-TEST_F(IdleTimerTest, NoRepeatIdle) {
- // Create an IdleTimer, which should fire once after 500ms.
- // Create a Quit timer which will fire after 1s.
- // Verify that we fired exactly once.
-
- mock_timer_started = Time::Now();
- TestIdleTask test_task(false);
-
- TestFinishedTask finish_task;
- base::OneShotTimer<TestFinishedTask> timer;
- timer.Start(TimeDelta::FromMilliseconds(2 * kSafeTestIntervalMs),
- &finish_task, &TestFinishedTask::Run);
-
- test_task.Start();
- MessageLoop::current()->Run();
-
- EXPECT_EQ(test_task.get_idle_counter(), 1);
-}
-
-TEST_F(IdleTimerTest, NoRepeatFlipIdleOnce) {
- // Create an IdleTimer, which should fire once after 500ms.
- // Create a Quit timer which will fire after 5s.
- // Create a timer to reset once, idle after 2s.
- // Verify that we fired exactly twice.
-
- mock_timer_started = Time::Now();
- TestIdleTask test_task(false);
-
- TestFinishedTask finish_task;
- ResetIdleTask reset_task;
-
- base::OneShotTimer<TestFinishedTask> t1;
- t1.Start(TimeDelta::FromMilliseconds(10 * kSafeTestIntervalMs), &finish_task,
- &TestFinishedTask::Run);
-
- base::OneShotTimer<ResetIdleTask> t2;
- t2.Start(TimeDelta::FromMilliseconds(4 * kSafeTestIntervalMs), &reset_task,
- &ResetIdleTask::Run);
-
- test_task.Start();
- MessageLoop::current()->Run();
-
- EXPECT_EQ(test_task.get_idle_counter(), 2);
-}
-
-TEST_F(IdleTimerTest, NoRepeatNotIdle) {
- // Create an IdleTimer, which should fire once after 500ms.
- // Create a Quit timer which will fire after 5s.
- // Create a timer to reset idle every 50ms.
- // Verify that we never fired.
-
- mock_timer_started = Time::Now();
- TestIdleTask test_task(false);
-
- TestFinishedTask finish_task;
- ResetIdleTask reset_task;
-
- base::OneShotTimer<TestFinishedTask> t;
- t.Start(TimeDelta::FromMilliseconds(10 * kSafeTestIntervalMs), &finish_task,
- &TestFinishedTask::Run);
-
- base::RepeatingTimer<ResetIdleTask> reset_timer;
- reset_timer.Start(TimeDelta::FromMilliseconds(50), &reset_task,
- &ResetIdleTask::Run);
-
- test_task.Start();
-
- MessageLoop::current()->Run();
-
- reset_timer.Stop();
-
- EXPECT_EQ(test_task.get_idle_counter(), 0);
-}
-
-///////////////////////////////////////////////////////////////////////////////
-// Repeat tests:
-// A repeating idle timer will fire repeatedly on each interval, as long
-// as it has been idle. So, if the machine remains idle, it will continue
-// firing over and over.
-
-TEST_F(IdleTimerTest, Repeat) {
- // Create an IdleTimer, which should fire repeatedly after 500ms.
- // Create a Quit timer which will fire after 1.5s.
- // Verify that we fired 2-3 times.
- mock_timer_started = Time::Now();
- TestIdleTask test_task(true);
-
- TestFinishedTask finish_task;
-
- base::OneShotTimer<TestFinishedTask> t;
- t.Start(TimeDelta::FromMilliseconds(kSafeTestIntervalMs * 3), &finish_task,
- &TestFinishedTask::Run);
-
- test_task.Start();
- MessageLoop::current()->Run();
-
- // In a perfect world, the idle_counter should be 2. However,
- // due to timer 'slop', accept 2 or 3.
- EXPECT_GE(test_task.get_idle_counter(), 2);
- EXPECT_LE(test_task.get_idle_counter(), 3);
-}
-
-TEST_F(IdleTimerTest, RepeatIdleReset) {
- // Create an IdleTimer, which should fire repeatedly after 500ms.
- // Create a Quit timer which will fire after 5s.
- // Create a reset timer, which fires after 2500ms
- // Verify that we fired 8-10 times.
- mock_timer_started = Time::Now();
- TestIdleTask test_task(true);
-
- ResetIdleTask reset_task;
- TestFinishedTask finish_task;
-
- base::OneShotTimer<TestFinishedTask> t1;
- t1.Start(TimeDelta::FromMilliseconds(10 * kSafeTestIntervalMs), &finish_task,
- &TestFinishedTask::Run);
-
- base::OneShotTimer<ResetIdleTask> t2;
- t2.Start(TimeDelta::FromMilliseconds(5 * kSafeTestIntervalMs), &reset_task,
- &ResetIdleTask::Run);
-
- test_task.Start();
- MessageLoop::current()->Run();
-
- // In a perfect world, the idle_counter should be 9. However,
- // since timers aren't guaranteed to fire perfectly, this can
- // be less. Accept 8-10.
- EXPECT_GE(test_task.get_idle_counter(), 8);
- EXPECT_LE(test_task.get_idle_counter(), 10);
-}
-
-TEST_F(IdleTimerTest, RepeatNotIdle) {
- // Create an IdleTimer, which should fire repeatedly after 500ms.
- // Create a Quit timer which will fire after 4s.
- // Create a timer to reset idle every 50ms.
- // Verify that we never fired.
-
- mock_timer_started = Time::Now();
- TestIdleTask test_task(true);
-
- TestFinishedTask finish_task;
- ResetIdleTask reset_task;
-
- base::OneShotTimer<TestFinishedTask> t;
- t.Start(TimeDelta::FromMilliseconds(8 * kSafeTestIntervalMs), &finish_task,
- &TestFinishedTask::Run);
-
- base::RepeatingTimer<ResetIdleTask> reset_timer;
- reset_timer.Start(TimeDelta::FromMilliseconds(50), &reset_task,
- &ResetIdleTask::Run);
-
- test_task.Start();
- MessageLoop::current()->Run();
-
- reset_timer.Stop();
-
- EXPECT_EQ(test_task.get_idle_counter(), 0);
-}
-
-} // namespace
diff --git a/chrome/browser/browser.cc b/chrome/browser/browser.cc
index a4052bd..608783a 100644
--- a/chrome/browser/browser.cc
+++ b/chrome/browser/browser.cc
@@ -7,7 +7,6 @@
#include "app/animation.h"
#include "app/l10n_util.h"
#include "base/command_line.h"
-#include "base/idle_timer.h"
#include "base/keyboard_codes.h"
#include "base/logging.h"
#include "base/string_util.h"