Commit 9c5fa40e authored by Jinoh Kang's avatar Jinoh Kang Committed by Alexandre Julliard

kernelbase: Fix infinite loop in Internal_EnumCalendarInfo.

parent 4010876a
......@@ -7045,12 +7045,6 @@ static void test_EnumCalendarInfoA(void)
{
INT i;
if (!strcmp(winetest_platform, "wine"))
{
skip("EnumCalendarInfo broken on Wine (test would hang with an infinite loop)\n");
return;
}
ok( EnumCalendarInfoA( calinfo_procA,
LOCALE_USER_DEFAULT,
ENUM_ALL_CALENDARS,
......@@ -7079,12 +7073,6 @@ static void test_EnumCalendarInfoW(void)
{
INT i;
if (!strcmp(winetest_platform, "wine"))
{
skip("EnumCalendarInfo broken on Wine (test would hang with an infinite loop)\n");
return;
}
ok( EnumCalendarInfoW( calinfo_procW,
LOCALE_USER_DEFAULT,
ENUM_ALL_CALENDARS,
......@@ -7114,12 +7102,6 @@ static void test_EnumCalendarInfoExA(void)
{
INT i;
if (!strcmp(winetest_platform, "wine"))
{
skip("EnumCalendarInfo broken on Wine (test would hang with an infinite loop)\n");
return;
}
ok( EnumCalendarInfoExA( calinfoex_procA,
LOCALE_USER_DEFAULT,
ENUM_ALL_CALENDARS,
......@@ -7149,12 +7131,6 @@ static void test_EnumCalendarInfoExW(void)
{
INT i;
if (!strcmp(winetest_platform, "wine"))
{
skip("EnumCalendarInfo broken on Wine (test would hang with an infinite loop)\n");
return;
}
ok( EnumCalendarInfoExW( calinfoex_procW,
LOCALE_USER_DEFAULT,
ENUM_ALL_CALENDARS,
......
......@@ -2727,8 +2727,8 @@ BOOL WINAPI DECLSPEC_HOTPATCH Internal_EnumCalendarInfo( CALINFO_ENUMPROCW proc,
BOOL exex, LPARAM lparam )
{
WCHAR buffer[256];
DWORD optional = 0;
INT ret;
CALID calendars[2] = { id };
INT ret, i;
if (!proc)
{
......@@ -2739,13 +2739,14 @@ BOOL WINAPI DECLSPEC_HOTPATCH Internal_EnumCalendarInfo( CALINFO_ENUMPROCW proc,
if (id == ENUM_ALL_CALENDARS)
{
if (!GetLocaleInfoW( lcid, LOCALE_ICALENDARTYPE | LOCALE_RETURN_NUMBER,
(WCHAR *)&id, sizeof(id) / sizeof(WCHAR) )) return FALSE;
(WCHAR *)&calendars[0], sizeof(calendars[0]) / sizeof(WCHAR) )) return FALSE;
if (!GetLocaleInfoW( lcid, LOCALE_IOPTIONALCALENDAR | LOCALE_RETURN_NUMBER,
(WCHAR *)&optional, sizeof(optional) / sizeof(WCHAR) )) optional = 0;
(WCHAR *)&calendars[1], sizeof(calendars[1]) / sizeof(WCHAR) )) calendars[1] = 0;
}
for (;;)
for (i = 0; i < ARRAY_SIZE(calendars) && calendars[i]; i++)
{
id = calendars[i];
if (type & CAL_RETURN_NUMBER)
ret = GetCalendarInfoW( lcid, id, type, NULL, 0, (LPDWORD)buffer );
else if (unicode)
......@@ -2764,8 +2765,6 @@ BOOL WINAPI DECLSPEC_HOTPATCH Internal_EnumCalendarInfo( CALINFO_ENUMPROCW proc,
else ret = proc( buffer );
}
if (!ret) break;
if (!optional) break;
id = optional;
}
return TRUE;
}
......
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