Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 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 #include "webkit/dom_storage/dom_storage_task_runner.h" | 5 #include "webkit/dom_storage/dom_storage_task_runner.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/message_loop_proxy.h" | 9 #include "base/message_loop_proxy.h" |
| 10 | 10 |
| 11 namespace dom_storage { | 11 namespace dom_storage { |
| 12 | 12 |
| 13 // DomStorageTaskRunner | 13 // DomStorageTaskRunner |
| 14 | 14 |
| 15 DomStorageTaskRunner::DomStorageTaskRunner( | 15 DomStorageTaskRunner::DomStorageTaskRunner( |
| 16 base::MessageLoopProxy* message_loop) | 16 base::MessageLoopProxy* message_loop) |
| 17 : message_loop_(message_loop) { | 17 : message_loop_(message_loop) { |
| 18 } | 18 } |
| 19 | 19 |
| 20 DomStorageTaskRunner::~DomStorageTaskRunner() { | 20 DomStorageTaskRunner::~DomStorageTaskRunner() { |
| 21 } | 21 } |
| 22 | 22 |
| 23 void DomStorageTaskRunner::PostTask( | 23 bool DomStorageTaskRunner::PostTask( |
| 24 const tracked_objects::Location& from_here, | 24 const tracked_objects::Location& from_here, |
| 25 const base::Closure& task) { | 25 const base::Closure& task) { |
| 26 message_loop_->PostTask(from_here, task); | 26 return message_loop_->PostTask(from_here, task); |
| 27 } | 27 } |
| 28 | 28 |
| 29 void DomStorageTaskRunner::PostDelayedTask( | 29 bool DomStorageTaskRunner::PostDelayedTask( |
| 30 const tracked_objects::Location& from_here, | 30 const tracked_objects::Location& from_here, |
| 31 const base::Closure& task, | 31 const base::Closure& task, |
| 32 base::TimeDelta delay) { | 32 base::TimeDelta delay) { |
| 33 message_loop_->PostDelayedTask(from_here, task, delay.InMilliseconds()); | 33 return message_loop_->PostDelayedTask(from_here, task, |
| 34 delay.InMilliseconds()); | |
| 34 } | 35 } |
| 35 | 36 |
| 36 // DomStorageWorkerPoolTaskRunner | 37 // DomStorageWorkerPoolTaskRunner |
| 37 | 38 |
| 38 DomStorageWorkerPoolTaskRunner::DomStorageWorkerPoolTaskRunner( | 39 DomStorageWorkerPoolTaskRunner::DomStorageWorkerPoolTaskRunner( |
| 39 base::SequencedWorkerPool* sequenced_worker_pool, | 40 base::SequencedWorkerPool* sequenced_worker_pool, |
| 40 base::MessageLoopProxy* delayed_task_loop) | 41 base::MessageLoopProxy* delayed_task_loop) |
| 41 : DomStorageTaskRunner(delayed_task_loop), | 42 : DomStorageTaskRunner(delayed_task_loop), |
| 42 sequenced_worker_pool_(sequenced_worker_pool), | 43 sequenced_worker_pool_(sequenced_worker_pool), |
| 43 sequence_token_( | 44 sequence_token_( |
| 44 sequenced_worker_pool->GetNamedSequenceToken("dom_storage_token")) { | 45 sequenced_worker_pool->GetNamedSequenceToken("dom_storage_token")) { |
| 45 } | 46 } |
| 46 | 47 |
| 47 DomStorageWorkerPoolTaskRunner::~DomStorageWorkerPoolTaskRunner() { | 48 DomStorageWorkerPoolTaskRunner::~DomStorageWorkerPoolTaskRunner() { |
| 48 } | 49 } |
| 49 | 50 |
| 50 void DomStorageWorkerPoolTaskRunner::PostTask( | 51 bool DomStorageWorkerPoolTaskRunner::PostTask( |
| 52 const tracked_objects::Location& from_here, | |
| 53 const base::Closure& task) { | |
| 54 // TODO(michaeln): Do all tasks need to be run prior to shutdown? | |
| 55 // Maybe make better use of the SHUTDOWN_BEHAVIOR. | |
| 56 return sequenced_worker_pool_->PostSequencedWorkerTask( | |
| 57 sequence_token_, from_here, task); | |
| 58 } | |
| 59 | |
| 60 bool DomStorageWorkerPoolTaskRunner::PostDelayedTask( | |
| 61 const tracked_objects::Location& from_here, | |
| 62 const base::Closure& task, | |
| 63 base::TimeDelta delay) { | |
| 64 // Post a task to call this->PostTask() after the delay. | |
| 65 return message_loop_->PostDelayedTask( | |
| 66 FROM_HERE, | |
| 67 base::Bind(&DomStorageWorkerPoolTaskRunner::PostTaskVoid, this, | |
|
michaeln
2012/02/15 04:10:53
You may be able to use base::IgnoreResult() on the
benm (inactive)
2012/02/15 17:38:17
I think the best I can do is wrap a call to PostTa
| |
| 68 from_here, task), | |
| 69 delay.InMilliseconds()); | |
| 70 } | |
| 71 | |
| 72 void DomStorageWorkerPoolTaskRunner::PostTaskVoid( | |
| 51 const tracked_objects::Location& from_here, | 73 const tracked_objects::Location& from_here, |
| 52 const base::Closure& task) { | 74 const base::Closure& task) { |
| 53 // TODO(michaeln): Do all tasks need to be run prior to shutdown? | 75 // TODO(michaeln): Do all tasks need to be run prior to shutdown? |
| 54 // Maybe make better use of the SHUTDOWN_BEHAVIOR. | 76 // Maybe make better use of the SHUTDOWN_BEHAVIOR. |
| 55 sequenced_worker_pool_->PostSequencedWorkerTask( | 77 sequenced_worker_pool_->PostSequencedWorkerTask( |
| 56 sequence_token_, from_here, task); | 78 sequence_token_, from_here, task); |
| 57 } | 79 } |
| 58 | 80 |
| 59 void DomStorageWorkerPoolTaskRunner::PostDelayedTask( | |
| 60 const tracked_objects::Location& from_here, | |
| 61 const base::Closure& task, | |
| 62 base::TimeDelta delay) { | |
| 63 // Post a task to call this->PostTask() after the delay. | |
| 64 message_loop_->PostDelayedTask( | |
| 65 FROM_HERE, | |
| 66 base::Bind(&DomStorageWorkerPoolTaskRunner::PostTask, this, | |
| 67 from_here, task), | |
| 68 delay.InMilliseconds()); | |
| 69 } | |
| 70 | |
| 71 } // namespace dom_storage | 81 } // namespace dom_storage |
| OLD | NEW |