Chromium Code Reviews| 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..3a02ab05ffec217d3c53f94120fa3a239d9817e6 |
| --- /dev/null |
| +++ b/base/task_scheduler/sequence_sort_key.h |
| @@ -0,0 +1,46 @@ |
| +// 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/gtest_prod_util.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 |
| +// PriorityQueue, a SequenceSortKey is immutable. |
| +class BASE_EXPORT SequenceSortKey { |
| + public: |
| + SequenceSortKey(); |
| + SequenceSortKey(TaskPriority priority, TimeTicks next_task_post_time); |
|
gab
2016/02/18 03:00:46
Add comments on constructors to highlight differen
fdoray
2016/02/18 14:56:12
Default constructor is not needed.
|
| + |
| + // Returns true if the the sequence associated with this sort key must run |
| + // after the sequence associated with |other|. |
|
fdoray
2016/02/18 01:46:11
Or, more simply:
Indicates whether the priority o
gab
2016/02/18 03:00:46
Or more simply: no comment as this is implicit fro
fdoray
2016/02/18 14:56:12
Done.
|
| + bool operator<(const SequenceSortKey& other) const; |
| + |
| + // Used for testing. |
|
gab
2016/02/18 03:00:46
Wouldn't bother with this comment.
fdoray
2016/02/18 14:56:12
Done.
|
| + bool operator==(const SequenceSortKey& other) const; |
| + |
| + TaskPriority priority() const { return priority_; } |
| + |
| + private: |
| + FRIEND_TEST_ALL_PREFIXES(TaskSchedulerSequenceTest, GetSequenceSortKey); |
|
gab
2016/02/18 03:00:46
Let's make this a struct with public members, does
fdoray
2016/02/18 14:56:12
As explained below, the members can't be const. I
|
| + |
| + // Highest task priority in the sequence at the time this sort key is created. |
|
fdoray
2016/02/18 01:46:11
*was created?
gab
2016/02/18 03:00:46
Yes.
fdoray
2016/02/18 14:56:13
Done.
|
| + TaskPriority priority_; |
|
gab
2016/02/18 03:00:46
const
fdoray
2016/02/18 14:56:12
Sadly, std::priority_queue needs operator=, which
gab
2016/02/18 20:22:34
Ugh :-(... really?! It does in place replacements
gab
2016/02/18 21:21:16
Resurfacing this.
fdoray
2016/02/18 22:19:53
Done.
|
| + |
| + // Post time of the next task to run in the sequence. |
|
fdoray
2016/02/18 01:46:11
... at the time this sort key was created.
fdoray
2016/02/18 14:56:12
Done.
|
| + TimeTicks next_task_post_time_; |
|
gab
2016/02/18 03:00:46
const
fdoray
2016/02/18 14:56:12
Same comment as above.
|
| +}; |
| + |
| +} // namespace internal |
| +} // namespace base |
| + |
| +#endif // BASE_TASK_SCHEDULER_SEQUENCE_SORT_KEY_H_ |