Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5293)

Unified Diff: base/task_scheduler/sequence_sort_key.h

Issue 1705253002: TaskScheduler [3/9] Task and Sequence (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@s_1_scheduler_lock
Patch Set: self review Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: base/task_scheduler/sequence_sort_key.h
diff --git a/base/task_scheduler/sequence_sort_key.h b/base/task_scheduler/sequence_sort_key.h
new file mode 100644
index 0000000000000000000000000000000000000000..d89ac9b9a3a1ccc3a9ed2b1db186e5a41a4d130c
--- /dev/null
+++ b/base/task_scheduler/sequence_sort_key.h
@@ -0,0 +1,37 @@
+// 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_SCHEDULER_SEQUENCE_SORT_KEY_H_
+#define BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_
+
+#include "base/base_export.h"
+#include "base/task_scheduler/task_traits.h"
+#include "base/time/time.h"
+
+namespace base {
+namespace internal {
+
+// A SequenceSortKey determines the position of a Sequence in a PriorityQueue.
+// Contrary to a Sequence, which can be modified when it is inside a
robliao 2016/02/19 02:33:43 // An immutable representation of the priority of
fdoray 2016/02/19 14:12:14 Done.
+// PriorityQueue, a SequenceSortKey is immutable.
+struct BASE_EXPORT SequenceSortKey {
robliao 2016/02/19 02:33:43 Nit: Add final.
fdoray 2016/02/19 14:12:14 Done.
+ public:
+ SequenceSortKey(TaskPriority priority, TimeTicks next_task_sequenced_time);
+
+ bool operator<(const SequenceSortKey& other) const;
robliao 2016/02/19 02:33:43 Do we need to support operator reflexivity? a < b
fdoray 2016/02/19 14:12:14 We need operator< to sort sequences in PriorityQue
gab 2016/02/19 16:50:47 Good catch Rob. The style @ https://google.github
gab 2016/02/19 16:52:56 Note: it may also make sense to remove comparison
fdoray 2016/02/19 22:28:29 As we discussed, the comparison is required outsid
+ bool operator==(const SequenceSortKey& other) const;
+
+ // Highest task priority in the sequence at the time this sort key was
+ // created.
+ const TaskPriority priority_;
robliao 2016/02/19 02:33:43 Will this immutability cause problems in STL conta
fdoray 2016/02/19 14:12:14 You're right, we won't be able to create STL conta
robliao 2016/02/22 21:34:12 Acknowledged.
+
+ // Sequenced time of the next task to run in the sequence at the time this
+ // sort key was created.
+ const TimeTicks next_task_sequenced_time_;
+};
+
+} // namespace internal
+} // namespace base
+
+#endif // BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_

Powered by Google App Engine
This is Rietveld 408576698