Added wxOKlibc(), which checks for glibc2.0, which incorrectly does UTF-8
conversion even when it's not in UTF-8 locale git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@2273 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
		@@ -458,6 +458,7 @@ size_t WXDLLEXPORT wxWC2MB(char *buf, const wchar_t *psz, size_t n);
 | 
				
			|||||||
#define wxWX2WC wxMB2WC
 | 
					#define wxWX2WC wxMB2WC
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					bool WXDLLEXPORT wxOKlibc(); // for internal use
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// if libc versions are not available, use replacements defined in wxchar.cpp
 | 
					// if libc versions are not available, use replacements defined in wxchar.cpp
 | 
				
			||||||
#ifndef wxStrdup
 | 
					#ifndef wxStrdup
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -40,7 +40,7 @@
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if wxUSE_WCHAR_T
 | 
					#if wxUSE_WCHAR_T
 | 
				
			||||||
size_t wxMB2WC(wchar_t *buf, const char *psz, size_t n)
 | 
					size_t WXDLLEXPORT wxMB2WC(wchar_t *buf, const char *psz, size_t n)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  if (buf) {
 | 
					  if (buf) {
 | 
				
			||||||
    if (!n || !*psz) {
 | 
					    if (!n || !*psz) {
 | 
				
			||||||
@@ -62,7 +62,7 @@ size_t wxMB2WC(wchar_t *buf, const char *psz, size_t n)
 | 
				
			|||||||
#endif // GNU
 | 
					#endif // GNU
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
size_t wxWC2MB(char *buf, const wchar_t *pwz, size_t n)
 | 
					size_t WXDLLEXPORT wxWC2MB(char *buf, const wchar_t *pwz, size_t n)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  if (buf) {
 | 
					  if (buf) {
 | 
				
			||||||
    if (!n || !*pwz) {
 | 
					    if (!n || !*pwz) {
 | 
				
			||||||
@@ -86,6 +86,26 @@ size_t wxWC2MB(char *buf, const wchar_t *pwz, size_t n)
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bool WXDLLEXPORT wxOKlibc()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if wxUSE_WCHAR_T && defined(__UNIX__) && defined(__GLIBC__)
 | 
				
			||||||
 | 
					  // GNU libc uses UTF-8 even when it shouldn't
 | 
				
			||||||
 | 
					  wchar_t res;
 | 
				
			||||||
 | 
					  if ((MB_CUR_MAX == 2) &&
 | 
				
			||||||
 | 
					      (wxMB2WC(&res, "\xdd\xa5", 1)>0) &&
 | 
				
			||||||
 | 
					      (res==0x765)) {
 | 
				
			||||||
 | 
					    // this is UTF-8 allright, check whether that's what we want
 | 
				
			||||||
 | 
					    char *cur_locale = setlocale(LC_ALL, NULL);
 | 
				
			||||||
 | 
					    if ((strlen(cur_locale) < 4) ||
 | 
				
			||||||
 | 
						(strcasecmp(cur_locale + strlen(cur_locale) - 4, "utf8"))) {
 | 
				
			||||||
 | 
					      // nope, don't use libc conversion
 | 
				
			||||||
 | 
					      return FALSE;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					  return TRUE;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef wxStrdup
 | 
					#ifndef wxStrdup
 | 
				
			||||||
wxChar * WXDLLEXPORT wxStrdup(const wxChar *psz)
 | 
					wxChar * WXDLLEXPORT wxStrdup(const wxChar *psz)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user