ExtensionSyncService: Properly differentiate between "pending install" and "pending...
[chromium-blink-merge.git] / base / message_loop / message_loop_task_runner.cc
blobc9b5ffe3f739d0bdb312f3ac3d6d6de8e4adf580
1 // Copyright (c) 2012 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.
5 #include "base/message_loop/message_loop_task_runner.h"
7 #include "base/location.h"
8 #include "base/logging.h"
9 #include "base/message_loop/incoming_task_queue.h"
11 namespace base {
12 namespace internal {
14 MessageLoopTaskRunner::MessageLoopTaskRunner(
15 scoped_refptr<IncomingTaskQueue> incoming_queue)
16 : incoming_queue_(incoming_queue), valid_thread_id_(kInvalidThreadId) {
19 void MessageLoopTaskRunner::BindToCurrentThread() {
20 AutoLock lock(valid_thread_id_lock_);
21 DCHECK_EQ(kInvalidThreadId, valid_thread_id_);
22 valid_thread_id_ = PlatformThread::CurrentId();
25 bool MessageLoopTaskRunner::PostDelayedTask(
26 const tracked_objects::Location& from_here,
27 const base::Closure& task,
28 base::TimeDelta delay) {
29 DCHECK(!task.is_null()) << from_here.ToString();
30 return incoming_queue_->AddToIncomingQueue(from_here, task, delay, true);
33 bool MessageLoopTaskRunner::PostNonNestableDelayedTask(
34 const tracked_objects::Location& from_here,
35 const base::Closure& task,
36 base::TimeDelta delay) {
37 DCHECK(!task.is_null()) << from_here.ToString();
38 return incoming_queue_->AddToIncomingQueue(from_here, task, delay, false);
41 bool MessageLoopTaskRunner::RunsTasksOnCurrentThread() const {
42 AutoLock lock(valid_thread_id_lock_);
43 return valid_thread_id_ == PlatformThread::CurrentId();
46 MessageLoopTaskRunner::~MessageLoopTaskRunner() {
49 } // namespace internal
51 } // namespace base