Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "base/task_scheduler/task.h" | 5 #include "base/task_scheduler/task.h" |
| 6 | 6 |
| 7 namespace base { | 7 namespace base { |
| 8 namespace internal { | 8 namespace internal { |
| 9 | 9 |
| 10 Task::Task(const tracked_objects::Location& posted_from, | 10 Task::Task(const tracked_objects::Location& posted_from, |
| 11 const Closure& task, | 11 const Closure& task, |
| 12 const TaskTraits& traits, | 12 const TaskTraits& traits_in, |
| 13 const TimeDelta& delay) | 13 const TimeDelta& delay) |
| 14 : PendingTask(posted_from, | 14 : PendingTask(posted_from, |
| 15 task, | 15 task, |
| 16 delay.is_zero() ? TimeTicks() : TimeTicks::Now() + delay, | 16 delay.is_zero() ? TimeTicks() : TimeTicks::Now() + delay, |
| 17 false), // Not nestable. | 17 false), // Not nestable. |
| 18 traits(traits) {} | 18 traits_in(traits) { |
| 19 // Prevent a delayed BLOCK_SHUTDOWN task from blocking shutdown before being | |
| 20 // scheduled by changing its shutdown behavior to SKIP_ON_SHUTDOWN. | |
| 21 if (!delay.is_zero() && | |
| 22 traits.shutdown_behavior() == TaskShutdownBehavior::BLOCK_SHUTDOWN) { | |
| 23 traits_in.WithShutdownBehavior(TaskShutdownBehavior::SKIP_ON_SHUTDOWN); | |
|
robliao
2016/10/03 17:16:35
Should this be traits instead of traits_in?
Actua
fdoray
2016/10/03 17:27:48
I uploaded the wrong patch. This should be |traits
robliao
2016/10/03 17:30:12
I'm meant a TODO that we're rewriting the shutdown
fdoray
2016/10/03 17:36:33
From our chat discussion, I thought we wanted to a
robliao
2016/10/03 17:50:25
Discussed offline: We'll go ahead and keep this lo
| |
| 24 } | |
| 25 } | |
| 19 | 26 |
| 20 Task::~Task() = default; | 27 Task::~Task() = default; |
| 21 | 28 |
| 22 } // namespace internal | 29 } // namespace internal |
| 23 } // namespace base | 30 } // namespace base |
| OLD | NEW |