X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/394b2900ffb066b20f3a06482b470521e3b876fe..ac66fda2c7c7fff024489594487f047383382071:/src/common/string.cpp?ds=sidebyside diff --git a/src/common/string.cpp b/src/common/string.cpp index a287759822..c3bc9331cb 100644 --- a/src/common/string.cpp +++ b/src/common/string.cpp @@ -369,6 +369,9 @@ wxString::SubstrBufFromMB wxString::ConvertStr(const char *psz, size_t nLength, // UTF-8 sequence and psz may be invalid: if ( wxStringOperations::IsValidUtf8String(psz, nLength) ) { + // we must pass the real string length to SubstrBufFromMB ctor + if ( nLength == npos ) + nLength = psz ? strlen(psz) : 0; return SubstrBufFromMB(wxCharBuffer::CreateNonOwned(psz), nLength); } // else: do the roundtrip through wchar_t* @@ -1236,17 +1239,17 @@ size_t wxString::Replace(const wxString& strOld, size_t uiCount = 0; // count of replacements made - size_t uiOldLen = strOld.length(); - size_t uiNewLen = strNew.length(); + const size_t uiOldLen = strOld.m_impl.length(); + const size_t uiNewLen = strNew.m_impl.length(); - for ( size_t dwPos = 0; dwPos < length(); ) + for ( size_t dwPos = 0; dwPos < m_impl.length(); ) { - dwPos = find(strOld, dwPos); + dwPos = m_impl.find(strOld.m_impl, dwPos); if ( dwPos == npos ) break; // replace this occurance of the old string with the new one - replace(dwPos, uiOldLen, strNew, uiNewLen); + m_impl.replace(dwPos, uiOldLen, strNew.m_impl); // move up pos past the string that was replaced dwPos += uiNewLen;