// Copyright (c) 2012 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_MEMORY_SCOPED_VECTOR_H_ #define BASE_MEMORY_SCOPED_VECTOR_H_ #pragma once #include #include "base/basictypes.h" #include "base/move.h" #include "base/stl_util.h" // ScopedVector wraps a vector deleting the elements from its // destructor. template class ScopedVector { MOVE_ONLY_TYPE_FOR_CPP_03(ScopedVector, RValue) public: typedef typename std::vector::iterator iterator; typedef typename std::vector::const_iterator const_iterator; typedef typename std::vector::reverse_iterator reverse_iterator; typedef typename std::vector::const_reverse_iterator const_reverse_iterator; ScopedVector() {} ~ScopedVector() { reset(); } ScopedVector(RValue& other) { swap(other); } ScopedVector& operator=(RValue& rhs) { swap(rhs); return *this; } std::vector* operator->() { return &v; } const std::vector* operator->() const { return &v; } T*& operator[](size_t i) { return v[i]; } const T* operator[](size_t i) const { return v[i]; } bool empty() const { return v.empty(); } size_t size() const { return v.size(); } reverse_iterator rbegin() { return v.rbegin(); } const_reverse_iterator rbegin() const { return v.rbegin(); } reverse_iterator rend() { return v.rend(); } const_reverse_iterator rend() const { return v.rend(); } iterator begin() { return v.begin(); } const_iterator begin() const { return v.begin(); } iterator end() { return v.end(); } const_iterator end() const { return v.end(); } void push_back(T* elem) { v.push_back(elem); } std::vector& get() { return v; } const std::vector& get() const { return v; } void swap(ScopedVector& other) { v.swap(other.v); } void release(std::vector* out) { out->swap(v); v.clear(); } void reset() { STLDeleteElements(&v); } void reserve(size_t capacity) { v.reserve(capacity); } void resize(size_t new_size) { v.resize(new_size); } // Lets the ScopedVector take ownership of |x|. iterator insert(iterator position, T* x) { return v.insert(position, x); } // Lets the ScopedVector take ownership of elements in [first,last). template void insert(iterator position, InputIterator first, InputIterator last) { v.insert(position, first, last); } iterator erase(iterator position) { delete *position; return v.erase(position); } iterator erase(iterator first, iterator last) { STLDeleteContainerPointers(first, last); return v.erase(first, last); } // Like |erase()|, but doesn't delete the element at |position|. iterator weak_erase(iterator position) { return v.erase(position); } // Like |erase()|, but doesn't delete the elements in [first, last). iterator weak_erase(iterator first, iterator last) { return v.erase(first, last); } private: std::vector v; }; #endif // BASE_MEMORY_SCOPED_VECTOR_H_