kernelbase: Reimplement EnumUILanguages() using the locale.nls data.
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
e74b0dc880
commit
1f70f72b29
|
@ -3849,6 +3849,10 @@ static void test_EnumUILanguageA(void)
|
|||
}
|
||||
ok(ret, "Expected ret != 0, got %d, error %ld\n", ret, GetLastError());
|
||||
|
||||
SetLastError(0xdeadbeef);
|
||||
ret = pEnumUILanguagesA(luilocale_proc1A, MUI_LANGUAGE_NAME, 0);
|
||||
ok(ret, "Expected ret != 0, got %d, error %ld\n", ret, GetLastError());
|
||||
|
||||
enumCount = 0;
|
||||
SetLastError(ERROR_SUCCESS);
|
||||
ret = pEnumUILanguagesA(luilocale_proc2A, 0, 0);
|
||||
|
|
|
@ -3111,38 +3111,58 @@ BOOL WINAPI DECLSPEC_HOTPATCH Internal_EnumTimeFormats( TIMEFMT_ENUMPROCW proc,
|
|||
BOOL WINAPI DECLSPEC_HOTPATCH Internal_EnumUILanguages( UILANGUAGE_ENUMPROCW proc, DWORD flags,
|
||||
LONG_PTR param, BOOL unicode )
|
||||
{
|
||||
WCHAR name[10];
|
||||
DWORD name_len, type, index = 0;
|
||||
HKEY key;
|
||||
WCHAR nameW[LOCALE_NAME_MAX_LENGTH];
|
||||
char nameA[LOCALE_NAME_MAX_LENGTH];
|
||||
DWORD i;
|
||||
|
||||
if (!proc)
|
||||
{
|
||||
SetLastError( ERROR_INVALID_PARAMETER );
|
||||
return FALSE;
|
||||
}
|
||||
if (flags & ~MUI_LANGUAGE_ID)
|
||||
if (flags & ~(MUI_LANGUAGE_ID | MUI_LANGUAGE_NAME))
|
||||
{
|
||||
SetLastError( ERROR_INVALID_FLAGS );
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (RegOpenKeyExW( nls_key, L"Locale", 0, KEY_READ, &key )) return FALSE;
|
||||
for (i = 0; i < locale_table->nb_lcnames; i++)
|
||||
{
|
||||
if (!lcnames_index[i].name) continue; /* skip invariant locale */
|
||||
if (lcnames_index[i].id & 0x80000000) continue; /* skip aliases */
|
||||
if (!get_locale_data( lcnames_index[i].idx )->inotneutral) continue; /* skip neutral locales */
|
||||
if (!SORTIDFROMLCID( lcnames_index[i].id ) != !(flags & LCID_ALTERNATE_SORTS))
|
||||
continue; /* skip alternate sorts */
|
||||
if (flags & MUI_LANGUAGE_NAME)
|
||||
{
|
||||
const WCHAR *str = locale_strings + lcnames_index[i].name;
|
||||
|
||||
for (;;)
|
||||
if (unicode)
|
||||
{
|
||||
name_len = ARRAY_SIZE(name);
|
||||
if (RegEnumValueW( key, index++, name, &name_len, NULL, &type, NULL, NULL )) break;
|
||||
if (type != REG_SZ) continue;
|
||||
if (!wcstoul( name, NULL, 16 )) continue;
|
||||
if (!unicode)
|
||||
memcpy( nameW, str + 1, (*str + 1) * sizeof(WCHAR) );
|
||||
if (!proc( nameW, param )) break;
|
||||
}
|
||||
else
|
||||
{
|
||||
char nameA[10];
|
||||
WideCharToMultiByte( CP_ACP, 0, name, -1, nameA, sizeof(nameA), NULL, NULL );
|
||||
WideCharToMultiByte( CP_ACP, 0, str + 1, -1, nameA, sizeof(nameA), NULL, NULL );
|
||||
if (!((UILANGUAGE_ENUMPROCA)proc)( nameA, param )) break;
|
||||
}
|
||||
else if (!proc( name, param )) break;
|
||||
}
|
||||
RegCloseKey( key );
|
||||
else
|
||||
{
|
||||
if (lcnames_index[i].id == LOCALE_CUSTOM_UNSPECIFIED) continue; /* skip locales with no lcid */
|
||||
if (unicode)
|
||||
{
|
||||
swprintf( nameW, ARRAY_SIZE(nameW), L"%04lx", lcnames_index[i].id );
|
||||
if (!proc( nameW, param )) break;
|
||||
}
|
||||
else
|
||||
{
|
||||
sprintf( nameA, "%04x", lcnames_index[i].id );
|
||||
if (!((UILANGUAGE_ENUMPROCA)proc)( nameA, param )) break;
|
||||
}
|
||||
}
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue