diff --git a/Source/Core/Common/Timer.cpp b/Source/Core/Common/Timer.cpp index fb81164390..91381eebd3 100644 --- a/Source/Core/Common/Timer.cpp +++ b/Source/Core/Common/Timer.cpp @@ -7,6 +7,7 @@ #ifdef _WIN32 #include +#include #include #else #include @@ -67,12 +68,10 @@ u64 Timer::ElapsedMs() const u64 Timer::GetLocalTimeSinceJan1970() { -#ifdef _MSC_VER - std::chrono::zoned_seconds seconds( - std::chrono::current_zone(), - std::chrono::time_point_cast(std::chrono::system_clock::now())); - return seconds.get_local_time().time_since_epoch().count(); -#else + // TODO Would really, really like to use std::chrono here, but Windows did not support + // std::chrono::current_zone() until 19H1, and other compilers don't even provide support for + // timezone-related parts of chrono. Someday! + // see https://bugs.dolphin-emu.org/issues/13007#note-4 time_t sysTime, tzDiff, tzDST; time(&sysTime); tm* gmTime = localtime(&sysTime); @@ -88,7 +87,6 @@ u64 Timer::GetLocalTimeSinceJan1970() tzDiff = sysTime - mktime(gmTime); return static_cast(sysTime + tzDiff + tzDST); -#endif } void Timer::IncreaseResolution()