// Copyright (c) 2011 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. #ifndef BASE_PENDING_TASK_H_ #define BASE_PENDING_TASK_H_ #include <array> #include "base/base_export.h" #include "base/callback.h" #include "base/containers/queue.h" #include "base/location.h" #include "base/time/time.h" namespace base { enum class Nestable { kNonNestable, kNestable, }; // Contains data about a pending task. Stored in TaskQueue and DelayedTaskQueue // for use by classes that queue and execute tasks. struct BASE_EXPORT PendingTask { PendingTask(const Location& posted_from, OnceClosure task, TimeTicks delayed_run_time = TimeTicks(), Nestable nestable = Nestable::kNestable); PendingTask(PendingTask&& other); ~PendingTask(); PendingTask& operator=(PendingTask&& other); // Used to support sorting. bool operator<(const PendingTask& other) const; // The task to run. OnceClosure task; // The site this PendingTask was posted from. Location posted_from; // The time when the task should be run. base::TimeTicks delayed_run_time; // Chain of up-to-four symbols of the parent tasks which led to this one being // posted. std::array<const void*, 4> task_backtrace = {}; // Secondary sort key for run time. int sequence_num = 0; // OK to dispatch from a nested loop. Nestable nestable; // Needs high resolution timers. bool is_high_res = false; }; using TaskQueue = base::queue<PendingTask>; // PendingTasks are sorted by their |delayed_run_time| property. using DelayedTaskQueue = std::priority_queue<base::PendingTask>; } // namespace base #endif // BASE_PENDING_TASK_H_