X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2415cf6725d5cfb11f52d29e5d28dfdaa197b366..ad653fa23069c5d9378247084f03c9a718c3ad62:/src/common/wxcrt.cpp diff --git a/src/common/wxcrt.cpp b/src/common/wxcrt.cpp index de9012b6d5..b9f4ef3c07 100644 --- a/src/common/wxcrt.cpp +++ b/src/common/wxcrt.cpp @@ -584,11 +584,11 @@ int ConvertStringToBuf(const wxString& s, char *out, size_t outsize) const size_t len = buf.length(); if ( outsize > len ) { - memcpy(out, buf, (len+1) * sizeof(char)); + memcpy(out, buf, len+1); } else // not enough space { - memcpy(out, buf, (outsize-1) * sizeof(char)); + memcpy(out, buf, outsize-1); out[outsize-1] = '\0'; } @@ -834,7 +834,8 @@ wxChar32* wxStrdup(const wxChar32* s) { size_t size = (wxStrlen(s) + 1) * sizeof(wxChar32); wxChar32 *ret = (wxChar32*) malloc(size); - memcpy(ret, s, size); + if ( ret ) + memcpy(ret, s, size); return ret; } #endif @@ -975,23 +976,35 @@ wxCRT_StrtoullBase(const T* nptr, T** endptr, int base, T* sign) } } - // Starts with 0x? + // Starts with octal or hexadecimal prefix? if ( i != end && *i == wxT('0') ) { ++i; if ( i != end ) { - if ( *i == wxT('x') && (base == 16 || base == 0) ) + if ( (*i == wxT('x')) || (*i == wxT('X')) ) { - base = 16; - ++i; + // Hexadecimal prefix: use base 16 if auto-detecting. + if ( base == 0 ) + base = 16; + + // If we do use base 16, just skip "x" as well. + if ( base == 16 ) + { + ++i; + } + else // Not using base 16 + { + // Then it's an error. + if ( endptr ) + *endptr = (T*) nptr; + wxSET_ERRNO(EINVAL); + return sum; + } } - else + else if ( base == 0 ) { - if ( endptr ) - *endptr = (T*) nptr; - wxSET_ERRNO(EINVAL); - return sum; + base = 8; } } else