Unicode support. The _() macro is made to imply _T() (would be boring to
type _(_T("text")), I think). That means you have to use wxGetString() directly if you need to look up from a string variable instead of a literal. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@2110 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
2bb67b808b
commit
7b36d72062
@ -30,7 +30,7 @@
|
|||||||
// gettext() style macro (notice that xgettext should be invoked with "-k_"
|
// gettext() style macro (notice that xgettext should be invoked with "-k_"
|
||||||
// option to extract the strings inside _() from the sources)
|
// option to extract the strings inside _() from the sources)
|
||||||
#ifndef WXINTL_NO_GETTEXT_MACRO
|
#ifndef WXINTL_NO_GETTEXT_MACRO
|
||||||
#define _(str) wxGetTranslation(str)
|
#define _(str) wxGetTranslation(_T(str))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@ -56,21 +56,21 @@ public:
|
|||||||
// call Init() if you use this ctor
|
// call Init() if you use this ctor
|
||||||
wxLocale();
|
wxLocale();
|
||||||
// the ctor has a side effect of changing current locale
|
// the ctor has a side effect of changing current locale
|
||||||
wxLocale(const char *szName, // name (for messages)
|
wxLocale(const wxChar *szName, // name (for messages)
|
||||||
const char *szShort = (const char *) NULL, // dir prefix (for msg files)
|
const wxChar *szShort = (const wxChar *) NULL, // dir prefix (for msg files)
|
||||||
const char *szLocale = (const char *) NULL, // locale (for setlocale)
|
const wxChar *szLocale = (const wxChar *) NULL, // locale (for setlocale)
|
||||||
bool bLoadDefault = TRUE) // preload wxstd.mo?
|
bool bLoadDefault = TRUE) // preload wxstd.mo?
|
||||||
{ Init(szName, szShort, szLocale, bLoadDefault); }
|
{ Init(szName, szShort, szLocale, bLoadDefault); }
|
||||||
// the same as a function (returns TRUE on success)
|
// the same as a function (returns TRUE on success)
|
||||||
bool Init(const char *szName,
|
bool Init(const wxChar *szName,
|
||||||
const char *szShort = (const char *) NULL,
|
const wxChar *szShort = (const wxChar *) NULL,
|
||||||
const char *szLocale = (const char *) NULL,
|
const wxChar *szLocale = (const wxChar *) NULL,
|
||||||
bool bLoadDefault = TRUE);
|
bool bLoadDefault = TRUE);
|
||||||
// restores old locale
|
// restores old locale
|
||||||
~wxLocale();
|
~wxLocale();
|
||||||
|
|
||||||
// returns locale name
|
// returns locale name
|
||||||
const char *GetLocale() const { return m_strLocale; }
|
const wxChar *GetLocale() const { return m_strLocale; }
|
||||||
|
|
||||||
// add a prefix to the catalog lookup path: the message catalog files will be
|
// add a prefix to the catalog lookup path: the message catalog files will be
|
||||||
// looked up under prefix/<lang>/LC_MESSAGES, prefix/LC_MESSAGES and prefix
|
// looked up under prefix/<lang>/LC_MESSAGES, prefix/LC_MESSAGES and prefix
|
||||||
@ -86,10 +86,10 @@ public:
|
|||||||
// The loaded catalog will be used for message lookup by GetString().
|
// The loaded catalog will be used for message lookup by GetString().
|
||||||
//
|
//
|
||||||
// Returns 'true' if it was successfully loaded
|
// Returns 'true' if it was successfully loaded
|
||||||
bool AddCatalog(const char *szDomain);
|
bool AddCatalog(const wxChar *szDomain);
|
||||||
|
|
||||||
// check if the given catalog is loaded
|
// check if the given catalog is loaded
|
||||||
bool IsLoaded(const char *szDomain) const;
|
bool IsLoaded(const wxChar *szDomain) const;
|
||||||
|
|
||||||
// retrieve the translation for a string in all loaded domains unless
|
// retrieve the translation for a string in all loaded domains unless
|
||||||
// the szDomain parameter is specified (and then only this domain is
|
// the szDomain parameter is specified (and then only this domain is
|
||||||
@ -101,20 +101,20 @@ public:
|
|||||||
//
|
//
|
||||||
// domains are searched in the last to first order, i.e. catalogs
|
// domains are searched in the last to first order, i.e. catalogs
|
||||||
// added later override those added before.
|
// added later override those added before.
|
||||||
const char *GetString(const char *szOrigString,
|
const wxMB2WXbuf GetString(const wxChar *szOrigString,
|
||||||
const char *szDomain = (const char *) NULL) const;
|
const wxChar *szDomain = (const wxChar *) NULL) const;
|
||||||
|
|
||||||
// Returns the current short name for the locale
|
// Returns the current short name for the locale
|
||||||
const wxString& GetName() const { return m_strShort; }
|
const wxString& GetName() const { return m_strShort; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// find catalog by name in a linked list, return NULL if !found
|
// find catalog by name in a linked list, return NULL if !found
|
||||||
wxMsgCatalog *FindCatalog(const char *szDomain) const;
|
wxMsgCatalog *FindCatalog(const wxChar *szDomain) const;
|
||||||
|
|
||||||
wxString m_strLocale, // this locale name
|
wxString m_strLocale, // this locale name
|
||||||
m_strShort; // short name for the locale
|
m_strShort; // short name for the locale
|
||||||
|
|
||||||
const char *m_pszOldLocale; // previous locale from setlocale()
|
const wxChar *m_pszOldLocale; // previous locale from setlocale()
|
||||||
wxLocale *m_pOldLocale; // previous wxLocale
|
wxLocale *m_pOldLocale; // previous wxLocale
|
||||||
|
|
||||||
wxMsgCatalog *m_pMsgCat; // pointer to linked list of catalogs
|
wxMsgCatalog *m_pMsgCat; // pointer to linked list of catalogs
|
||||||
@ -128,10 +128,10 @@ private:
|
|||||||
extern WXDLLEXPORT wxLocale* wxGetLocale();
|
extern WXDLLEXPORT wxLocale* wxGetLocale();
|
||||||
|
|
||||||
// get the translation of the string in the current locale
|
// get the translation of the string in the current locale
|
||||||
inline const char *wxGetTranslation(const char *sz)
|
inline const wxMB2WXbuf wxGetTranslation(const wxChar *sz)
|
||||||
{
|
{
|
||||||
wxLocale *pLoc = wxGetLocale();
|
wxLocale *pLoc = wxGetLocale();
|
||||||
return pLoc ? pLoc->GetString(sz) : sz;
|
return pLoc ? pLoc->GetString(sz) : (const wxMB2WXbuf)sz;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user