applied modified UTF-8 locales patch (766893)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@21735 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -105,6 +105,7 @@ Unix:
|
|||||||
- fixed compilation on Solaris 7 with large files support enabled
|
- fixed compilation on Solaris 7 with large files support enabled
|
||||||
- added wxTaskBarIcon implementation for X11
|
- added wxTaskBarIcon implementation for X11
|
||||||
- added support for GNU/Hurd in configure
|
- added support for GNU/Hurd in configure
|
||||||
|
- wxLocale::Init now tries to set .utf8 locale in Unicode mode (Andreas Pflug)
|
||||||
|
|
||||||
wxGTK:
|
wxGTK:
|
||||||
|
|
||||||
|
@@ -213,6 +213,19 @@ Checking in src/msw/window.cpp;
|
|||||||
new revision: 1.381; previous revision: 1.380
|
new revision: 1.381; previous revision: 1.380
|
||||||
done
|
done
|
||||||
|
|
||||||
|
24. Fix wxLocale::Init to try xx_YY.utf8 on systems where xx_YY fails
|
||||||
|
(presumably RedHat; do it in Unicode mode only)
|
||||||
|
|
||||||
|
See: Patch [ 766893 ]
|
||||||
|
Checking in intl.cpp;
|
||||||
|
/pack/cvsroots/wxwindows/wxWindows/src/common/intl.cpp,v <-- intl.cpp
|
||||||
|
new revision: 1.97; previous revision: 1.96
|
||||||
|
done
|
||||||
|
Checking in changes.txt;
|
||||||
|
/pack/cvsroots/wxwindows/wxWindows/docs/changes.txt,v <-- changes.txt
|
||||||
|
new revision: 1.297; previous revision: 1.296
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
TODO for 2.4 (items that are not backports)
|
TODO for 2.4 (items that are not backports)
|
||||||
===========================================
|
===========================================
|
||||||
|
@@ -141,6 +141,7 @@ static inline wxString ExtractNotLang(const wxString& langFull)
|
|||||||
#endif // __UNIX__
|
#endif // __UNIX__
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxMsgCatalogFile corresponds to one disk-file message catalog.
|
// wxMsgCatalogFile corresponds to one disk-file message catalog.
|
||||||
//
|
//
|
||||||
@@ -644,6 +645,23 @@ bool wxLocale::Init(const wxChar *szName,
|
|||||||
return bOk;
|
return bOk;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(__UNIX__) && wxUSE_UNICODE
|
||||||
|
static wxWCharBuffer wxSetlocaleTryUTF(int c, const wxChar *lc)
|
||||||
|
{
|
||||||
|
wxMB2WXbuf l = wxSetlocale(c, lc);
|
||||||
|
if ( lc && lc[0] != 0 && !l )
|
||||||
|
{
|
||||||
|
wxString buf(lc);
|
||||||
|
buf += wxT(".utf8");
|
||||||
|
l = wxSetlocale(c, buf.c_str());
|
||||||
|
}
|
||||||
|
return l;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
#define wxSetlocaleTryUTF(c, lc) wxSetlocale(c, lc)
|
||||||
|
#endif
|
||||||
|
|
||||||
bool wxLocale::Init(int language, int flags)
|
bool wxLocale::Init(int language, int flags)
|
||||||
{
|
{
|
||||||
int lang = language;
|
int lang = language;
|
||||||
@@ -679,12 +697,12 @@ bool wxLocale::Init(int language, int flags)
|
|||||||
else
|
else
|
||||||
locale = info->CanonicalName;
|
locale = info->CanonicalName;
|
||||||
|
|
||||||
wxMB2WXbuf retloc = wxSetlocale(LC_ALL, locale);
|
wxMB2WXbuf retloc = wxSetlocaleTryUTF(LC_ALL, locale);
|
||||||
|
|
||||||
if ( !retloc )
|
if ( !retloc )
|
||||||
{
|
{
|
||||||
// Some C libraries don't like xx_YY form and require xx only
|
// Some C libraries don't like xx_YY form and require xx only
|
||||||
retloc = wxSetlocale(LC_ALL, locale.Mid(0,2));
|
retloc = wxSetlocaleTryUTF(LC_ALL, locale.Mid(0,2));
|
||||||
}
|
}
|
||||||
if ( !retloc )
|
if ( !retloc )
|
||||||
{
|
{
|
||||||
@@ -702,13 +720,13 @@ bool wxLocale::Init(int language, int flags)
|
|||||||
else if (mid == wxT("nn"))
|
else if (mid == wxT("nn"))
|
||||||
locale = wxT("no_NY");
|
locale = wxT("no_NY");
|
||||||
|
|
||||||
retloc = wxSetlocale(LC_ALL, locale);
|
retloc = wxSetlocaleTryUTF(LC_ALL, locale);
|
||||||
}
|
}
|
||||||
if ( !retloc )
|
if ( !retloc )
|
||||||
{
|
{
|
||||||
// (This time, we changed locale in previous if-branch, so try again.)
|
// (This time, we changed locale in previous if-branch, so try again.)
|
||||||
// Some C libraries don't like xx_YY form and require xx only
|
// Some C libraries don't like xx_YY form and require xx only
|
||||||
retloc = wxSetlocale(LC_ALL, locale.Mid(0,2));
|
retloc = wxSetlocaleTryUTF(LC_ALL, locale.Mid(0,2));
|
||||||
}
|
}
|
||||||
if ( !retloc )
|
if ( !retloc )
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user