| // Copyright 2016 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #include "base/task/task_scheduler/task.h" |
| |
| #include <utility> |
| |
| #include "base/atomic_sequence_num.h" |
| |
| namespace base { |
| namespace internal { |
| |
| namespace { |
| |
| AtomicSequenceNumber g_sequence_nums_for_tracing; |
| |
| } // namespace |
| |
| Task::Task(const Location& posted_from, OnceClosure task, TimeDelta delay) |
| : PendingTask(posted_from, |
| std::move(task), |
| delay.is_zero() ? TimeTicks() : TimeTicks::Now() + delay, |
| Nestable::kNonNestable), |
| delay(delay) { |
| // TaskScheduler doesn't use |sequence_num| but tracing (toplevel.flow) relies |
| // on it being unique. While this subtle dependency is a bit overreaching, |
| // TaskScheduler is the only task system that doesn't use |sequence_num| and |
| // the dependent code rarely changes so this isn't worth a big change and |
| // faking it here isn't too bad for now (posting tasks is full of atomic ops |
| // already). |
| this->sequence_num = g_sequence_nums_for_tracing.GetNext(); |
| } |
| |
| // This should be "= default but MSVC has trouble with "noexcept = default" in |
| // this case. |
| Task::Task(Task&& other) noexcept |
| : PendingTask(std::move(other)), |
| delay(other.delay), |
| sequenced_time(other.sequenced_time), |
| sequenced_task_runner_ref(std::move(other.sequenced_task_runner_ref)), |
| single_thread_task_runner_ref( |
| std::move(other.single_thread_task_runner_ref)) {} |
| |
| Task::~Task() = default; |
| |
| Task& Task::operator=(Task&& other) = default; |
| |
| } // namespace internal |
| } // namespace base |