From: Mattia Barbon Date: Thu, 28 Aug 2003 20:32:06 +0000 (+0000) Subject: wxString::rfind fixed for wxUSE_STL=0 from Robert Vazan. X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/93c83507aaee06567f754b976fbc16b813a30b9c?ds=sidebyside wxString::rfind fixed for wxUSE_STL=0 from Robert Vazan. Added missing wxArrayString::reserve. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@23287 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/src/common/string.cpp b/src/common/string.cpp index 2bd4e6178f..4715f63154 100644 --- a/src/common/string.cpp +++ b/src/common/string.cpp @@ -509,13 +509,15 @@ size_t wxStringBase::rfind(wxChar ch, size_t nStart) const wxASSERT( nStart <= length() ); } - const wxChar *p = wxStrrchr(c_str(), ch); - - if ( p == NULL ) - return npos; + const wxChar *actual; + for ( actual = c_str() + ( nStart == npos ? length() : nStart + 1 ); + actual > c_str(); --actual ) + { + if ( *(actual - 1) == ch ) + return (actual - 1) - c_str(); + } - size_t result = p - c_str(); - return ( result > nStart ) ? npos : result; + return npos; } size_t wxStringBase::find_first_of(const wxChar* sz, size_t nStart) const @@ -1961,6 +1963,11 @@ wxArrayString::~wxArrayString() wxDELETEA(m_pItems); } +void wxArrayString::reserve(size_t nSize) +{ + Alloc(nSize); +} + // pre-allocates memory (frees the previous data!) void wxArrayString::Alloc(size_t nSize) {