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

Side by Side Diff: ui/events/event_target_iterator.h

Issue 2628393003: Remove ScopedVector from ui/events/. (Closed)
Patch Set: chromeos2 Created 3 years, 11 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 UI_EVENTS_EVENT_TARGET_ITERATOR_H_ 5 #ifndef UI_EVENTS_EVENT_TARGET_ITERATOR_H_
6 #define UI_EVENTS_EVENT_TARGET_ITERATOR_H_ 6 #define UI_EVENTS_EVENT_TARGET_ITERATOR_H_
7 7
8 #include <memory>
8 #include <vector> 9 #include <vector>
9 10
10 namespace ui { 11 namespace ui {
11 12
12 class EventTarget; 13 class EventTarget;
13 14
14 // An interface that allows iterating over a set of EventTargets. 15 // An interface that allows iterating over a set of EventTargets.
15 class EventTargetIterator { 16 class EventTargetIterator {
16 public: 17 public:
17 virtual ~EventTargetIterator() {} 18 virtual ~EventTargetIterator() {}
18 virtual EventTarget* GetNextTarget() = 0; 19 virtual EventTarget* GetNextTarget() = 0;
19 }; 20 };
20 21
21 // Provides an EventTargetIterator implementation for iterating over a list of 22 // Provides EventTargetIterator implementations for iterating over a list of
22 // EventTargets. The list is iterated in the reverse order, since typically the 23 // EventTargets. The list is iterated in the reverse order, since typically the
23 // EventTargets are maintained in increasing z-order in the lists. 24 // EventTargets are maintained in increasing z-order in the lists.
24 template<typename T> 25 template <typename T>
25 class EventTargetIteratorImpl : public EventTargetIterator { 26 class EventTargetIteratorPtrImpl : public EventTargetIterator {
26 public: 27 public:
27 explicit EventTargetIteratorImpl(const std::vector<T*>& children) 28 explicit EventTargetIteratorPtrImpl(const std::vector<T*>& children)
28 : begin_(children.rbegin()), 29 : begin_(children.rbegin()), end_(children.rend()) {}
29 end_(children.rend()) { 30 ~EventTargetIteratorPtrImpl() override {}
30 }
31 ~EventTargetIteratorImpl() override {}
32 31
33 EventTarget* GetNextTarget() override { 32 EventTarget* GetNextTarget() override {
34 if (begin_ == end_) 33 if (begin_ == end_)
35 return NULL; 34 return nullptr;
36 EventTarget* target = *(begin_); 35 EventTarget* target = *(begin_);
37 ++begin_; 36 ++begin_;
38 return target; 37 return target;
39 } 38 }
40 39
41 private: 40 private:
42 typename std::vector<T*>::const_reverse_iterator begin_; 41 typename std::vector<T*>::const_reverse_iterator begin_;
43 typename std::vector<T*>::const_reverse_iterator end_; 42 typename std::vector<T*>::const_reverse_iterator end_;
44 }; 43 };
45 44
45 template <typename T>
46 class EventTargetIteratorUniquePtrImpl : public EventTargetIterator {
47 public:
48 explicit EventTargetIteratorUniquePtrImpl(
49 const std::vector<std::unique_ptr<T>>& children)
50 : begin_(children.rbegin()), end_(children.rend()) {}
51 ~EventTargetIteratorUniquePtrImpl() override {}
52
53 EventTarget* GetNextTarget() override {
54 if (begin_ == end_)
55 return nullptr;
56 EventTarget* target = begin_->get();
57 ++begin_;
58 return target;
59 }
60
61 private:
62 typename std::vector<std::unique_ptr<T>>::const_reverse_iterator begin_;
63 typename std::vector<std::unique_ptr<T>>::const_reverse_iterator end_;
64 };
65
46 } // namespace ui 66 } // namespace ui
47 67
48 #endif // UI_EVENTS_EVENT_TARGET_ITERATOR_H_ 68 #endif // UI_EVENTS_EVENT_TARGET_ITERATOR_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698