Commit 667dad23 authored by Dmitry Timoshkov's avatar Dmitry Timoshkov Committed by Alexandre Julliard

kernel32: Separate modifier from charset before detecting the charset codepage.

parent 01af8501
...@@ -351,6 +351,8 @@ static void parse_locale_name( const WCHAR *str, struct locale_name *name ) ...@@ -351,6 +351,8 @@ static void parse_locale_name( const WCHAR *str, struct locale_name *name )
static const WCHAR latnW[] = {'-','L','a','t','n',0}; static const WCHAR latnW[] = {'-','L','a','t','n',0};
WCHAR *p; WCHAR *p;
TRACE("%s\n", debugstr_w(str));
name->country = name->charset = name->script = name->modifier = NULL; name->country = name->charset = name->script = name->modifier = NULL;
name->lcid = MAKELCID( MAKELANGID(LANG_ENGLISH,SUBLANG_DEFAULT), SORT_DEFAULT ); name->lcid = MAKELCID( MAKELANGID(LANG_ENGLISH,SUBLANG_DEFAULT), SORT_DEFAULT );
name->matches = 0; name->matches = 0;
...@@ -395,7 +397,6 @@ static void parse_locale_name( const WCHAR *str, struct locale_name *name ) ...@@ -395,7 +397,6 @@ static void parse_locale_name( const WCHAR *str, struct locale_name *name )
{ {
*p++ = 0; *p++ = 0;
name->charset = p; name->charset = p;
name->codepage = find_charset( name->charset );
p = strchrW( p, '@' ); p = strchrW( p, '@' );
} }
if (p) if (p)
...@@ -404,6 +405,9 @@ static void parse_locale_name( const WCHAR *str, struct locale_name *name ) ...@@ -404,6 +405,9 @@ static void parse_locale_name( const WCHAR *str, struct locale_name *name )
name->modifier = p; name->modifier = p;
} }
if (name->charset)
name->codepage = find_charset( name->charset );
/* rebuild a Windows name if possible */ /* rebuild a Windows name if possible */
if (name->charset) goto done; /* can't specify charset in Windows format */ if (name->charset) goto done; /* can't specify charset in Windows format */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment