OLD | NEW |
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 #ifndef COMPONENTS_SCHEDULER_CHILD_NESTABLE_SINGLE_THREAD_TASK_RUNNER_H_ | 5 #ifndef COMPONENTS_SCHEDULER_CHILD_NESTABLE_SINGLE_THREAD_TASK_RUNNER_H_ |
6 #define COMPONENTS_SCHEDULER_CHILD_NESTABLE_SINGLE_THREAD_TASK_RUNNER_H_ | 6 #define COMPONENTS_SCHEDULER_CHILD_NESTABLE_SINGLE_THREAD_TASK_RUNNER_H_ |
7 | 7 |
8 #include "base/single_thread_task_runner.h" | 8 #include "base/single_thread_task_runner.h" |
9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
10 #include "components/scheduler/scheduler_export.h" | 10 #include "components/scheduler/scheduler_export.h" |
11 | 11 |
12 namespace scheduler { | 12 namespace scheduler { |
13 | 13 |
14 // A single thread task runner which exposes whether it is running nested. | 14 // A single thread task runner which exposes whether it is running nested. |
15 class SCHEDULER_EXPORT NestableSingleThreadTaskRunner | 15 class SCHEDULER_EXPORT NestableSingleThreadTaskRunner |
16 : public base::SingleThreadTaskRunner { | 16 : public base::SingleThreadTaskRunner { |
17 public: | 17 public: |
18 NestableSingleThreadTaskRunner() {} | 18 NestableSingleThreadTaskRunner() {} |
19 | 19 |
| 20 // If the underlying task runner supports the concept of a default task |
| 21 // runner, the delegate should implement this function to redirect that task |
| 22 // runner to the scheduler. |
| 23 virtual void SetDefaultTaskRunner( |
| 24 scoped_refptr<base::SingleThreadTaskRunner> task_runner) = 0; |
| 25 |
20 // Returns true if the task runner is nested (i.e., running a run loop within | 26 // Returns true if the task runner is nested (i.e., running a run loop within |
21 // a nested task). | 27 // a nested task). |
22 virtual bool IsNested() const = 0; | 28 virtual bool IsNested() const = 0; |
23 | 29 |
24 // Adds and removes MessageLoop::TaskObservers to the task runner. | 30 // Adds and removes MessageLoop::TaskObservers to the task runner. |
25 virtual void AddTaskObserver( | 31 virtual void AddTaskObserver( |
26 base::MessageLoop::TaskObserver* task_observer) = 0; | 32 base::MessageLoop::TaskObserver* task_observer) = 0; |
27 virtual void RemoveTaskObserver( | 33 virtual void RemoveTaskObserver( |
28 base::MessageLoop::TaskObserver* task_observer) = 0; | 34 base::MessageLoop::TaskObserver* task_observer) = 0; |
29 | 35 |
30 protected: | 36 protected: |
31 ~NestableSingleThreadTaskRunner() override {} | 37 ~NestableSingleThreadTaskRunner() override {} |
32 | 38 |
33 DISALLOW_COPY_AND_ASSIGN(NestableSingleThreadTaskRunner); | 39 DISALLOW_COPY_AND_ASSIGN(NestableSingleThreadTaskRunner); |
34 }; | 40 }; |
35 | 41 |
36 } // namespace scheduler | 42 } // namespace scheduler |
37 | 43 |
38 #endif // COMPONENTS_SCHEDULER_CHILD_NESTABLE_SINGLE_THREAD_TASK_RUNNER_H_ | 44 #endif // COMPONENTS_SCHEDULER_CHILD_NESTABLE_SINGLE_THREAD_TASK_RUNNER_H_ |
OLD | NEW |