Commit e21d3d7e authored by ulan@chromium.org's avatar ulan@chromium.org

Revert r24922 "Windows: use SystemTimeToTzSpecificLocalTime instead of localtime_s."

SystemTimeToTzSpecificLocalTime doesn't work correctly inside Chrome sandbox.

BUG=chromium:417640
LOG=Y
R=yangguo@chromium.org

Review URL: https://codereview.chromium.org/710643002

Cr-Commit-Position: refs/heads/master@{#25211}
git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@25211 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 57ae5420
...@@ -346,26 +346,41 @@ void Win32Time::SetToCurrentTime() { ...@@ -346,26 +346,41 @@ void Win32Time::SetToCurrentTime() {
} }
int64_t FileTimeToInt64(FILETIME ft) {
ULARGE_INTEGER result;
result.LowPart = ft.dwLowDateTime;
result.HighPart = ft.dwHighDateTime;
return static_cast<int64_t>(result.QuadPart);
}
// Return the local timezone offset in milliseconds east of UTC. This // Return the local timezone offset in milliseconds east of UTC. This
// takes into account whether daylight saving is in effect at the time. // takes into account whether daylight saving is in effect at the time.
// Only times in the 32-bit Unix range may be passed to this function. // Only times in the 32-bit Unix range may be passed to this function.
// Also, adding the time-zone offset to the input must not overflow. // Also, adding the time-zone offset to the input must not overflow.
// The function EquivalentTime() in date.js guarantees this. // The function EquivalentTime() in date.js guarantees this.
int64_t Win32Time::LocalOffset(TimezoneCache* cache) { int64_t Win32Time::LocalOffset(TimezoneCache* cache) {
FILETIME local; cache->InitializeIfNeeded();
SYSTEMTIME system_utc, system_local;
FileTimeToSystemTime(&time_.ft_, &system_utc); Win32Time rounded_to_second(*this);
SystemTimeToTzSpecificLocalTime(NULL, &system_utc, &system_local); rounded_to_second.t() =
SystemTimeToFileTime(&system_local, &local); rounded_to_second.t() / 1000 / kTimeScaler * 1000 * kTimeScaler;
return (FileTimeToInt64(local) - FileTimeToInt64(time_.ft_)) / kTimeScaler; // Convert to local time using POSIX localtime function.
// Windows XP Service Pack 3 made SystemTimeToTzSpecificLocalTime()
// very slow. Other browsers use localtime().
// Convert from JavaScript milliseconds past 1/1/1970 0:00:00 to
// POSIX seconds past 1/1/1970 0:00:00.
double unchecked_posix_time = rounded_to_second.ToJSTime() / 1000;
if (unchecked_posix_time > INT_MAX || unchecked_posix_time < 0) {
return 0;
}
// Because _USE_32BIT_TIME_T is defined, time_t is a 32-bit int.
time_t posix_time = static_cast<time_t>(unchecked_posix_time);
// Convert to local time, as struct with fields for day, hour, year, etc.
tm posix_local_time_struct;
if (localtime_s(&posix_local_time_struct, &posix_time)) return 0;
if (posix_local_time_struct.tm_isdst > 0) {
return (cache->tzinfo_.Bias + cache->tzinfo_.DaylightBias) * -kMsPerMinute;
} else if (posix_local_time_struct.tm_isdst == 0) {
return (cache->tzinfo_.Bias + cache->tzinfo_.StandardBias) * -kMsPerMinute;
} else {
return cache->tzinfo_.Bias * -kMsPerMinute;
}
} }
......
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