1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/task/thread_pool.h"
#include "base/check.h"
#include "base/task/scoped_set_task_priority_for_current_thread.h"
#include "base/task/task_traits.h"
#include "base/task/thread_pool/thread_pool_impl.h"
#include "base/task/thread_pool/thread_pool_instance.h"
#include "base/threading/post_task_and_reply_impl.h"
#include "build/build_config.h"
namespace base {
namespace {
internal::ThreadPoolImpl* GetThreadPoolImpl() {
auto* instance = ThreadPoolInstance::Get();
DCHECK(instance)
<< "No threadpool instance for this process. See the 'Prerequisite' "
"section of base/task/thread_pool.h.\n"
"Hint: if this is in a unit test, you're likely merely missing a "
"base::test::TaskEnvironment member in your fixture (or your fixture "
"is using a base::test::SingleThreadTaskEnvironment and now needs a "
"full base::test::TaskEnvironment).\n";
return static_cast<internal::ThreadPoolImpl*>(instance);
}
} // namespace
// static
bool ThreadPool::PostTask(const Location& from_here, OnceClosure task) {
return ThreadPool::PostDelayedTask(from_here, std::move(task), TimeDelta());
}
// static
bool ThreadPool::PostDelayedTask(const Location& from_here,
OnceClosure task,
TimeDelta delay) {
return ThreadPool::PostDelayedTask(from_here, {}, std::move(task), delay);
}
// static
bool ThreadPool::PostTaskAndReply(const Location& from_here,
OnceClosure task,
OnceClosure reply) {
return ThreadPool::PostTaskAndReply(from_here, {}, std::move(task),
std::move(reply));
}
// static
bool ThreadPool::PostTask(const Location& from_here,
const TaskTraits& traits,
OnceClosure task) {
return ThreadPool::PostDelayedTask(from_here, traits, std::move(task),
TimeDelta());
}
// static
bool ThreadPool::PostDelayedTask(const Location& from_here,
const TaskTraits& traits,
OnceClosure task,
TimeDelta delay) {
return GetThreadPoolImpl()->PostDelayedTask(from_here, traits,
std::move(task), delay);
}
// static
bool ThreadPool::PostTaskAndReply(const Location& from_here,
const TaskTraits& traits,
OnceClosure task,
OnceClosure reply) {
return internal::PostTaskAndReplyImpl(
[&traits](const Location& location, OnceClosure task) {
return ThreadPool::PostTask(location, traits, std::move(task));
},
from_here, std::move(task), std::move(reply));
}
// static
scoped_refptr<TaskRunner> ThreadPool::CreateTaskRunner(
const TaskTraits& traits) {
return GetThreadPoolImpl()->CreateTaskRunner(traits);
}
// static
scoped_refptr<SequencedTaskRunner> ThreadPool::CreateSequencedTaskRunner(
const TaskTraits& traits) {
return GetThreadPoolImpl()->CreateSequencedTaskRunner(traits);
}
// static
scoped_refptr<UpdateableSequencedTaskRunner>
ThreadPool::CreateUpdateableSequencedTaskRunner(const TaskTraits& traits) {
return GetThreadPoolImpl()->CreateUpdateableSequencedTaskRunner(traits);
}
// static
scoped_refptr<SingleThreadTaskRunner> ThreadPool::CreateSingleThreadTaskRunner(
const TaskTraits& traits,
SingleThreadTaskRunnerThreadMode thread_mode) {
return GetThreadPoolImpl()->CreateSingleThreadTaskRunner(traits, thread_mode);
}
#if BUILDFLAG(IS_WIN)
// static
scoped_refptr<SingleThreadTaskRunner> ThreadPool::CreateCOMSTATaskRunner(
const TaskTraits& traits,
SingleThreadTaskRunnerThreadMode thread_mode) {
return GetThreadPoolImpl()->CreateCOMSTATaskRunner(traits, thread_mode);
}
#endif // BUILDFLAG(IS_WIN)
// static
scoped_refptr<SequencedTaskRunner>
ThreadPool::CreateSequencedTaskRunnerForResource(const TaskTraits& traits,
const base::FilePath& path) {
return GetThreadPoolImpl()->CreateSequencedTaskRunnerForResource(traits,
path);
}
} // namespace base
|