blob: 32be1c8c7156dab0236c5b1f83f340ddb144b7a9 [file] [log] [blame]
// 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.
#ifndef BASE_TASK_THREAD_POOL_TASK_SOURCE_SORT_KEY_H_
#define BASE_TASK_THREAD_POOL_TASK_SOURCE_SORT_KEY_H_
#include "base/base_export.h"
#include "base/task/task_traits.h"
#include "base/time/time.h"
namespace base {
namespace internal {
// An immutable but assignable representation of the priority of a Sequence.
class BASE_EXPORT TaskSourceSortKey final {
public:
TaskSourceSortKey() = default;
TaskSourceSortKey(TaskPriority priority, TimeTicks next_task_sequenced_time);
TaskPriority priority() const { return priority_; }
TimeTicks next_task_sequenced_time() const {
return next_task_sequenced_time_;
}
// Lower sort key means more important.
bool operator<=(const TaskSourceSortKey& other) const;
bool operator==(const TaskSourceSortKey& other) const {
return priority_ == other.priority_ &&
next_task_sequenced_time_ == other.next_task_sequenced_time_;
}
bool operator!=(const TaskSourceSortKey& other) const {
return !(other == *this);
}
private:
// The private section allows this class to keep its immutable property while
// being copy-assignable (i.e. instead of making its members const).
// Highest task priority in the sequence at the time this sort key was
// created.
TaskPriority priority_;
// Sequenced time of the next task to run in the sequence at the time this
// sort key was created.
TimeTicks next_task_sequenced_time_;
};
} // namespace internal
} // namespace base
#endif // BASE_TASK_THREAD_POOL_TASK_SOURCE_SORT_KEY_H_