summaryrefslogtreecommitdiffstats
path: root/chrome/renderer/user_script_idle_scheduler.cc
diff options
context:
space:
mode:
authoraa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-03 05:02:30 +0000
committeraa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-03 05:02:30 +0000
commitfa7b6b547368d12ccd61f6cbf251f2ff0d37b504 (patch)
treec28ef0f99dc70cd1dc8acf70f3cc8af5d2cb9072 /chrome/renderer/user_script_idle_scheduler.cc
parentd12f7a9539c490b3e008d234526a67d0496972b3 (diff)
downloadchromium_src-fa7b6b547368d12ccd61f6cbf251f2ff0d37b504.zip
chromium_src-fa7b6b547368d12ccd61f6cbf251f2ff0d37b504.tar.gz
chromium_src-fa7b6b547368d12ccd61f6cbf251f2ff0d37b504.tar.bz2
Re-commit "Add new user script injection point:
document_idle." Original code review: http://codereview.chromium.org/339064 BUG=26126 TBR=rafaelw@chromium.org git-svn-id: svn://svn.chromium.org/chrome/trunk/src@30796 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/renderer/user_script_idle_scheduler.cc')
-rw-r--r--chrome/renderer/user_script_idle_scheduler.cc47
1 files changed, 47 insertions, 0 deletions
diff --git a/chrome/renderer/user_script_idle_scheduler.cc b/chrome/renderer/user_script_idle_scheduler.cc
new file mode 100644
index 0000000..2468bf1
--- /dev/null
+++ b/chrome/renderer/user_script_idle_scheduler.cc
@@ -0,0 +1,47 @@
+// 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/renderer/user_script_idle_scheduler.h"
+
+#include "base/message_loop.h"
+#include "chrome/renderer/render_view.h"
+
+namespace {
+// The length of time to wait after the DOM is complete to try and run user
+// scripts.
+const int kUserScriptIdleTimeoutMs = 200;
+}
+
+UserScriptIdleScheduler::UserScriptIdleScheduler(RenderView* view,
+ WebKit::WebFrame* frame)
+ : ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)), view_(view),
+ frame_(frame), has_run_(false) {
+}
+
+void UserScriptIdleScheduler::DidFinishDocumentLoad() {
+ MessageLoop::current()->PostDelayedTask(FROM_HERE,
+ method_factory_.NewRunnableMethod(&UserScriptIdleScheduler::MaybeRun),
+ kUserScriptIdleTimeoutMs);
+}
+
+void UserScriptIdleScheduler::DidFinishLoad() {
+ // Ensure that running scripts does not keep any progress UI running.
+ MessageLoop::current()->PostTask(FROM_HERE,
+ method_factory_.NewRunnableMethod(&UserScriptIdleScheduler::MaybeRun));
+}
+
+void UserScriptIdleScheduler::Cancel() {
+ view_ = NULL;
+ frame_ = NULL;
+}
+
+void UserScriptIdleScheduler::MaybeRun() {
+ if (!view_)
+ return;
+
+ DCHECK(frame_);
+ view_->OnUserScriptIdleTriggered(frame_);
+ Cancel();
+ has_run_ = true;
+}