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 BASE_THREADING_SEQUENCED_TASK_RUNNER_HANDLE_H_ | 5 #ifndef BASE_THREADING_SEQUENCED_TASK_RUNNER_HANDLE_H_ |
6 #define BASE_THREADING_SEQUENCED_TASK_RUNNER_HANDLE_H_ | 6 #define BASE_THREADING_SEQUENCED_TASK_RUNNER_HANDLE_H_ |
7 | 7 |
8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
9 #include "base/macros.h" | 9 #include "base/macros.h" |
10 #include "base/memory/ref_counted.h" | 10 #include "base/memory/ref_counted.h" |
11 | 11 |
12 namespace base { | 12 namespace base { |
13 | 13 |
14 class SequencedTaskRunner; | 14 class SequencedTaskRunner; |
15 | 15 |
16 class BASE_EXPORT SequencedTaskRunnerHandle { | 16 class BASE_EXPORT SequencedTaskRunnerHandle { |
17 public: | 17 public: |
18 // Returns a SequencedTaskRunner which guarantees that posted tasks will only | 18 // Returns a SequencedTaskRunner which guarantees that posted tasks will only |
19 // run after the current task is finished and will satisfy a SequenceChecker. | 19 // run after the current task is finished and will satisfy a SequenceChecker. |
20 // It should only be called if IsSet() returns true (see the comment there for | 20 // It should only be called if IsSet() returns true (see the comment there for |
21 // the requirements). | 21 // the requirements). |
22 static scoped_refptr<SequencedTaskRunner> Get(); | 22 static scoped_refptr<SequencedTaskRunner> Get(); |
23 | 23 |
24 // Returns true if one of the following conditions is fulfilled: | 24 // Returns true if one of the following conditions is fulfilled: |
25 // a) The current thread has a ThreadTaskRunnerHandle (which includes any | 25 // a) A SequencedTaskRunner has been assigned to the current thread by |
| 26 // instantiating a SequencedTaskRunnerHandle. |
| 27 // b) The current thread has a ThreadTaskRunnerHandle (which includes any |
26 // thread that has a MessageLoop associated with it), or | 28 // thread that has a MessageLoop associated with it), or |
27 // b) The current thread is a worker thread belonging to a | 29 // c) The current thread is a worker thread belonging to a |
28 // SequencedWorkerPool. | 30 // SequencedWorkerPool. |
29 static bool IsSet(); | 31 static bool IsSet(); |
30 | 32 |
| 33 // Binds |task_runner| to the current thread. |
| 34 explicit SequencedTaskRunnerHandle( |
| 35 scoped_refptr<SequencedTaskRunner> task_runner); |
| 36 ~SequencedTaskRunnerHandle(); |
| 37 |
31 private: | 38 private: |
32 DISALLOW_IMPLICIT_CONSTRUCTORS(SequencedTaskRunnerHandle); | 39 scoped_refptr<SequencedTaskRunner> task_runner_; |
| 40 |
| 41 DISALLOW_COPY_AND_ASSIGN(SequencedTaskRunnerHandle); |
33 }; | 42 }; |
34 | 43 |
35 } // namespace base | 44 } // namespace base |
36 | 45 |
37 #endif // BASE_THREADING_SEQUENCED_TASK_RUNNER_HANDLE_H_ | 46 #endif // BASE_THREADING_SEQUENCED_TASK_RUNNER_HANDLE_H_ |
OLD | NEW |