added wxString::rbegin() and rend()
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@38742 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -70,6 +70,7 @@ All:
|
|||||||
versions in order to eliminate compiler errors.
|
versions in order to eliminate compiler errors.
|
||||||
- Fixed bug where wxDateTime::Now() would sometimes return an incorrect value
|
- Fixed bug where wxDateTime::Now() would sometimes return an incorrect value
|
||||||
the first time it was called.
|
the first time it was called.
|
||||||
|
- Added wxString::rbegin() and rend()
|
||||||
|
|
||||||
|
|
||||||
All (GUI):
|
All (GUI):
|
||||||
|
@@ -299,6 +299,44 @@ public:
|
|||||||
typedef value_type *iterator;
|
typedef value_type *iterator;
|
||||||
typedef const value_type *const_iterator;
|
typedef const value_type *const_iterator;
|
||||||
|
|
||||||
|
#define wxSTRING_REVERSE_ITERATOR(name, const_or_not) \
|
||||||
|
class name \
|
||||||
|
{ \
|
||||||
|
public: \
|
||||||
|
typedef wxChar value_type; \
|
||||||
|
typedef const_or_not value_type& reference; \
|
||||||
|
typedef const_or_not value_type *pointer; \
|
||||||
|
typedef const_or_not value_type *iterator_type; \
|
||||||
|
\
|
||||||
|
name(iterator_type i) : m_cur(i) { } \
|
||||||
|
name(const name& ri) : m_cur(ri.m_cur) { } \
|
||||||
|
\
|
||||||
|
iterator_type base() const { return m_cur; } \
|
||||||
|
\
|
||||||
|
reference operator*() const { return *(m_cur - 1); } \
|
||||||
|
pointer operator->() const { return m_cur - 1; } \
|
||||||
|
\
|
||||||
|
name& operator++() { --m_cur; return *this; } \
|
||||||
|
name operator++(int) { name tmp = *this; --m_cur; return tmp; } \
|
||||||
|
name& operator--() { ++m_cur; return *this; } \
|
||||||
|
name operator--(int) { name tmp = *this; ++m_cur; return tmp; } \
|
||||||
|
\
|
||||||
|
bool operator==(name ri) const { return m_cur == ri.m_cur; } \
|
||||||
|
bool operator!=(name ri) const { return !(*this == ri); } \
|
||||||
|
\
|
||||||
|
private: \
|
||||||
|
iterator_type m_cur; \
|
||||||
|
}
|
||||||
|
|
||||||
|
wxSTRING_REVERSE_ITERATOR(const_reverse_iterator, const);
|
||||||
|
|
||||||
|
#define wxSTRING_CONST
|
||||||
|
wxSTRING_REVERSE_ITERATOR(reverse_iterator, wxSTRING_CONST);
|
||||||
|
#undef wxSTRING_CONST
|
||||||
|
|
||||||
|
#undef wxSTRING_REVERSE_ITERATOR
|
||||||
|
|
||||||
|
|
||||||
// constructors and destructor
|
// constructors and destructor
|
||||||
// ctor for an empty string
|
// ctor for an empty string
|
||||||
wxStringBase() { Init(); }
|
wxStringBase() { Init(); }
|
||||||
@@ -431,14 +469,18 @@ public:
|
|||||||
|
|
||||||
// first valid index position
|
// first valid index position
|
||||||
const_iterator begin() const { return m_pchData; }
|
const_iterator begin() const { return m_pchData; }
|
||||||
// position one after the last valid one
|
|
||||||
const_iterator end() const { return m_pchData + length(); }
|
|
||||||
|
|
||||||
// first valid index position
|
|
||||||
iterator begin();
|
iterator begin();
|
||||||
// position one after the last valid one
|
// position one after the last valid one
|
||||||
|
const_iterator end() const { return m_pchData + length(); }
|
||||||
iterator end();
|
iterator end();
|
||||||
|
|
||||||
|
// first element of the reversed string
|
||||||
|
const_reverse_iterator rbegin() const { return const_reverse_iterator(end()); }
|
||||||
|
reverse_iterator rbegin() { return reverse_iterator(end()); }
|
||||||
|
// one beyond the end of the reversed string
|
||||||
|
const_reverse_iterator rend() const { return const_reverse_iterator(begin()); }
|
||||||
|
reverse_iterator rend() { return reverse_iterator(begin()); }
|
||||||
|
|
||||||
// insert another string
|
// insert another string
|
||||||
wxStringBase& insert(size_t nPos, const wxStringBase& str)
|
wxStringBase& insert(size_t nPos, const wxStringBase& str)
|
||||||
{
|
{
|
||||||
|
@@ -44,6 +44,7 @@ private:
|
|||||||
CPPUNIT_TEST( StdReplace );
|
CPPUNIT_TEST( StdReplace );
|
||||||
CPPUNIT_TEST( StdRFind );
|
CPPUNIT_TEST( StdRFind );
|
||||||
CPPUNIT_TEST( StdResize );
|
CPPUNIT_TEST( StdResize );
|
||||||
|
CPPUNIT_TEST( StdRiter );
|
||||||
CPPUNIT_TEST( StdSubstr );
|
CPPUNIT_TEST( StdSubstr );
|
||||||
CPPUNIT_TEST_SUITE_END();
|
CPPUNIT_TEST_SUITE_END();
|
||||||
|
|
||||||
@@ -59,6 +60,7 @@ private:
|
|||||||
void StdReplace();
|
void StdReplace();
|
||||||
void StdRFind();
|
void StdRFind();
|
||||||
void StdResize();
|
void StdResize();
|
||||||
|
void StdRiter();
|
||||||
void StdSubstr();
|
void StdSubstr();
|
||||||
|
|
||||||
DECLARE_NO_COPY_CLASS(StdStringTestCase)
|
DECLARE_NO_COPY_CLASS(StdStringTestCase)
|
||||||
@@ -444,6 +446,26 @@ void StdStringTestCase::StdResize()
|
|||||||
CPPUNIT_ASSERT( s4 == _T("abcABCdefDEFWW") );
|
CPPUNIT_ASSERT( s4 == _T("abcABCdefDEFWW") );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void StdStringTestCase::StdRiter()
|
||||||
|
{
|
||||||
|
const wxString s(_T("fozbar"));
|
||||||
|
|
||||||
|
wxString::const_reverse_iterator ri(s.rbegin());
|
||||||
|
CPPUNIT_ASSERT_EQUAL( _T('r'), *ri );
|
||||||
|
CPPUNIT_ASSERT_EQUAL( _T('a'), *++ri );
|
||||||
|
CPPUNIT_ASSERT_EQUAL( _T('r'), *--ri );
|
||||||
|
|
||||||
|
ri = s.rend();
|
||||||
|
ri--;
|
||||||
|
CPPUNIT_ASSERT_EQUAL( _T('f'), *ri );
|
||||||
|
|
||||||
|
--ri;
|
||||||
|
CPPUNIT_ASSERT_EQUAL( _T('o'), *ri );
|
||||||
|
|
||||||
|
wxString::const_iterator i = ri.base();
|
||||||
|
CPPUNIT_ASSERT_EQUAL( _T('z'), *i );
|
||||||
|
}
|
||||||
|
|
||||||
void StdStringTestCase::StdSubstr()
|
void StdStringTestCase::StdSubstr()
|
||||||
{
|
{
|
||||||
wxString s1 = _T("abcdefgABCDEFG");
|
wxString s1 = _T("abcdefgABCDEFG");
|
||||||
@@ -453,11 +475,6 @@ void StdStringTestCase::StdSubstr()
|
|||||||
CPPUNIT_ASSERT( s1.substr( 1, 20 ) == _T("bcdefgABCDEFG") );
|
CPPUNIT_ASSERT( s1.substr( 1, 20 ) == _T("bcdefgABCDEFG") );
|
||||||
CPPUNIT_ASSERT( s1.substr( 14, 30 ) == _T("") );
|
CPPUNIT_ASSERT( s1.substr( 14, 30 ) == _T("") );
|
||||||
|
|
||||||
|
|
||||||
// 1
|
|
||||||
// 012 34567 89012 3456
|
|
||||||
// wxString s1 = _T("abc\0defg\0ABCD\0EFG");
|
|
||||||
|
|
||||||
s1.insert(3,1,'\0');
|
s1.insert(3,1,'\0');
|
||||||
s1.insert(8,1,'\0');
|
s1.insert(8,1,'\0');
|
||||||
s1.insert(13,1,'\0');
|
s1.insert(13,1,'\0');
|
||||||
|
Reference in New Issue
Block a user