X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d1efca1a2ac2dd20d47d217ce2be1bcc506377e0..832e44d38a9c283ea1b03a76f80efb52519de21f:/src/common/strconv.cpp diff --git a/src/common/strconv.cpp b/src/common/strconv.cpp index fb2d4e0023..b4eaa65148 100644 --- a/src/common/strconv.cpp +++ b/src/common/strconv.cpp @@ -186,25 +186,55 @@ static size_t decode_utf16(const wchar_t* input, wxUint32& output) // wxMBConv // ---------------------------------------------------------------------------- +#define IGNORE_LIBC 0 + size_t wxMBConv::MB2WC(wchar_t *buf, const char *psz, size_t n) const { - return wxMB2WC(buf, psz, n)+1; +#if IGNORE_LIBC + if (buf) + { + for (size_t i = 0; i < strlen( psz )+1; i++) + buf[i] = (wchar_t) psz[i]; + // printf( "libc %s\n", buf ); + return strlen( psz ); + } + else + { + return strlen( psz ); + } +#else + return wxMB2WC(buf, psz, n); +#endif } size_t wxMBConv::WC2MB(char *buf, const wchar_t *psz, size_t n) const { - return wxWC2MB(buf, psz, n)+1; +#if IGNORE_LIBC + if (buf) + { + for (size_t i = 0; i < wxStrlen( psz )+1; i++) + buf[i] = (char) psz[i]; + // printf( "libc %s\n", buf ); + return wxStrlen( psz ); + } + else + { + return wxStrlen( psz ); + } +#else + return wxWC2MB(buf, psz, n); +#endif } const wxWCharBuffer wxMBConv::cMB2WC(const char *psz) const { if (psz) { - size_t nLen = MB2WC((wchar_t *) NULL, psz, 0); + size_t nLen = MB2WC((wchar_t *) NULL, psz, 0); // return value excludes /0 if (nLen == (size_t)-1) return wxWCharBuffer((wchar_t *) NULL); - wxWCharBuffer buf(nLen); - MB2WC((wchar_t *)(const wchar_t *) buf, psz, nLen); + wxWCharBuffer buf(nLen); // this allocates nLen1+ + MB2WC((wchar_t *)(const wchar_t *) buf, psz, nLen+1); return buf; } else @@ -215,34 +245,18 @@ const wxCharBuffer wxMBConv::cWC2MB(const wchar_t *psz) const { if (psz) { - size_t nLen = WC2MB((char *) NULL, psz, 0); + size_t nLen = WC2MB((char *) NULL, psz, 0); // return value excludes /0 if (nLen == (size_t)-1) return wxCharBuffer((char *) NULL); - wxCharBuffer buf(nLen); - WC2MB((char *)(const char *) buf, psz, nLen); + wxCharBuffer buf(nLen); // this allocates nLen+1 + WC2MB((char *)(const char *) buf, psz, nLen+1); + // printf( "str %s\n", (const char*) buf ); return buf; } else return wxCharBuffer((char *) NULL); } -// ---------------------------------------------------------------------------- -// standard file conversion -// ---------------------------------------------------------------------------- - -WXDLLEXPORT_DATA(wxMBConvFile) wxConvFile; - -// just use the libc conversion for now -size_t wxMBConvFile::MB2WC(wchar_t *buf, const char *psz, size_t n) const -{ - return wxMB2WC(buf, psz, n); -} - -size_t wxMBConvFile::WC2MB(char *buf, const wchar_t *psz, size_t n) const -{ - return wxWC2MB(buf, psz, n); -} - // ---------------------------------------------------------------------------- // standard gdk conversion // ---------------------------------------------------------------------------- @@ -425,6 +439,7 @@ size_t wxMBConvUTF8::WC2MB(char *buf, const wchar_t *psz, size_t n) const } if (buf && (len