X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/851630e4f39057d8679720da44678e622659d9a1..9b4aede26d327d24d9a5d2ee4675b24ecde75cf5:/include/wx/buffer.h diff --git a/include/wx/buffer.h b/include/wx/buffer.h index dea159f833..9f9eb174b7 100644 --- a/include/wx/buffer.h +++ b/include/wx/buffer.h @@ -15,15 +15,8 @@ #define _WX_BUFFER_H #include "wx/wxchar.h" -#include // strdup -#ifdef HAVE_WCSTR_H -#include -#elif defined( HAVE_WCHAR_H ) -#include // wchar_t -#else -#pragma error "Don't know what to do!" -#endif +#include // strdup // ---------------------------------------------------------------------------- // Special classes for (wide) character strings: they use malloc/free instead @@ -35,14 +28,14 @@ class wxCharBuffer public: wxCharBuffer(const char *str) { - wxASSERT_MSG( str, _T("NULL string in wxCharBuffer") ); + wxASSERT_MSG( str, wxT("NULL string in wxCharBuffer") ); m_str = str ? strdup(str) : (char *)NULL; } wxCharBuffer(size_t len) { m_str = (char *)malloc(len+1); - m_str[len] = '\0'; + m_str[len] = '\0'; } // no need to check for NULL, free() does it ~wxCharBuffer() { free(m_str); } @@ -62,20 +55,22 @@ public: } operator const char *() const { return m_str; } + char operator[](size_t n) const { return m_str[n]; } private: char *m_str; }; +#if wxUSE_WCHAR_T class wxWCharBuffer { public: wxWCharBuffer(const wchar_t *wcs) { - wxASSERT_MSG( wcs, _T("NULL string in wxWCharBuffer") ); + wxASSERT_MSG( wcs, wxT("NULL string in wxWCharBuffer") ); if (wcs) { - size_t siz = (wcslen(wcs)+1)*sizeof(wchar_t); + size_t siz = (::wcslen(wcs)+1)*sizeof(wchar_t); m_wcs = (wchar_t *)malloc(siz); memcpy(m_wcs, wcs, siz); } @@ -84,7 +79,7 @@ public: wxWCharBuffer(size_t len) { m_wcs = (wchar_t *)malloc((len+1)*sizeof(wchar_t)); - m_wcs[len] = L'\0'; + m_wcs[len] = L'\0'; } // no need to check for NULL, free() does it @@ -105,22 +100,24 @@ public: } operator const wchar_t *() const { return m_wcs; } + wchar_t operator[](size_t n) const { return m_wcs[n]; } private: wchar_t *m_wcs; }; +#endif #if wxUSE_UNICODE -#define wxMB2WXbuf wxWCharBuffer -#define wxWX2MBbuf wxCharBuffer -#define wxWC2WXbuf wxChar* -#define wxWX2WCbuf wxChar* -#else -#define wxMB2WXbuf wxChar* -#define wxWX2MBbuf wxChar* -#define wxWC2WXbuf wxCharBuffer -#define wxWX2WCbuf wxWCharBuffer -#endif + #define wxMB2WXbuf wxWCharBuffer + #define wxWX2MBbuf wxCharBuffer + #define wxWC2WXbuf wxChar* + #define wxWX2WCbuf wxChar* +#else // ANSI + #define wxMB2WXbuf wxChar* + #define wxWX2MBbuf wxChar* + #define wxWC2WXbuf wxCharBuffer + #define wxWX2WCbuf wxWCharBuffer +#endif // Unicode/ANSI // ---------------------------------------------------------------------------- // template class for any kind of data