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

Side by Side Diff: content/child/scheduler/worker_scheduler_impl.h

Issue 1033643004: Add a WorkerScheduler and a WebThreadImplForWorker (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: InitOnThread needed to call Init() Created 5 years, 8 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 2014 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 #ifndef CONTENT_RENDERER_SCHEDULER_NULL_RENDERER_SCHEDULER_H_ 5 #ifndef CONTENT_CHILD_SCHEDULER_WORKER_SCHEDULER_IMPL_H_
6 #define CONTENT_RENDERER_SCHEDULER_NULL_RENDERER_SCHEDULER_H_ 6 #define CONTENT_CHILD_SCHEDULER_WORKER_SCHEDULER_IMPL_H_
7 7
8 #include "content/renderer/scheduler/renderer_scheduler.h" 8 #include "content/child/scheduler/worker_scheduler.h"
9 #include "content/child/scheduler/scheduler_helper.h"
10
11 namespace base {
12 namespace trace_event {
13 class ConvertableToTraceFormat;
14 }
15 }
9 16
10 namespace content { 17 namespace content {
11 18
12 class NullRendererScheduler : public RendererScheduler { 19 class NestableSingleThreadTaskRunner;
20
21 class CONTENT_EXPORT WorkerSchedulerImpl
22 : public WorkerScheduler,
23 public SchedulerHelper::SchedulerHelperDelegate {
Sami 2015/04/02 10:19:46 I guess the delegate could be inherited privately?
rmcilroy 2015/04/02 11:01:26 +1 (and for RendererSchedulerImpl too if possible)
kinuko 2015/04/02 13:03:08 style-nit: private inheritance is not encouraged b
alex clarke (OOO till 29th) 2015/04/02 15:19:28 In light of the style guide comments I think makin
13 public: 24 public:
14 NullRendererScheduler(); 25 WorkerSchedulerImpl(
15 ~NullRendererScheduler() override; 26 scoped_refptr<NestableSingleThreadTaskRunner> main_task_runner);
27 ~WorkerSchedulerImpl() override;
16 28
29 // Implement WorkerScheduler:
Sami 2015/04/02 10:19:46 nit: "WorkerScheduler implementation:" is the usua
alex clarke (OOO till 29th) 2015/04/02 15:19:28 Done.
17 scoped_refptr<base::SingleThreadTaskRunner> DefaultTaskRunner() override; 30 scoped_refptr<base::SingleThreadTaskRunner> DefaultTaskRunner() override;
18 scoped_refptr<base::SingleThreadTaskRunner> CompositorTaskRunner() override;
19 scoped_refptr<base::SingleThreadTaskRunner> LoadingTaskRunner() override;
20 scoped_refptr<SingleThreadIdleTaskRunner> IdleTaskRunner() override; 31 scoped_refptr<SingleThreadIdleTaskRunner> IdleTaskRunner() override;
21
22 void WillBeginFrame(const cc::BeginFrameArgs& args) override;
23 void BeginFrameNotExpectedSoon() override;
24 void DidCommitFrameToCompositor() override;
25 void DidReceiveInputEventOnCompositorThread(
26 const blink::WebInputEvent& web_input_event) override;
27 void DidAnimateForInputOnCompositorThread() override;
28 bool IsHighPriorityWorkAnticipated() override;
29 bool ShouldYieldForHighPriorityWork() override;
30 bool CanExceedIdleDeadlineIfRequired() const override; 32 bool CanExceedIdleDeadlineIfRequired() const override;
31 void AddTaskObserver(base::MessageLoop::TaskObserver* task_observer) override; 33 void AddTaskObserver(base::MessageLoop::TaskObserver* task_observer) override;
32 void RemoveTaskObserver( 34 void RemoveTaskObserver(
33 base::MessageLoop::TaskObserver* task_observer) override; 35 base::MessageLoop::TaskObserver* task_observer) override;
36 void Init() override;
34 void Shutdown() override; 37 void Shutdown() override;
35 38
39 void SetTimeSourceForTesting(scoped_refptr<cc::TestNowSource> time_source);
40 void SetWorkBatchSizeForTesting(size_t work_batch_size);
41
36 private: 42 private:
37 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; 43 // SchedulerHelperDelegate implementation:
38 scoped_refptr<SingleThreadIdleTaskRunner> idle_task_runner_; 44 bool CanEnterLongIdlePeriod(
45 base::TimeTicks now,
46 base::TimeDelta* next_long_idle_period_delay_out) override;
39 47
40 DISALLOW_COPY_AND_ASSIGN(NullRendererScheduler); 48 void MaybeStartLongIdlePeriod();
49
50 SchedulerHelper helper_;
51
52 DISALLOW_COPY_AND_ASSIGN(WorkerSchedulerImpl);
41 }; 53 };
42 54
43 } // namespace content 55 } // namespace content
44 56
45 #endif // CONTENT_RENDERER_SCHEDULER_NULL_RENDERER_SCHEDULER_H_ 57 #endif // CONTENT_CHILD_SCHEDULER_WORKER_SCHEDULER_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698