| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 #include "content/renderer/input/main_thread_event_queue_task_list.h" | 5 #include "content/renderer/input/main_thread_event_queue_task_list.h" |
| 6 | 6 |
| 7 namespace content { | 7 namespace content { |
| 8 | 8 |
| 9 MainThreadEventQueueTaskList::MainThreadEventQueueTaskList() {} | 9 MainThreadEventQueueTaskList::MainThreadEventQueueTaskList() {} |
| 10 | 10 |
| 11 MainThreadEventQueueTaskList::~MainThreadEventQueueTaskList() {} | 11 MainThreadEventQueueTaskList::~MainThreadEventQueueTaskList() {} |
| 12 | 12 |
| 13 void MainThreadEventQueueTaskList::Queue( | 13 void MainThreadEventQueueTaskList::Queue( |
| 14 std::unique_ptr<MainThreadEventQueueTask> event) { | 14 std::unique_ptr<MainThreadEventQueueTask> event) { |
| 15 for (auto last_event_iter = queue_.rbegin(); last_event_iter != queue_.rend(); | 15 for (auto last_event_iter = queue_.rbegin(); last_event_iter != queue_.rend(); |
| 16 ++last_event_iter) { | 16 ++last_event_iter) { |
| 17 switch ((*last_event_iter)->CoalesceWith(*event.get())) { | 17 switch ((*last_event_iter)->FilterNewEvent(*event.get())) { |
| 18 case MainThreadEventQueueTask::CoalesceResult::Coalesced: | 18 case MainThreadEventQueueTask::FilterResult::CoalescedEvent: |
| 19 return; | 19 return; |
| 20 case MainThreadEventQueueTask::CoalesceResult::CannotCoalesce: | 20 case MainThreadEventQueueTask::FilterResult::StopIterating: |
| 21 break; | 21 break; |
| 22 case MainThreadEventQueueTask::CoalesceResult::KeepSearching: | 22 case MainThreadEventQueueTask::FilterResult::KeepIterating: |
| 23 continue; | 23 continue; |
| 24 } | 24 } |
| 25 break; | 25 break; |
| 26 } | 26 } |
| 27 queue_.emplace_back(std::move(event)); | 27 queue_.emplace_back(std::move(event)); |
| 28 } | 28 } |
| 29 | 29 |
| 30 std::unique_ptr<MainThreadEventQueueTask> MainThreadEventQueueTaskList::Pop() { | 30 std::unique_ptr<MainThreadEventQueueTask> MainThreadEventQueueTaskList::Pop() { |
| 31 std::unique_ptr<MainThreadEventQueueTask> result; | 31 std::unique_ptr<MainThreadEventQueueTask> result; |
| 32 if (!queue_.empty()) { | 32 if (!queue_.empty()) { |
| 33 result.reset(queue_.front().release()); | 33 result.reset(queue_.front().release()); |
| 34 queue_.pop_front(); | 34 queue_.pop_front(); |
| 35 } | 35 } |
| 36 return result; | 36 return result; |
| 37 } | 37 } |
| 38 | 38 |
| 39 } // namespace | 39 } // namespace |
| OLD | NEW |