X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/af49c4b8a2d3553e733e71c7dd3911881f4c1a2a..408ac1b8cf965067dbc0c36beabac0c8a5769501:/include/wx/strconv.h diff --git a/include/wx/strconv.h b/include/wx/strconv.h index 60aef2c1dd..dd127751dd 100644 --- a/include/wx/strconv.h +++ b/include/wx/strconv.h @@ -6,7 +6,7 @@ // Created: 29/01/98 // RCS-ID: $Id$ // Copyright: (c) 1998 Ove Kaaven, Robert Roebling, Vadim Zeitlin -// Licence: wxWindows license +// Licence: wxWindows licence /////////////////////////////////////////////////////////////////////////////// #ifndef _WX_WXSTRCONVH__ @@ -20,6 +20,10 @@ #include "wx/wxchar.h" #include "wx/buffer.h" +#ifdef __DIGITALMARS__ +#include "typeinfo.h" +#endif + #if defined(__VISAGECPP__) && __IBMCPP__ >= 400 # undef __BSEXCPT__ #endif @@ -32,7 +36,7 @@ // wxMBConv (base class for conversions, using libc conversion itself) // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxMBConv +class WXDLLIMPEXP_BASE wxMBConv { public: // the actual conversion takes place here @@ -54,60 +58,46 @@ public: const wxCharBuffer cWC2WX(const wchar_t *psz) const { return cWC2MB(psz); } const wxWCharBuffer cWX2WC(const char *psz) const { return cMB2WC(psz); } #endif // Unicode/ANSI + + // virtual dtor for any base class + virtual ~wxMBConv(); }; -WXDLLEXPORT_DATA(extern wxMBConv) wxConvLibc; +WXDLLIMPEXP_DATA_BASE(extern wxMBConv) wxConvLibc; // ---------------------------------------------------------------------------- // wxMBConvUTF7 (for conversion using UTF7 encoding) // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxMBConvUTF7 : public wxMBConv +class WXDLLIMPEXP_BASE wxMBConvUTF7 : public wxMBConv { public: virtual size_t MB2WC(wchar_t *buf, const char *psz, size_t n) const; virtual size_t WC2MB(char *buf, const wchar_t *psz, size_t n) const; }; -WXDLLEXPORT_DATA(extern wxMBConvUTF7) wxConvUTF7; +WXDLLIMPEXP_DATA_BASE(extern wxMBConvUTF7) wxConvUTF7; // ---------------------------------------------------------------------------- // wxMBConvUTF8 (for conversion using UTF8 encoding) // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxMBConvUTF8 : public wxMBConv -{ -public: - virtual size_t MB2WC(wchar_t *buf, const char *psz, size_t n) const; - virtual size_t WC2MB(char *buf, const wchar_t *psz, size_t n) const; -}; - -WXDLLEXPORT_DATA(extern wxMBConvUTF8) wxConvUTF8; - -#ifdef __WXGTK12__ - -// ---------------------------------------------------------------------------- -// wxMBConvUTF8 (for conversion using GDK's internal converions) -// ---------------------------------------------------------------------------- - -class WXDLLEXPORT wxMBConvGdk : public wxMBConv +class WXDLLIMPEXP_BASE wxMBConvUTF8 : public wxMBConv { public: virtual size_t MB2WC(wchar_t *buf, const char *psz, size_t n) const; virtual size_t WC2MB(char *buf, const wchar_t *psz, size_t n) const; }; -WXDLLEXPORT_DATA(extern wxMBConvGdk) wxConvGdk; - -#endif // wxGTK 1.2 +WXDLLIMPEXP_DATA_BASE(extern wxMBConvUTF8) wxConvUTF8; // ---------------------------------------------------------------------------- // wxCSConv (for conversion based on loadable char sets) // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxCharacterSet; +class WXDLLIMPEXP_BASE wxCharacterSet; -class WXDLLEXPORT wxCSConv : public wxMBConv +class WXDLLIMPEXP_BASE wxCSConv : public wxMBConv { public: wxCSConv(const wxChar *charset); @@ -115,7 +105,7 @@ public: virtual ~wxCSConv(); wxCSConv& operator=(const wxCSConv& conv); - + void LoadNow(); virtual size_t MB2WC(wchar_t *buf, const char *psz, size_t n) const; @@ -134,15 +124,16 @@ private: }; #define wxConvFile wxConvLocal -WXDLLEXPORT_DATA(extern wxCSConv) wxConvLocal; -WXDLLEXPORT_DATA(extern wxMBConv *) wxConvCurrent; +WXDLLIMPEXP_DATA_BASE(extern wxCSConv) wxConvLocal; +WXDLLIMPEXP_DATA_BASE(extern wxCSConv) wxConvISO8859_1; +WXDLLIMPEXP_DATA_BASE(extern wxMBConv *) wxConvCurrent; // ---------------------------------------------------------------------------- // filename conversion macros // ---------------------------------------------------------------------------- // filenames are multibyte on Unix and probably widechar on Windows? -#if defined(__UNIX__) || defined(__BORLANDC__) +#if defined(__UNIX__) || defined(__BORLANDC__) || defined(__WXMAC__ ) #define wxMBFILES 1 #else #define wxMBFILES 0 @@ -163,15 +154,15 @@ WXDLLEXPORT_DATA(extern wxMBConv *) wxConvCurrent; // stand-ins in absence of wchar_t // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxMBConv +class WXDLLIMPEXP_BASE wxMBConv { public: const char* cMB2WX(const char *psz) const { return psz; } const char* cWX2MB(const char *psz) const { return psz; } }; -WXDLLEXPORT_DATA(extern wxMBConv) wxConvLibc, wxConvFile; -WXDLLEXPORT_DATA(extern wxMBConv *) wxConvCurrent; +WXDLLIMPEXP_DATA_BASE(extern wxMBConv) wxConvLibc, wxConvFile, wxConvLocal, wxConvISO8859_1, wxConvUTF8; +WXDLLIMPEXP_DATA_BASE(extern wxMBConv *) wxConvCurrent; #define wxFNCONV(name) name #define wxFNSTRINGCAST WXSTRINGCAST