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

Unified Diff: content/renderer/scheduler/single_thread_idle_task_runner.cc

Issue 664963002: content: Add RendererScheduler. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix bug in calculating remaining_compositor_priority_time Created 6 years, 2 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: content/renderer/scheduler/single_thread_idle_task_runner.cc
diff --git a/content/renderer/scheduler/single_thread_idle_task_runner.cc b/content/renderer/scheduler/single_thread_idle_task_runner.cc
new file mode 100644
index 0000000000000000000000000000000000000000..2885f05ba9494b91bb9ca4b1478b9c434aa04634
--- /dev/null
+++ b/content/renderer/scheduler/single_thread_idle_task_runner.cc
@@ -0,0 +1,36 @@
+// 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 "content/renderer/scheduler/single_thread_idle_task_runner.h"
+
+#include "base/location.h"
+
+namespace content {
+
+SingleThreadIdleTaskRunner::SingleThreadIdleTaskRunner(
+ scoped_refptr<base::SingleThreadTaskRunner> task_runner,
+ base::WeakPtr<IdleTaskDeadlineSupplier> deadline_supplier)
+ : task_runner_(task_runner),
+ deadline_supplier_(deadline_supplier) { }
+
+SingleThreadIdleTaskRunner::~SingleThreadIdleTaskRunner() { }
+
+bool SingleThreadIdleTaskRunner::RunsTasksOnCurrentThread() const {
+ return task_runner_->RunsTasksOnCurrentThread();
+}
+
+void SingleThreadIdleTaskRunner::PostIdleTask(
+ const tracked_objects::Location& from_here,
+ const IdleTask& idle_task) {
+ task_runner_->PostTask(FROM_HERE, base::Bind(
Sami 2014/10/24 10:46:13 Please pass the original |from_here| so we don't l
rmcilroy 2014/10/24 14:58:29 Argh, that's what I meant to do - good spot! Done.
+ &SingleThreadIdleTaskRunner::RunTask, base::Unretained(this), idle_task));
Sami 2014/10/24 10:46:13 I guess Unretained shouldn't be used here since th
rmcilroy 2014/10/24 14:58:29 Done.
+}
+
+void SingleThreadIdleTaskRunner::RunTask(IdleTask idle_task) {
+ if (deadline_supplier_) {
+ idle_task.Run(deadline_supplier_->CurrentIdleTaskDeadline());
+ }
+}
+
+} // namespace content

Powered by Google App Engine
This is Rietveld 408576698