1 // Copyright 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CC_BASE_SCOPED_PTR_VECTOR_H_
6 #define CC_BASE_SCOPED_PTR_VECTOR_H_
11 #include "base/basictypes.h"
12 #include "base/logging.h"
13 #include "base/memory/scoped_ptr.h"
14 #include "base/stl_util.h"
18 // This type acts like a vector<scoped_ptr> based on top of std::vector. The
19 // ScopedPtrVector has ownership of all elements in the vector.
21 class ScopedPtrVector
{
23 typedef typename
std::vector
<T
*>::const_iterator const_iterator
;
24 typedef typename
std::vector
<T
*>::reverse_iterator reverse_iterator
;
25 typedef typename
std::vector
<T
*>::const_reverse_iterator
26 const_reverse_iterator
;
28 #if defined(OS_ANDROID)
29 // On Android the iterator is not a class, so we can't block assignment.
30 typedef typename
std::vector
<T
*>::iterator iterator
;
32 // Ban setting values on the iterator directly. New pointers must be passed
33 // to methods on the ScopedPtrVector class to appear in the vector.
34 class iterator
: public std::vector
<T
*>::iterator
{
36 iterator(const typename
std::vector
<T
*>::iterator
& other
) // NOLINT
37 : std::vector
<T
*>::iterator(other
) {}
38 T
* const& operator*() { return std::vector
<T
*>::iterator::operator*(); }
44 ~ScopedPtrVector() { clear(); }
50 T
* at(size_t index
) const {
51 DCHECK(index
< size());
55 T
* operator[](size_t index
) const {
66 return at(size() - 1);
73 scoped_ptr
<T
> take(iterator position
) {
74 if (position
== end())
75 return scoped_ptr
<T
>();
76 DCHECK(position
< end());
78 typename
std::vector
<T
*>::iterator writable_position
= position
;
79 scoped_ptr
<T
> ret(*writable_position
);
80 *writable_position
= NULL
;
84 scoped_ptr
<T
> take_back() {
87 return scoped_ptr
<T
>(NULL
);
88 return take(end() - 1);
91 void erase(iterator position
) {
92 if (position
== end())
94 typename
std::vector
<T
*>::iterator writable_position
= position
;
95 delete *writable_position
;
96 data_
.erase(position
);
99 void erase(iterator first
, iterator last
) {
100 DCHECK(first
<= last
);
101 for (iterator it
= first
; it
!= last
; ++it
) {
104 typename
std::vector
<T
*>::iterator writable_it
= it
;
107 data_
.erase(first
, last
);
110 void reserve(size_t size
) {
115 STLDeleteElements(&data_
);
118 void push_back(scoped_ptr
<T
> item
) {
119 data_
.push_back(item
.release());
127 void insert(iterator position
, scoped_ptr
<T
> item
) {
128 DCHECK(position
<= end());
129 data_
.insert(position
, item
.release());
132 void insert_and_take(iterator position
,
133 ScopedPtrVector
<T
>& other
) {
134 std::vector
<T
*> tmp_data
;
135 for (ScopedPtrVector
<T
>::iterator it
= other
.begin();
138 tmp_data
.push_back(other
.take(it
).release());
140 data_
.insert(position
, tmp_data
.begin(), tmp_data
.end());
143 void swap(ScopedPtrVector
<T
>& other
) {
144 data_
.swap(other
.data_
);
147 void swap(iterator a
, iterator b
) {
150 if (a
== end() || b
== end() || a
== b
)
152 typename
std::vector
<T
*>::iterator writable_a
= a
;
153 typename
std::vector
<T
*>::iterator writable_b
= b
;
154 std::swap(*writable_a
, *writable_b
);
157 template<class Compare
>
158 inline void sort(Compare comp
) {
159 std::sort(data_
.begin(), data_
.end(), comp
);
162 iterator
begin() { return static_cast<iterator
>(data_
.begin()); }
163 const_iterator
begin() const { return data_
.begin(); }
164 iterator
end() { return static_cast<iterator
>(data_
.end()); }
165 const_iterator
end() const { return data_
.end(); }
167 reverse_iterator
rbegin() { return data_
.rbegin(); }
168 const_reverse_iterator
rbegin() const { return data_
.rbegin(); }
169 reverse_iterator
rend() { return data_
.rend(); }
170 const_reverse_iterator
rend() const { return data_
.rend(); }
173 std::vector
<T
*> data_
;
175 DISALLOW_COPY_AND_ASSIGN(ScopedPtrVector
);
180 #endif // CC_BASE_SCOPED_PTR_VECTOR_H_