]>
git.saurik.com Git - wxWidgets.git/blob - include/wx/intl.h
1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: Internationalization and localisation for wxWindows
4 // Author: Vadim Zeitlin
8 // Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
9 // Licence: wxWindows license
10 /////////////////////////////////////////////////////////////////////////////
16 #pragma interface "intl.h"
20 #include "wx/string.h"
22 // ============================================================================
24 // ============================================================================
26 // ----------------------------------------------------------------------------
28 // ----------------------------------------------------------------------------
30 // # adjust if necessary
31 typedef unsigned char uint8
;
32 typedef unsigned long uint32
;
34 // ----------------------------------------------------------------------------
36 // ----------------------------------------------------------------------------
38 // gettext() style macro
39 #define _(str) wxGetTranslation(str)
41 // ----------------------------------------------------------------------------
43 // ----------------------------------------------------------------------------
44 class WXDLLEXPORT wxLocale
;
45 class WXDLLEXPORT wxMsgCatalog
;
47 // ----------------------------------------------------------------------------
49 // ----------------------------------------------------------------------------
50 extern wxLocale
* WXDLLEXPORT
wxGetLocale();
51 inline const char* wxGetTranslation(const char *sz
);
53 // ============================================================================
55 // ============================================================================
57 // ----------------------------------------------------------------------------
58 // wxLocale: encapsulates all language dependent settings, including current
59 // message catalogs, date, time and currency formats (#### to do) &c
60 // ----------------------------------------------------------------------------
61 class WXDLLEXPORT wxLocale
65 // the ctor has a side effect of changing current locale
66 wxLocale(const char *szName
, // name (for messages)
67 const char *szShort
= NULL
, // dir prefix (for msg files)
68 const char *szLocale
= NULL
, // locale (for setlocale)
69 bool bLoadDefault
= TRUE
); // preload wxstd.mo?
70 // restores old locale
73 // returns locale name
74 const char *GetLocale() const { return m_strLocale
; }
76 // add a catalog: it's searched for in standard places (current directory
77 // first, system one after). It will be used for message lookup by
80 // Returns 'true' if it was successfully loaded
81 bool AddCatalog(const char *szDomain
);
83 // check if the given catalog is loaded
84 bool IsLoaded(const char *szDomain
) const;
86 // retrieve the translation for a string in all loaded domains unless
87 // the szDomain parameter is specified (and then only this domain is
90 // return original string if translation is not available
91 // (in this case an error message is generated the first time
92 // a string is not found; use wxLogNull to suppress it)
94 // domains are searched in the last to first order, i.e. catalogs
95 // added later override those added before.
96 const char *GetString(const char *szOrigString
,
97 const char *szDomain
= NULL
) const;
100 // find catalog by name in a linked list, return NULL if !found
101 wxMsgCatalog
*FindCatalog(const char *szDomain
) const;
103 wxString m_strLocale
, // this locale name
104 m_strShort
; // short name for the locale
106 const char *m_pszOldLocale
; // previous locale from setlocale()
107 wxLocale
*m_pOldLocale
; // previous wxLocale
109 wxMsgCatalog
*m_pMsgCat
; // pointer to linked list of catalogs
112 // ============================================================================
114 // ============================================================================
116 // ----------------------------------------------------------------------------
117 // wxTString: automatically translates strings to current language
118 // ----------------------------------------------------------------------------
120 // this feature should be enabled by defining WX_USE_AUTOTRANS, if it's not
121 // done no automatic translation is performed
123 class WXDLLEXPORT wxTString
126 // NB: different ctors do different things!
128 wxTString(const char *sz
) : m_pcsz(wxGetTranslation(sz
)) { }
130 wxTString(const wxString
& s
) : m_pcsz(s
) { }
132 // NB: no copy ctor, it must be a POD so that we can pass it
133 // to vararg functions (and it's not needed anyhow)
135 // implicit conversion
136 operator const char *() const { return m_pcsz
; }
141 #else //!USE_AUTOTRANS
142 #define wxTString wxString
143 #endif //USE_AUTOTRANS
145 #define TRANSSTRING_DEFINED
147 // ----------------------------------------------------------------------------
149 // ----------------------------------------------------------------------------
151 // get the translation of the string in the current locale
152 inline const char *wxGetTranslation(const char *sz
)
154 wxLocale
*pLoc
= wxGetLocale();
155 return pLoc
== NULL
? sz
: pLoc
->GetString(sz
);