Piotr Caban : msvcrt: Don't overwrite mbcinfo inside setlocale.

Alexandre Julliard julliard at winehq.org
Wed Oct 12 14:31:18 CDT 2011


Module: wine
Branch: master
Commit: cf27cb49276f333c83e56b62781ca32b30e52735
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=cf27cb49276f333c83e56b62781ca32b30e52735

Author: Piotr Caban <piotr at codeweavers.com>
Date:   Wed Oct 12 11:54:53 2011 +0200

msvcrt: Don't overwrite mbcinfo inside setlocale.

---

 dlls/msvcrt/locale.c |    5 ++---
 dlls/msvcrt/main.c   |    1 -
 dlls/msvcrt/msvcrt.h |    1 +
 3 files changed, 3 insertions(+), 4 deletions(-)

diff --git a/dlls/msvcrt/locale.c b/dlls/msvcrt/locale.c
index d83f8db..2f646e7 100644
--- a/dlls/msvcrt/locale.c
+++ b/dlls/msvcrt/locale.c
@@ -364,7 +364,7 @@ MSVCRT_pthreadlocinfo get_locinfo(void) {
 }
 
 /* INTERNAL: returns pthreadlocinfo struct */
-static MSVCRT_pthreadmbcinfo get_mbcinfo(void) {
+MSVCRT_pthreadmbcinfo get_mbcinfo(void) {
     thread_data_t *data = msvcrt_get_thread_data();
 
     if(!data || !data->have_locale)
@@ -1172,8 +1172,6 @@ char* CDECL MSVCRT_setlocale(int category, const char* locale)
             swap_pointers((void**)&locinfo->pclmap, (void**)&loc->locinfo->pclmap);
             swap_pointers((void**)&locinfo->pcumap, (void**)&loc->locinfo->pcumap);
 
-            memcpy(get_mbcinfo(), loc->mbcinfo, sizeof(MSVCRT_threadmbcinfo));
-
             if(category != MSVCRT_LC_ALL)
                 break;
             /* fall through */
@@ -1323,5 +1321,6 @@ BOOL msvcrt_init_locale(void)
     MSVCRT__pctype = MSVCRT_locale->locinfo->pctype;
     for(i=MSVCRT_LC_MIN; i<=MSVCRT_LC_MAX; i++)
         MSVCRT___lc_handle[i] = MSVCRT_locale->locinfo->lc_handle[i];
+    _setmbcp(_MB_CP_ANSI);
     return TRUE;
 }
diff --git a/dlls/msvcrt/main.c b/dlls/msvcrt/main.c
index 45191cd..736c068 100644
--- a/dlls/msvcrt/main.c
+++ b/dlls/msvcrt/main.c
@@ -110,7 +110,6 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
     msvcrt_init_console();
     msvcrt_init_args();
     msvcrt_init_signals();
-    _setmbcp(_MB_CP_LOCALE);
     /* don't allow unloading msvcrt, we can't setup file handles twice */
     LdrAddRefDll( 0, hinstDLL );
     TRACE("finished process init\n");
diff --git a/dlls/msvcrt/msvcrt.h b/dlls/msvcrt/msvcrt.h
index 3741842..963e227 100644
--- a/dlls/msvcrt/msvcrt.h
+++ b/dlls/msvcrt/msvcrt.h
@@ -883,6 +883,7 @@ int            __cdecl MSVCRT_raise(int sig);
 
 extern MSVCRT__locale_t MSVCRT_locale;
 MSVCRT_pthreadlocinfo get_locinfo(void);
+MSVCRT_pthreadmbcinfo get_mbcinfo(void);
 void __cdecl MSVCRT__free_locale(MSVCRT__locale_t);
 void free_locinfo(MSVCRT_pthreadlocinfo);
 void free_mbcinfo(MSVCRT_pthreadmbcinfo);




More information about the wine-cvs mailing list