From: Vadim Zeitlin Date: Sat, 12 Apr 2008 17:10:28 +0000 (+0000) Subject: don't stop on NULs in Replace() X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/394b2900ffb066b20f3a06482b470521e3b876fe don't stop on NULs in Replace() git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@53144 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/src/common/string.cpp b/src/common/string.cpp index 6b65824622..a287759822 100644 --- a/src/common/string.cpp +++ b/src/common/string.cpp @@ -1239,31 +1239,24 @@ size_t wxString::Replace(const wxString& strOld, size_t uiOldLen = strOld.length(); size_t uiNewLen = strNew.length(); - size_t dwPos = 0; - - while ( (*this)[dwPos] != wxT('\0') ) + for ( size_t dwPos = 0; dwPos < length(); ) { - //DO NOT USE STRSTR HERE - //this string can contain embedded null characters, - //so strstr will function incorrectly dwPos = find(strOld, dwPos); if ( dwPos == npos ) - break; // exit the loop - else - { - //replace this occurance of the old string with the new one - replace(dwPos, uiOldLen, strNew, uiNewLen); + break; - //move up pos past the string that was replaced - dwPos += uiNewLen; + // replace this occurance of the old string with the new one + replace(dwPos, uiOldLen, strNew, uiNewLen); - //increase replace count - ++uiCount; + // move up pos past the string that was replaced + dwPos += uiNewLen; - // stop now? - if ( !bReplaceAll ) - break; // exit the loop - } + // increase replace count + ++uiCount; + + // stop after the first one? + if ( !bReplaceAll ) + break; } return uiCount;