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

Side by Side Diff: components/scheduler/renderer/webthread_impl_for_renderer_scheduler.cc

Issue 1308183005: Introduce WebTaskRunner Patch 2/5 (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Missed one rename Created 5 years, 3 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "components/scheduler/renderer/webthread_impl_for_renderer_scheduler.h" 5 #include "components/scheduler/renderer/webthread_impl_for_renderer_scheduler.h"
6 6
7 #include "components/scheduler/child/task_queue.h" 7 #include "components/scheduler/child/task_queue.h"
8 #include "components/scheduler/child/web_task_runner_impl.h"
8 #include "components/scheduler/renderer/renderer_scheduler.h" 9 #include "components/scheduler/renderer/renderer_scheduler.h"
9 #include "components/scheduler/renderer/renderer_web_scheduler_impl.h" 10 #include "components/scheduler/renderer/renderer_web_scheduler_impl.h"
10 #include "third_party/WebKit/public/platform/WebTraceLocation.h" 11 #include "third_party/WebKit/public/platform/WebTraceLocation.h"
11 12
12 namespace scheduler { 13 namespace scheduler {
13 14
14 WebThreadImplForRendererScheduler::WebThreadImplForRendererScheduler( 15 WebThreadImplForRendererScheduler::WebThreadImplForRendererScheduler(
15 RendererScheduler* scheduler) 16 RendererScheduler* scheduler)
16 : web_scheduler_(new RendererWebSchedulerImpl(scheduler)), 17 : web_scheduler_(new RendererWebSchedulerImpl(scheduler)),
17 task_runner_(scheduler->DefaultTaskRunner()), 18 task_runner_(scheduler->DefaultTaskRunner()),
18 idle_task_runner_(scheduler->IdleTaskRunner()), 19 idle_task_runner_(scheduler->IdleTaskRunner()),
19 scheduler_(scheduler), 20 scheduler_(scheduler),
20 thread_id_(base::PlatformThread::CurrentId()) { 21 thread_id_(base::PlatformThread::CurrentId()),
21 } 22 default_web_task_runner_(
23 new WebTaskRunnerImpl(scheduler->DefaultTaskRunner())) {}
22 24
23 WebThreadImplForRendererScheduler::~WebThreadImplForRendererScheduler() { 25 WebThreadImplForRendererScheduler::~WebThreadImplForRendererScheduler() {
24 } 26 }
25 27
26 blink::PlatformThreadId WebThreadImplForRendererScheduler::threadId() const { 28 blink::PlatformThreadId WebThreadImplForRendererScheduler::threadId() const {
27 return thread_id_; 29 return thread_id_;
28 } 30 }
29 31
30 blink::WebScheduler* WebThreadImplForRendererScheduler::scheduler() const { 32 blink::WebScheduler* WebThreadImplForRendererScheduler::scheduler() const {
31 return web_scheduler_.get(); 33 return web_scheduler_.get();
32 } 34 }
33 35
34 base::SingleThreadTaskRunner* WebThreadImplForRendererScheduler::TaskRunner() 36 base::SingleThreadTaskRunner* WebThreadImplForRendererScheduler::TaskRunner()
35 const { 37 const {
36 return task_runner_.get(); 38 return task_runner_.get();
37 } 39 }
38 40
39 SingleThreadIdleTaskRunner* WebThreadImplForRendererScheduler::IdleTaskRunner() 41 SingleThreadIdleTaskRunner* WebThreadImplForRendererScheduler::IdleTaskRunner()
40 const { 42 const {
41 return idle_task_runner_.get(); 43 return idle_task_runner_.get();
42 } 44 }
43 45
46 blink::WebTaskRunner* WebThreadImplForRendererScheduler::taskRunner() {
47 return default_web_task_runner_.get();
48 }
49
44 void WebThreadImplForRendererScheduler::AddTaskObserverInternal( 50 void WebThreadImplForRendererScheduler::AddTaskObserverInternal(
45 base::MessageLoop::TaskObserver* observer) { 51 base::MessageLoop::TaskObserver* observer) {
46 scheduler_->AddTaskObserver(observer); 52 scheduler_->AddTaskObserver(observer);
47 } 53 }
48 54
49 void WebThreadImplForRendererScheduler::RemoveTaskObserverInternal( 55 void WebThreadImplForRendererScheduler::RemoveTaskObserverInternal(
50 base::MessageLoop::TaskObserver* observer) { 56 base::MessageLoop::TaskObserver* observer) {
51 scheduler_->RemoveTaskObserver(observer); 57 scheduler_->RemoveTaskObserver(observer);
52 } 58 }
53 59
54 } // namespace scheduler 60 } // namespace scheduler
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698