OLD | NEW |
(Empty) | |
| 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 |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #include "base/threading/sequenced_task_runner_handle.h" |
| 6 |
| 7 #include "base/sequenced_task_runner.h" |
| 8 #include "base/thread_task_runner_handle.h" |
| 9 #include "base/threading/sequenced_worker_pool.h" |
| 10 |
| 11 namespace base { |
| 12 |
| 13 // static |
| 14 scoped_refptr<SequencedTaskRunner> SequencedTaskRunnerHandle::Get() { |
| 15 // If we are on a worker thread for a SequencedBlockingPool that is running a |
| 16 // sequenced task, return a SequencedTaskRunner for it. |
| 17 scoped_refptr<base::SequencedWorkerPool> pool = |
| 18 SequencedWorkerPool::GetWorkerPoolForCurrentThread(); |
| 19 if (pool) { |
| 20 SequencedWorkerPool::SequenceToken sequence_token = |
| 21 SequencedWorkerPool::GetSequenceTokenForCurrentThread(); |
| 22 if (!sequence_token.IsValid()) |
| 23 return nullptr; |
| 24 |
| 25 DCHECK(pool->IsRunningSequenceOnCurrentThread(sequence_token)); |
| 26 return pool->GetSequencedTaskRunner(sequence_token); |
| 27 } |
| 28 |
| 29 // Otherwise, return a SingleThreadTaskRunner for the current thread. |
| 30 if (base::ThreadTaskRunnerHandle::IsSet()) |
| 31 return base::ThreadTaskRunnerHandle::Get(); |
| 32 |
| 33 return nullptr; |
| 34 } |
| 35 |
| 36 } // namespace base |
OLD | NEW |