mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-11-24 06:16:30 +03:00
68 lines
1.6 KiB
C++
68 lines
1.6 KiB
C++
// 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;
|
|
|
|
// Task backtrace.
|
|
std::array<const void*, 4> task_backtrace;
|
|
|
|
// Secondary sort key for run time.
|
|
int sequence_num;
|
|
|
|
// OK to dispatch from a nested loop.
|
|
Nestable nestable;
|
|
|
|
// Needs high resolution timers.
|
|
bool is_high_res;
|
|
};
|
|
|
|
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_
|