X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b21126db7a8232fa9e64b29f916d73d6b0153bef..d3fa4bc22e84e3ca4d88cc1772f2d414140a1017:/interface/wx/chartype.h
diff --git a/interface/wx/chartype.h b/interface/wx/chartype.h
index d9c3e9c895..f22f9d1345 100644
--- a/interface/wx/chartype.h
+++ b/interface/wx/chartype.h
@@ -3,7 +3,7 @@
// Purpose: interface of global functions
// Author: wxWidgets team
// RCS-ID: $Id$
-// Licence: wxWindows license
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
/** @addtogroup group_funcmacro_string */
@@ -15,16 +15,16 @@
builds of wxWidgets. This macro simply returns the value passed to it
without changes in ASCII build. In fact, its definition is:
-@code
-#ifdef UNICODE
-# define wxT(x) L##x
-#else // !Unicode
-# define wxT(x) x
-#endif
-@endcode
+ @code
+ #ifdef UNICODE
+ # define wxT(x) L##x
+ #else // !Unicode
+ # define wxT(x) x
+ #endif
+ @endcode
Note that since wxWidgets 2.9.0 you shouldn't use wxT() anymore in your
- program sources if you want to support Unicode.
+ program sources (it was previously required if you wanted to support Unicode).
@see @ref overview_unicode, wxS()
@@ -33,9 +33,38 @@
#define wxT(string)
/**
- wxS is macro which can be used with character and string literals (in other words,
- @c 'x' or @c "foo") to either convert them to wide characters or wide strings
- in @c wchar_t-based (UTF-16) builds or keep them unchanged in @c char-based
+ Compatibility macro which expands to wxT() in wxWidgets 2 only.
+
+ This macro can be used in code which needs to compile with both
+ wxWidgets 2 and 3 versions, in places where the wx2 API requires a Unicode string
+ (in Unicode build) but the wx3 API only accepts a standard narrow
+ string, as in e.g. wxCmdLineEntryDesc structure objects initializers.
+
+ Example of use:
+ @code
+ const wxCmdLineEntryDesc cmdLineDesc[] =
+ {
+ { wxCMD_LINE_SWITCH, wxT_2("q"), wxT_2("quiet"),
+ wxT_2("Don't output verbose messages") },
+ wxCMD_LINE_DESC_END
+ };
+ @endcode
+
+ Without @c wxT_2 the code above wouldn't compile with wxWidgets 2, but using @c
+ wxT instead, it wouldn't compile with wxWidgets 3.
+
+ @see wxT()
+
+ @since 2.8.12, 2.9.2
+
+ @header{wx/chartype.h}
+ */
+#define wxT_2(string)
+
+/**
+ wxS is a macro which can be used with character and string literals (in other words,
+ @c 'x' or @c "foo") to convert them either to wide characters or wide strings
+ in @c wchar_t-based (UTF-16) builds, or to keep them unchanged in @c char-based
(UTF-8) builds.
Basically this macro produces characters or strings of type wxStringCharType.
@@ -60,36 +89,41 @@
Don't confuse this macro with _()!
+ Note that since wxWidgets 2.9.0 the use of _T() is discouraged just like
+ for wxT() and also that this macro may conflict with identifiers defined in
+ standard headers of some compilers (such as Sun CC) so its use should
+ really be avoided.
+
@header{wx/chartype.h}
*/
#define _T(string)
/**
wxChar is defined to be
- - @c char when wxUSE_UNICODE==0
- - @c wchar_t when wxUSE_UNICODE==1 (the default).
+ \- @c char when wxUSE_UNICODE==0
+ \- @c wchar_t when wxUSE_UNICODE==1 (the default).
*/
typedef wxUSE_UNICODE_dependent wxChar;
/**
wxSChar is defined to be
- - signed char when wxUSE_UNICODE==0
- - @c wchar_t when wxUSE_UNICODE==1 (the default).
+ \- signed char when wxUSE_UNICODE==0
+ \- @c wchar_t when wxUSE_UNICODE==1 (the default).
*/
typedef wxUSE_UNICODE_dependent wxSChar;
/**
wxUChar is defined to be
- - unsigned char when wxUSE_UNICODE==0
- - @c wchar_t when wxUSE_UNICODE==1 (the default).
+ \- unsigned char when wxUSE_UNICODE==0
+ \- @c wchar_t when wxUSE_UNICODE==1 (the default).
*/
typedef wxUSE_UNICODE_dependent wxUChar;
/**
wxStringCharType is defined to be:
- - @c char when wxUSE_UNICODE==0
- - @c char when wxUSE_UNICODE_WCHAR==0 and wxUSE_UNICODE==1
- - @c wchar_t when wxUSE_UNICODE_WCHAR==1 and wxUSE_UNICODE==1
+ \- @c char when wxUSE_UNICODE==0
+ \- @c char when wxUSE_UNICODE_WCHAR==0 and wxUSE_UNICODE==1
+ \- @c wchar_t when wxUSE_UNICODE_WCHAR==1 and wxUSE_UNICODE==1
The @c wxUSE_UNICODE_WCHAR symbol is defined to @c 1 when building on
Windows while it's defined to @c 0 when building on Unix, Linux or OS X.