Commit e5a25ec5 authored by Piotr Caban's avatar Piotr Caban Committed by Alexandre Julliard

kernel32: Fixed TIME_CompTimeZoneID behavior on dates close to New Year's Eve.

parent b057c5f1
...@@ -336,6 +336,29 @@ static void test_GetTimeZoneInformation(void) ...@@ -336,6 +336,29 @@ static void test_GetTimeZoneInformation(void)
l_time = system_time_to_minutes(&local); l_time = system_time_to_minutes(&local);
ok(l_time - s_time == diff, "got %d, expected %d\n", ok(l_time - s_time == diff, "got %d, expected %d\n",
(LONG)(l_time - s_time), diff); (LONG)(l_time - s_time), diff);
/* test 23:01, 31st of December date */
memset(&tzinfo, 0, sizeof(tzinfo));
tzinfo.StandardDate.wMonth = 10;
tzinfo.StandardDate.wDay = 5;
tzinfo.StandardDate.wHour = 2;
tzinfo.StandardDate.wMinute = 0;
tzinfo.DaylightDate.wMonth = 4;
tzinfo.DaylightDate.wDay = 1;
tzinfo.DaylightDate.wHour = 2;
tzinfo.Bias = 0;
tzinfo.StandardBias = 0;
tzinfo.DaylightBias = -60;
utc.wYear = 2012;
utc.wMonth = 12;
utc.wDay = 31;
utc.wHour = 23;
utc.wMinute = 1;
res = pSystemTimeToTzSpecificLocalTime(&tzinfo, &utc, &local);
ok(res, "SystemTimeToTzSpecificLocalTime error %u\n", GetLastError());
ok(local.wYear==2012 && local.wMonth==12 && local.wDay==31 && local.wHour==23 && local.wMinute==1,
"got (%d-%d-%d %02d:%02d), expected (2012-12-31 23:01)\n",
local.wYear, local.wMonth, local.wDay, local.wHour, local.wMinute);
} }
static void test_FileTimeToSystemTime(void) static void test_FileTimeToSystemTime(void)
......
...@@ -152,7 +152,7 @@ static int TIME_DayLightCompareDate( const SYSTEMTIME *date, ...@@ -152,7 +152,7 @@ static int TIME_DayLightCompareDate( const SYSTEMTIME *date,
static DWORD TIME_CompTimeZoneID ( const TIME_ZONE_INFORMATION *pTZinfo, static DWORD TIME_CompTimeZoneID ( const TIME_ZONE_INFORMATION *pTZinfo,
FILETIME *lpFileTime, BOOL islocal ) FILETIME *lpFileTime, BOOL islocal )
{ {
int ret; int ret, year;
BOOL beforeStandardDate, afterDaylightDate; BOOL beforeStandardDate, afterDaylightDate;
DWORD retval = TIME_ZONE_ID_INVALID; DWORD retval = TIME_ZONE_ID_INVALID;
LONGLONG llTime = 0; /* initialized to prevent gcc complaining */ LONGLONG llTime = 0; /* initialized to prevent gcc complaining */
...@@ -177,20 +177,29 @@ static DWORD TIME_CompTimeZoneID ( const TIME_ZONE_INFORMATION *pTZinfo, ...@@ -177,20 +177,29 @@ static DWORD TIME_CompTimeZoneID ( const TIME_ZONE_INFORMATION *pTZinfo,
if (!islocal) { if (!islocal) {
FILETIME2LL( lpFileTime, llTime ); FILETIME2LL( lpFileTime, llTime );
llTime -= ( pTZinfo->Bias + pTZinfo->DaylightBias ) llTime -= pTZinfo->Bias * (LONGLONG)600000000;
* (LONGLONG)600000000;
LL2FILETIME( llTime, &ftTemp) LL2FILETIME( llTime, &ftTemp)
lpFileTime = &ftTemp; lpFileTime = &ftTemp;
} }
FileTimeToSystemTime(lpFileTime, &SysTime); FileTimeToSystemTime(lpFileTime, &SysTime);
year = SysTime.wYear;
/* check for daylight savings */
ret = TIME_DayLightCompareDate( &SysTime, &pTZinfo->StandardDate); if (!islocal) {
if (ret == -2) llTime -= pTZinfo->DaylightBias * (LONGLONG)600000000;
return TIME_ZONE_ID_INVALID; LL2FILETIME( llTime, &ftTemp)
FileTimeToSystemTime(lpFileTime, &SysTime);
}
/* check for daylight savings */
if(year == SysTime.wYear) {
ret = TIME_DayLightCompareDate( &SysTime, &pTZinfo->StandardDate);
if (ret == -2)
return TIME_ZONE_ID_INVALID;
beforeStandardDate = ret < 0; beforeStandardDate = ret < 0;
} else
beforeStandardDate = SysTime.wYear < year;
if (!islocal) { if (!islocal) {
llTime -= ( pTZinfo->StandardBias - pTZinfo->DaylightBias ) llTime -= ( pTZinfo->StandardBias - pTZinfo->DaylightBias )
...@@ -199,11 +208,14 @@ static DWORD TIME_CompTimeZoneID ( const TIME_ZONE_INFORMATION *pTZinfo, ...@@ -199,11 +208,14 @@ static DWORD TIME_CompTimeZoneID ( const TIME_ZONE_INFORMATION *pTZinfo,
FileTimeToSystemTime(lpFileTime, &SysTime); FileTimeToSystemTime(lpFileTime, &SysTime);
} }
ret = TIME_DayLightCompareDate( &SysTime, &pTZinfo->DaylightDate); if(year == SysTime.wYear) {
if (ret == -2) ret = TIME_DayLightCompareDate( &SysTime, &pTZinfo->DaylightDate);
return TIME_ZONE_ID_INVALID; if (ret == -2)
return TIME_ZONE_ID_INVALID;
afterDaylightDate = ret >= 0; afterDaylightDate = ret >= 0;
} else
afterDaylightDate = SysTime.wYear > year;
retval = TIME_ZONE_ID_STANDARD; retval = TIME_ZONE_ID_STANDARD;
if( pTZinfo->DaylightDate.wMonth < pTZinfo->StandardDate.wMonth ) { if( pTZinfo->DaylightDate.wMonth < pTZinfo->StandardDate.wMonth ) {
......
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