]> git.saurik.com Git - wxWidgets.git/commitdiff
applied modified UTF-8 locales patch (766893)
authorVáclav Slavík <vslavik@fastmail.fm>
Mon, 7 Jul 2003 08:28:44 +0000 (08:28 +0000)
committerVáclav Slavík <vslavik@fastmail.fm>
Mon, 7 Jul 2003 08:28:44 +0000 (08:28 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@21735 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

docs/changes.txt
docs/toback24.txt
src/common/intl.cpp

index d1703b0c8eb4881ad84a1f90672cb607e539ce0f..c30903e627678fd7413146ae174f4a3087cbd861 100644 (file)
@@ -105,6 +105,7 @@ Unix:
 - fixed compilation on Solaris 7 with large files support enabled
 - added wxTaskBarIcon implementation for X11
 - added support for GNU/Hurd in configure
+- wxLocale::Init now tries to set .utf8 locale in Unicode mode (Andreas Pflug)
 
 wxGTK:
 
index 182f55a2f1adf0942eeb52ae9541fc32d4d99e32..83d2c076548e31840de8d888b810cf7cc2bf5239 100644 (file)
@@ -213,6 +213,19 @@ Checking in src/msw/window.cpp;
 new revision: 1.381; previous revision: 1.380
 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)
 ===========================================
index 684c9a5f2516b0e2418017183a1642a6c51f2eb0..69178b2abc00766a56c47bbe4f3a995d5a7a25ea 100644 (file)
@@ -141,6 +141,7 @@ static inline wxString ExtractNotLang(const wxString& langFull)
 #endif // __UNIX__
 
 
+
 // ----------------------------------------------------------------------------
 // wxMsgCatalogFile corresponds to one disk-file message catalog.
 //
@@ -644,6 +645,23 @@ bool wxLocale::Init(const wxChar *szName,
   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)
 {
     int lang = language;
@@ -679,12 +697,12 @@ bool wxLocale::Init(int language, int flags)
     else
         locale = info->CanonicalName;
 
-    wxMB2WXbuf retloc = wxSetlocale(LC_ALL, locale);
+    wxMB2WXbuf retloc = wxSetlocaleTryUTF(LC_ALL, locale);
 
     if ( !retloc )
     {
         // 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 )
     {
@@ -702,13 +720,13 @@ bool wxLocale::Init(int language, int flags)
         else if (mid == wxT("nn"))
             locale = wxT("no_NY");
 
-        retloc = wxSetlocale(LC_ALL, locale);
+        retloc = wxSetlocaleTryUTF(LC_ALL, locale);
     }
     if ( !retloc )
     {
         // (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
-        retloc = wxSetlocale(LC_ALL, locale.Mid(0,2));
+        retloc = wxSetlocaleTryUTF(LC_ALL, locale.Mid(0,2));
     }
     if ( !retloc )
     {