| Index: base/thread_task_runner_handle.cc
|
| diff --git a/base/thread_task_runner_handle.cc b/base/thread_task_runner_handle.cc
|
| index 911e90c798c47f8b69af49a7631a5487a8a01b94..3a3f14b300582d8b5e0504ec6fdb8c7ad37c1599 100644
|
| --- a/base/thread_task_runner_handle.cc
|
| +++ b/base/thread_task_runner_handle.cc
|
| @@ -4,15 +4,19 @@
|
|
|
| #include "base/thread_task_runner_handle.h"
|
|
|
| +#include <utility>
|
| +
|
| #include "base/lazy_instance.h"
|
| +#include "base/logging.h"
|
| #include "base/single_thread_task_runner.h"
|
| +#include "base/threading/sequenced_task_runner_handle.h"
|
| #include "base/threading/thread_local.h"
|
|
|
| namespace base {
|
|
|
| namespace {
|
|
|
| -base::LazyInstance<base::ThreadLocalPointer<ThreadTaskRunnerHandle> >::Leaky
|
| +base::LazyInstance<base::ThreadLocalPointer<ThreadTaskRunnerHandle>>::Leaky
|
| lazy_tls_ptr = LAZY_INSTANCE_INITIALIZER;
|
|
|
| } // namespace
|
| @@ -26,21 +30,23 @@ scoped_refptr<SingleThreadTaskRunner> ThreadTaskRunnerHandle::Get() {
|
|
|
| // static
|
| bool ThreadTaskRunnerHandle::IsSet() {
|
| - return lazy_tls_ptr.Pointer()->Get() != NULL;
|
| + return !!lazy_tls_ptr.Pointer()->Get();
|
| }
|
|
|
| ThreadTaskRunnerHandle::ThreadTaskRunnerHandle(
|
| scoped_refptr<SingleThreadTaskRunner> task_runner)
|
| : task_runner_(std::move(task_runner)) {
|
| DCHECK(task_runner_->BelongsToCurrentThread());
|
| - DCHECK(!lazy_tls_ptr.Pointer()->Get());
|
| + // No SequencedTaskRunnerHandle (which includes ThreadTaskRunnerHandles)
|
| + // should already be set for this thread.
|
| + DCHECK(!SequencedTaskRunnerHandle::IsSet());
|
| lazy_tls_ptr.Pointer()->Set(this);
|
| }
|
|
|
| ThreadTaskRunnerHandle::~ThreadTaskRunnerHandle() {
|
| DCHECK(task_runner_->BelongsToCurrentThread());
|
| DCHECK_EQ(lazy_tls_ptr.Pointer()->Get(), this);
|
| - lazy_tls_ptr.Pointer()->Set(NULL);
|
| + lazy_tls_ptr.Pointer()->Set(nullptr);
|
| }
|
|
|
| } // namespace base
|
|
|