| Index: third_party/WebKit/Source/platform/scheduler/base/time_domain.h
|
| diff --git a/third_party/WebKit/Source/platform/scheduler/base/time_domain.h b/third_party/WebKit/Source/platform/scheduler/base/time_domain.h
|
| index 52c7678eea23ac5de1257546e25a5172f24ea4fa..b6b1150b7f3332387cc3d6e18df2e7a18c21e038 100644
|
| --- a/third_party/WebKit/Source/platform/scheduler/base/time_domain.h
|
| +++ b/third_party/WebKit/Source/platform/scheduler/base/time_domain.h
|
| @@ -13,6 +13,7 @@
|
| #include "base/memory/ref_counted.h"
|
| #include "base/memory/weak_ptr.h"
|
| #include "base/time/time.h"
|
| +#include "platform/scheduler/base/intrusive_heap.h"
|
| #include "platform/scheduler/base/lazy_now.h"
|
| #include "platform/scheduler/base/task_queue_impl.h"
|
|
|
| @@ -134,20 +135,18 @@ class BLINK_PLATFORM_EXPORT TimeDomain {
|
| private:
|
| void MoveNewlyUpdatableQueuesIntoUpdatableQueueSet();
|
|
|
| - using DelayedWakeupMultimap =
|
| - std::multimap<base::TimeTicks, internal::TaskQueueImpl*>;
|
| + struct DelayedWakeup {
|
| + base::TimeTicks time;
|
| + internal::TaskQueueImpl* queue;
|
|
|
| - DelayedWakeupMultimap delayed_wakeup_multimap_;
|
| + bool operator<=(const DelayedWakeup& other) const {
|
| + return time <= other.time;
|
| + }
|
|
|
| - // This map makes it easy to remove a queue from |delayed_wakeup_multimap_|.
|
| - // NOTE inserting or removing elements from a std::map does not invalidate any
|
| - // iterators.
|
| - using QueueToDelayedWakeupMultimapIteratorMap =
|
| - std::unordered_map<internal::TaskQueueImpl*,
|
| - DelayedWakeupMultimap::iterator>;
|
| + void SetHeapIndex(size_t i) { queue->set_heap_index(i); }
|
| + };
|
|
|
| - QueueToDelayedWakeupMultimapIteratorMap
|
| - queue_to_delayed_wakeup_multimap_iterator_map_;
|
| + IntrusiveHeap<DelayedWakeup> delayed_wakeup_queue_;
|
|
|
| // This lock guards only |newly_updatable_|. It's not expected to be heavily
|
| // contended.
|
|
|