| // Copyright 2017 the V8 project authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef V8_BASE_TIMEZONE_CACHE_H_ |
| #define V8_BASE_TIMEZONE_CACHE_H_ |
| |
| namespace v8 { |
| namespace base { |
| |
| class TimezoneCache { |
| public: |
| // Short name of the local timezone (e.g., EST) |
| virtual const char* LocalTimezone(double time_ms) = 0; |
| |
| // ES #sec-daylight-saving-time-adjustment |
| // Daylight Saving Time Adjustment |
| virtual double DaylightSavingsOffset(double time_ms) = 0; |
| |
| // ES #sec-local-time-zone-adjustment |
| // Local Time Zone Adjustment |
| // |
| // https://github.com/tc39/ecma262/pull/778 |
| virtual double LocalTimeOffset(double time_ms, bool is_utc) = 0; |
| |
| /** |
| * Time zone redetection indicator for Clear function. |
| * |
| * kSkip indicates host time zone doesn't have to be redetected. |
| * kRedetect indicates host time zone should be redetected, and used to set |
| * the default time zone. |
| * |
| * The host time zone detection may require file system access or similar |
| * operations unlikely to be available inside a sandbox. If v8 is run inside a |
| * sandbox, the host time zone has to be detected outside the sandbox |
| * separately. |
| */ |
| enum class TimeZoneDetection { kSkip, kRedetect }; |
| |
| // Called when the local timezone changes |
| virtual void Clear(TimeZoneDetection time_zone_detection) = 0; |
| |
| // Called when tearing down the isolate |
| virtual ~TimezoneCache() = default; |
| }; |
| |
| } // namespace base |
| } // namespace v8 |
| |
| #endif // V8_BASE_TIMEZONE_CACHE_H_ |