Correctly use the returned value from GetTimeZoneInformation.
This commit is contained in:
parent
c41d0c9a4b
commit
4ca34c4b2f
|
@ -57,9 +57,11 @@ static void test_mktime()
|
||||||
char TZ_env[256];
|
char TZ_env[256];
|
||||||
int secs;
|
int secs;
|
||||||
|
|
||||||
ok (res != 0, "GetTimeZoneInformation faile\n");
|
ok (res != TIME_ZONE_ID_INVALID, "GetTimeZoneInformation failed\n");
|
||||||
/* Bias may be positive or negative, to use offset of one day */
|
/* Bias may be positive or negative, to use offset of one day */
|
||||||
secs= SECSPERDAY - tzinfo.Bias*SECSPERMIN;
|
secs= SECSPERDAY - (tzinfo.Bias +
|
||||||
|
( res == TIME_ZONE_ID_STANDARD ? tzinfo.StandardBias :
|
||||||
|
( res == TIME_ZONE_ID_DAYLIGHT ? tzinfo.DaylightBias : 0 ))) * SECSPERMIN;
|
||||||
my_tm.tm_mday = 1 + secs/SECSPERDAY;
|
my_tm.tm_mday = 1 + secs/SECSPERDAY;
|
||||||
secs = secs % SECSPERDAY;
|
secs = secs % SECSPERDAY;
|
||||||
my_tm.tm_hour = secs / SECSPERHOUR;
|
my_tm.tm_hour = secs / SECSPERHOUR;
|
||||||
|
@ -87,15 +89,19 @@ static void test_localtime()
|
||||||
{
|
{
|
||||||
TIME_ZONE_INFORMATION tzinfo;
|
TIME_ZONE_INFORMATION tzinfo;
|
||||||
DWORD res = GetTimeZoneInformation(&tzinfo);
|
DWORD res = GetTimeZoneInformation(&tzinfo);
|
||||||
time_t gmt = (time_t)(SECSPERDAY + tzinfo.Bias*SECSPERMIN);
|
time_t gmt = (time_t)(SECSPERDAY + (tzinfo.Bias +
|
||||||
|
( res == TIME_ZONE_ID_STANDARD ? tzinfo.StandardBias :
|
||||||
|
( res == TIME_ZONE_ID_DAYLIGHT ? tzinfo.DaylightBias : 0 ))) * SECSPERMIN);
|
||||||
|
|
||||||
char TZ_env[256];
|
char TZ_env[256];
|
||||||
struct tm* lt;
|
struct tm* lt;
|
||||||
|
|
||||||
ok (res != 0, "GetTimeZoneInformation faile\n");
|
ok (res != TIME_ZONE_ID_INVALID, "GetTimeZoneInformation failed\n");
|
||||||
lt = localtime(&gmt);
|
lt = localtime(&gmt);
|
||||||
ok(((lt->tm_year == 70) && (lt->tm_mon == 0) && (lt->tm_yday == 1) &&
|
ok(((lt->tm_year == 70) && (lt->tm_mon == 0) && (lt->tm_yday == 1) &&
|
||||||
(lt->tm_mday == 2) && (lt->tm_wday == 5) && (lt->tm_hour == 0) &&
|
(lt->tm_mday == 2) && (lt->tm_wday == 5) && (lt->tm_hour == 0) &&
|
||||||
(lt->tm_min == 0) && (lt->tm_sec == 0) && (lt->tm_isdst == 0)),
|
(lt->tm_min == 0) && (lt->tm_sec == 0) && (lt->tm_isdst ==
|
||||||
|
(res == TIME_ZONE_ID_DAYLIGHT))),
|
||||||
"Wrong date:Year %4d mon %2d yday %3d mday %2d wday %1d hour%2d min %2d sec %2d dst %2d\n",
|
"Wrong date:Year %4d mon %2d yday %3d mday %2d wday %1d hour%2d min %2d sec %2d dst %2d\n",
|
||||||
lt->tm_year, lt->tm_mon, lt->tm_yday, lt->tm_mday, lt->tm_wday, lt->tm_hour,
|
lt->tm_year, lt->tm_mon, lt->tm_yday, lt->tm_mday, lt->tm_wday, lt->tm_hour,
|
||||||
lt->tm_min, lt->tm_sec, lt->tm_isdst);
|
lt->tm_min, lt->tm_sec, lt->tm_isdst);
|
||||||
|
@ -105,7 +111,8 @@ static void test_localtime()
|
||||||
lt = localtime(&gmt);
|
lt = localtime(&gmt);
|
||||||
ok(((lt->tm_year == 70) && (lt->tm_mon == 0) && (lt->tm_yday == 1) &&
|
ok(((lt->tm_year == 70) && (lt->tm_mon == 0) && (lt->tm_yday == 1) &&
|
||||||
(lt->tm_mday == 2) && (lt->tm_wday == 5) && (lt->tm_hour == 0) &&
|
(lt->tm_mday == 2) && (lt->tm_wday == 5) && (lt->tm_hour == 0) &&
|
||||||
(lt->tm_min == 0) && (lt->tm_sec == 0) && (lt->tm_isdst == 0)),
|
(lt->tm_min == 0) && (lt->tm_sec == 0) && (lt->tm_isdst ==
|
||||||
|
(res == TIME_ZONE_ID_DAYLIGHT))),
|
||||||
"Wrong date:Year %4d mon %2d yday %3d mday %2d wday %1d hour%2d min %2d sec %2d dst %2d\n",
|
"Wrong date:Year %4d mon %2d yday %3d mday %2d wday %1d hour%2d min %2d sec %2d dst %2d\n",
|
||||||
lt->tm_year, lt->tm_mon, lt->tm_yday, lt->tm_mday, lt->tm_wday, lt->tm_hour,
|
lt->tm_year, lt->tm_mon, lt->tm_yday, lt->tm_mday, lt->tm_wday, lt->tm_hour,
|
||||||
lt->tm_min, lt->tm_sec, lt->tm_isdst);
|
lt->tm_min, lt->tm_sec, lt->tm_isdst);
|
||||||
|
|
|
@ -124,7 +124,7 @@ struct MSVCRT_tm* MSVCRT_localtime(const MSVCRT_time_t* secs)
|
||||||
|
|
||||||
tzid = GetTimeZoneInformation(&tzinfo);
|
tzid = GetTimeZoneInformation(&tzinfo);
|
||||||
|
|
||||||
if (tzid == TIME_ZONE_ID_UNKNOWN) {
|
if (tzid == TIME_ZONE_ID_UNKNOWN || tzid == TIME_ZONE_ID_INVALID) {
|
||||||
tm.tm_isdst = -1;
|
tm.tm_isdst = -1;
|
||||||
} else {
|
} else {
|
||||||
tm.tm_isdst = (tzid == TIME_ZONE_ID_DAYLIGHT?1:0);
|
tm.tm_isdst = (tzid == TIME_ZONE_ID_DAYLIGHT?1:0);
|
||||||
|
@ -234,7 +234,9 @@ void _ftime(struct MSVCRT__timeb *buf)
|
||||||
|
|
||||||
buf->time = time / TICKSPERSEC - SECS_1601_TO_1970;
|
buf->time = time / TICKSPERSEC - SECS_1601_TO_1970;
|
||||||
buf->millitm = (time % TICKSPERSEC) / TICKSPERMSEC;
|
buf->millitm = (time % TICKSPERSEC) / TICKSPERMSEC;
|
||||||
buf->timezone = tzinfo.Bias;
|
buf->timezone = tzinfo.Bias +
|
||||||
|
( tzid == TIME_ZONE_ID_STANDARD ? tzinfo.StandardBias :
|
||||||
|
( tzid == TIME_ZONE_ID_DAYLIGHT ? tzinfo.DaylightBias : 0 ));
|
||||||
buf->dstflag = (tzid == TIME_ZONE_ID_DAYLIGHT?1:0);
|
buf->dstflag = (tzid == TIME_ZONE_ID_DAYLIGHT?1:0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue