OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_ | 5 #ifndef BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_ |
6 #define BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_ | 6 #define BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_ |
7 | 7 |
8 #include "base/base_export.h" | 8 #include "base/base_export.h" |
9 #include "base/task_scheduler/task_traits.h" | 9 #include "base/task_scheduler/task_traits.h" |
10 #include "base/time/time.h" | 10 #include "base/time/time.h" |
11 | 11 |
12 namespace base { | 12 namespace base { |
13 namespace internal { | 13 namespace internal { |
14 | 14 |
15 // An immutable representation of the priority of a Sequence. | 15 // An immutable but assignable representation of the priority of a Sequence. |
16 struct BASE_EXPORT SequenceSortKey final { | 16 class BASE_EXPORT SequenceSortKey final { |
| 17 public: |
17 SequenceSortKey(TaskPriority priority, TimeTicks next_task_sequenced_time); | 18 SequenceSortKey(TaskPriority priority, TimeTicks next_task_sequenced_time); |
18 | 19 |
19 bool operator<(const SequenceSortKey& other) const; | 20 bool operator<(const SequenceSortKey& other) const; |
20 bool operator>(const SequenceSortKey& other) const { return other < *this; } | 21 bool operator>(const SequenceSortKey& other) const { return other < *this; } |
21 | 22 |
| 23 bool operator==(const SequenceSortKey& other) const { |
| 24 return priority_ == other.priority_ && |
| 25 next_task_sequenced_time_ == other.next_task_sequenced_time_; |
| 26 } |
| 27 bool operator!=(const SequenceSortKey& other) const { |
| 28 return !(other == *this); |
| 29 }; |
| 30 |
| 31 private: |
| 32 // The private section allows this class to keep its immutable property while |
| 33 // being copy-assignable (i.e. instead of making its members const). |
| 34 |
22 // Highest task priority in the sequence at the time this sort key was | 35 // Highest task priority in the sequence at the time this sort key was |
23 // created. | 36 // created. |
24 const TaskPriority priority; | 37 TaskPriority priority_; |
25 | 38 |
26 // Sequenced time of the next task to run in the sequence at the time this | 39 // Sequenced time of the next task to run in the sequence at the time this |
27 // sort key was created. | 40 // sort key was created. |
28 const TimeTicks next_task_sequenced_time; | 41 TimeTicks next_task_sequenced_time_; |
29 }; | 42 }; |
30 | 43 |
31 } // namespace internal | 44 } // namespace internal |
32 } // namespace base | 45 } // namespace base |
33 | 46 |
34 #endif // BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_ | 47 #endif // BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_ |
OLD | NEW |