]> git.saurik.com Git - wxWidgets.git/blobdiff - src/common/string.cpp
Apply patch that prevents a crash when more than
[wxWidgets.git] / src / common / string.cpp
index b4857f3b57fe3bdcecda123dc5f49ff48a2fc873..779beaee430cb125adcf14aed77aa052e3cfc7d5 100644 (file)
@@ -131,8 +131,12 @@ wxSTD istream& operator>>(wxSTD istream& is, wxString& WXUNUSED(str))
 
 wxSTD ostream& operator<<(wxSTD ostream& os, const wxString& str)
 {
-  os << str.c_str();
-  return os;
+#ifdef __BORLANDC__
+    os << str.mb_str();
+#else
+    os << str.c_str();
+#endif
+    return os;
 }
 
 #endif // wxUSE_STD_IOSTREAM
@@ -742,12 +746,9 @@ wxStringBase& wxStringBase::replace(size_t nStart, size_t nLen,
   //
   //Also, we can't use append with the full character pointer and must
   //do it manually because this string can contain null characters
-  if ( nStart != 0 )
-  {
-      for(size_t i1 = 0; i1 < nStart; ++i1)
-          strTmp.append(1, this->c_str()[i1]);
-  }
-  
+  for(size_t i1 = 0; i1 < nStart; ++i1)
+      strTmp.append(1, this->c_str()[i1]);
+
   //its safe to do the full version here because
   //sz must be a normal c string
   strTmp.append(sz);
@@ -1527,7 +1528,7 @@ wxString wxString::AfterFirst(wxChar ch) const
 }
 
 // replace first (or all) occurences of some substring with another one
-size_t wxString::Replace(const wxChar *szOld, 
+size_t wxString::Replace(const wxChar *szOld,
                   const wxChar *szNew, bool bReplaceAll)
 {
     // if we tried to replace an empty string we'd enter an infinite loop below
@@ -1541,27 +1542,27 @@ size_t wxString::Replace(const wxChar *szOld,
 
     size_t dwPos = 0;
 
-    while ( this->c_str()[dwPos] != wxT('\0') ) 
+    while ( this->c_str()[dwPos] != wxT('\0') )
     {
         //DO NOT USE STRSTR HERE
         //this string can contain embedded null characters,
         //so strstr will function incorrectly
         dwPos = find(szOld, dwPos);
-        if ( dwPos == npos ) 
+        if ( dwPos == npos )
             break;                  // exit the loop
-        else 
+        else
         {
             //replace this occurance of the old string with the new one
             replace(dwPos, uiOldLen, szNew, uiNewLen);
 
-            //move up pos past the old string
-            dwPos += uiOldLen;
+            //move up pos past the string that was replaced
+            dwPos += uiNewLen;
 
             //increase replace count
             ++uiCount;
-    
+
             // stop now?
-            if ( !bReplaceAll ) 
+            if ( !bReplaceAll )
                 break;                  // exit the loop
         }
     }
@@ -1842,8 +1843,14 @@ int wxString::PrintfV(const wxChar* pszFormat, va_list argptr)
         // in which case we need to break out
         if ( (len >= 0 && len <= size)
         // No EOVERFLOW on Windows nor Palm 6.0 nor OpenVMS nor MacOS (not X)
-       // not OS/2 (not Innotek libc).
-#if !defined(__WXMSW__) && !defined(__WXPALMOS__) && !defined( __VMS ) && !(defined(__WXMAC__) && !defined(__WXMAC_OSX__)) && !(defined(__EMX__) && !defined(__INNOTEK_LIBC__))
+        // not OS/2 (not Innotek libc).
+#if !defined(__WXMSW__)                              && \
+    !defined(__WXPALMOS__)                           && \
+    !defined(__OpenBSD__)                            && \
+    !defined(__DJGPP__)                              && \
+    !defined( __VMS )                                && \
+    !(defined(__WXMAC__) && !defined(__WXMAC_OSX__)) && \
+    !(defined(__EMX__) && !defined(__INNOTEK_LIBC__))
             || errno != EOVERFLOW
 #endif
             )