X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7a3e402c11cee61059e515e8a82d52fe285e69b7..dcd307ee1f13834bdfe43a0964db657bcd860142:/include/wx/buffer.h diff --git a/include/wx/buffer.h b/include/wx/buffer.h index 67d23526d6..b91a6cfc78 100644 --- a/include/wx/buffer.h +++ b/include/wx/buffer.h @@ -15,6 +15,7 @@ #define _WX_BUFFER_H #include "wx/wxchar.h" + #include // strdup // ---------------------------------------------------------------------------- @@ -27,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); } @@ -54,6 +55,7 @@ public: } operator const char *() const { return m_str; } + char operator[](size_t n) const { return m_str[n]; } private: char *m_str; @@ -65,7 +67,7 @@ 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); @@ -77,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 @@ -98,6 +100,7 @@ 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; @@ -105,16 +108,16 @@ private: #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