X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/64f8f94ca0797f2d4a0c7daf34500ccc23c7d83e..931483d799fcac4a442b123d32b14282ee17dc8d:/src/common/string.cpp diff --git a/src/common/string.cpp b/src/common/string.cpp index 8f20b9ac13..4551c66931 100644 --- a/src/common/string.cpp +++ b/src/common/string.cpp @@ -35,7 +35,11 @@ #endif #include -#include + +#ifndef __WXWINCE__ + #include +#endif + #include #include @@ -1604,7 +1608,7 @@ wxString& wxString::Trim(bool bFromRight) reverse_iterator psz = rbegin(); while ( (psz != rend()) && wxSafeIsspace(*psz) ) psz++; - + // truncate at trailing space start erase(psz.base(), end()); } @@ -1677,23 +1681,36 @@ int wxString::Find(const wxChar *pszSub) const // the implementation of all the functions below is exactly the same so factor // it out + +#ifdef __WATCOMC__ + #define STR2INTLINK _WCRTLINK +#else + #define STR2INTLINK +#endif + template bool wxStringToIntType(const wxChar *start, T *val, int base, - T (*func)(const wxChar *, wxChar **, int)) + T STR2INTLINK (*func)(const wxChar *, wxChar **, int)) { wxCHECK_MSG( val, false, _T("NULL output pointer") ); wxASSERT_MSG( !base || (base > 1 && base <= 36), _T("invalid base") ); +#ifndef __WXWINCE__ errno = 0; +#endif wxChar *end; *val = (*func)(start, &end, base); // return true only if scan was stopped by the terminating NUL and if the // string was not empty to start with and no under/overflow occurred - return !*end && (end != start) && (errno != ERANGE); + return !*end && (end != start) +#ifndef __WXWINCE__ + && (errno != ERANGE) +#endif + ; } bool wxString::ToLong(long *val, int base) const @@ -1712,6 +1729,8 @@ bool wxString::ToLongLong(wxLongLong_t *val, int base) const return wxStringToIntType(c_str(), val, base, wxStrtoll); #else // TODO: implement this ourselves + wxUnusedVar(val); + wxUnusedVar(base); return false; #endif // wxHAS_STRTOLL } @@ -1722,6 +1741,8 @@ bool wxString::ToULongLong(wxULongLong_t *val, int base) const return wxStringToIntType(c_str(), val, base, wxStrtoull); #else // TODO: implement this ourselves + wxUnusedVar(val); + wxUnusedVar(base); return false; #endif } @@ -1730,7 +1751,9 @@ bool wxString::ToDouble(double *val) const { wxCHECK_MSG( val, false, _T("NULL pointer in wxString::ToDouble") ); +#ifndef __WXWINCE__ errno = 0; +#endif const wxChar *start = c_str(); wxChar *end; @@ -1738,7 +1761,11 @@ bool wxString::ToDouble(double *val) const // return true only if scan was stopped by the terminating NUL and if the // string was not empty to start with and no under/overflow occurred - return !*end && (end != start) && (errno != ERANGE); + return !*end && (end != start) +#ifndef __WXWINCE__ + && (errno != ERANGE) +#endif + ; } // ---------------------------------------------------------------------------