wxVector() : m_size(0), m_capacity(0), m_values(NULL) {}
wxVector(size_type size)
- : m_size(0), m_capacity(0), m_values(NULL)
+ : m_size(0), m_capacity(0), m_values(NULL)
{
reserve(size);
for ( size_t n = 0; n < size; n++ )
}
wxVector(size_type size, const value_type& v)
- : m_size(0), m_capacity(0), m_values(NULL)
+ : m_size(0), m_capacity(0), m_values(NULL)
{
reserve(size);
for ( size_t n = 0; n < size; n++ )
m_capacity = n;
}
+ void resize(size_type n)
+ {
+ if ( n < m_size )
+ Shrink(n);
+ else if ( n > m_size )
+ Extend(n, value_type());
+ }
+
+ void resize(size_type n, const value_type& v)
+ {
+ if ( n < m_size )
+ Shrink(n);
+ else if ( n > m_size )
+ Extend(n, v);
+ }
+
size_type size() const
{
return m_size;
}
private:
+ void Shrink(size_type n)
+ {
+ for ( size_type i = n; i < m_size; i++ )
+ m_values[i].~T();
+ m_size = n;
+ }
+
+ void Extend(size_type n, const value_type& v)
+ {
+ reserve(n);
+ for ( size_type i = m_size; i < n; i++ )
+ push_back(v);
+ }
+
size_type m_size,
m_capacity;
value_type *m_values;
Return reverse iterator to end of the vector.
*/
reverse_iterator rbegin();
-
+
/**
Return reverse iterator to beginning of the vector.
*/
*/
void reserve(size_type n);
+ /**
+ Makes the vector of size @a n.
+
+ If @a n is less than the current size(), the elements at the end of the
+ vector are erased. If it is greater, then the vector is completed with
+ either the copies of the given object @a v or @c value_type() objects
+ until it becomes of size @a n.
+ */
+ //@{
+ void resize(size_type n);
+ void resize(size_type n, const value_type& v);
+ //@}
+
/**
Returns the size of the vector.
*/
CPPUNIT_TEST( Iterators );
CPPUNIT_TEST( Objects );
CPPUNIT_TEST( NonPODs );
+ CPPUNIT_TEST( Resize );
CPPUNIT_TEST_SUITE_END();
void PushPopTest();
void Iterators();
void Objects();
void NonPODs();
+ void Resize();
DECLARE_NO_COPY_CLASS(VectorsTestCase)
};
vs.erase(vs.begin());
vs.clear();
}
+
+void VectorsTestCase::Resize()
+{
+ wxVector<CountedObject> v;
+ v.resize(3);
+
+ CPPUNIT_ASSERT_EQUAL( 3, v.size() );
+ CPPUNIT_ASSERT_EQUAL( 3, CountedObject::GetCount() );
+ CPPUNIT_ASSERT_EQUAL( 0, v[0].GetValue() );
+ CPPUNIT_ASSERT_EQUAL( 0, v[1].GetValue() );
+ CPPUNIT_ASSERT_EQUAL( 0, v[2].GetValue() );
+
+ v.resize(1);
+ CPPUNIT_ASSERT_EQUAL( 1, v.size() );
+ CPPUNIT_ASSERT_EQUAL( 1, CountedObject::GetCount() );
+
+ v.resize(4, CountedObject(17));
+ CPPUNIT_ASSERT_EQUAL( 4, v.size() );
+ CPPUNIT_ASSERT_EQUAL( 4, CountedObject::GetCount() );
+ CPPUNIT_ASSERT_EQUAL( 0, v[0].GetValue() );
+ CPPUNIT_ASSERT_EQUAL( 17, v[1].GetValue() );
+ CPPUNIT_ASSERT_EQUAL( 17, v[2].GetValue() );
+ CPPUNIT_ASSERT_EQUAL( 17, v[3].GetValue() );
+}
+