Merge pull request #12521 from lioncash/reent

Core: Make use of reentrant time utilities where applicable
This commit is contained in:
Admiral H. Curtiss 2024-01-26 18:55:26 +01:00 committed by GitHub
commit b09b59c125
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 24 additions and 31 deletions

View File

@ -5,6 +5,8 @@
#include <string> #include <string>
#include <fmt/chrono.h>
#include "Common/CommonTypes.h" #include "Common/CommonTypes.h"
#include "Core/HW/EXI/EXI_DeviceIPL.h" #include "Core/HW/EXI/EXI_DeviceIPL.h"
#include "Core/HW/Memmap.h" #include "Core/HW/Memmap.h"
@ -93,10 +95,10 @@ u64 NetKDTimeDevice::GetAdjustedUTC() const
time_t dst_diff{}; time_t dst_diff{};
const time_t current_time = CEXIIPL::GetEmulatedTime(GetSystem(), CEXIIPL::UNIX_EPOCH); const time_t current_time = CEXIIPL::GetEmulatedTime(GetSystem(), CEXIIPL::UNIX_EPOCH);
tm* const gm_time = gmtime(&current_time); tm gm_time = fmt::gmtime(current_time);
const u32 emulated_time = mktime(gm_time); const u32 emulated_time = mktime(&gm_time);
if (gm_time->tm_isdst == 1) if (gm_time.tm_isdst == 1)
dst_diff = 3600; dst_diff = 3600;
return u64(s64(emulated_time) + utcdiff - dst_diff); return u64(s64(emulated_time) + utcdiff - dst_diff);
@ -108,10 +110,10 @@ void NetKDTimeDevice::SetAdjustedUTC(u64 wii_utc)
time_t dst_diff{}; time_t dst_diff{};
const time_t current_time = CEXIIPL::GetEmulatedTime(GetSystem(), CEXIIPL::UNIX_EPOCH); const time_t current_time = CEXIIPL::GetEmulatedTime(GetSystem(), CEXIIPL::UNIX_EPOCH);
tm* const gm_time = gmtime(&current_time); tm gm_time = fmt::gmtime(current_time);
const u32 emulated_time = mktime(gm_time); const u32 emulated_time = mktime(&gm_time);
if (gm_time->tm_isdst == 1) if (gm_time.tm_isdst == 1)
dst_diff = 3600; dst_diff = 3600;
utcdiff = s64(emulated_time - wii_utc - dst_diff); utcdiff = s64(emulated_time - wii_utc - dst_diff);

View File

@ -7,8 +7,8 @@
#include <array> #include <array>
#include <cctype> #include <cctype>
#include <cstring> #include <cstring>
#include <iomanip>
#include <iterator> #include <iterator>
#include <locale>
#include <mbedtls/config.h> #include <mbedtls/config.h>
#include <mbedtls/md.h> #include <mbedtls/md.h>
#include <mutex> #include <mutex>
@ -18,6 +18,7 @@
#include <variant> #include <variant>
#include <vector> #include <vector>
#include <fmt/chrono.h>
#include <fmt/format.h> #include <fmt/format.h>
#include "Common/Assert.h" #include "Common/Assert.h"
@ -160,21 +161,19 @@ std::string MovieManager::GetInputDisplay()
} }
// NOTE: GPU Thread // NOTE: GPU Thread
std::string MovieManager::GetRTCDisplay() std::string MovieManager::GetRTCDisplay() const
{ {
using ExpansionInterface::CEXIIPL; using ExpansionInterface::CEXIIPL;
const time_t current_time = const time_t current_time = CEXIIPL::GetEmulatedTime(m_system, CEXIIPL::UNIX_EPOCH);
CEXIIPL::GetEmulatedTime(Core::System::GetInstance(), CEXIIPL::UNIX_EPOCH); const tm gm_time = fmt::gmtime(current_time);
const tm* const gm_time = gmtime(&current_time);
std::ostringstream format_time; // Use current locale for formatting time, as fmt is locale-agnostic by default.
format_time << std::put_time(gm_time, "Date/Time: %c\n"); return fmt::format(std::locale{""}, "Date/Time: {:%c}", gm_time);
return format_time.str();
} }
// NOTE: GPU Thread // NOTE: GPU Thread
std::string MovieManager::GetRerecords() std::string MovieManager::GetRerecords() const
{ {
if (IsMovieActive()) if (IsMovieActive())
return fmt::format("Rerecords: {}", m_rerecords); return fmt::format("Rerecords: {}", m_rerecords);

View File

@ -222,8 +222,8 @@ public:
WiimoteEmu::ExtensionNumber ext, const WiimoteEmu::EncryptionKey& key); WiimoteEmu::ExtensionNumber ext, const WiimoteEmu::EncryptionKey& key);
std::string GetInputDisplay(); std::string GetInputDisplay();
std::string GetRTCDisplay(); std::string GetRTCDisplay() const;
std::string GetRerecords(); std::string GetRerecords() const;
private: private:
void GetSettings(); void GetSettings();

View File

@ -7,6 +7,7 @@
#include <atomic> #include <atomic>
#include <condition_variable> #include <condition_variable>
#include <filesystem> #include <filesystem>
#include <locale>
#include <map> #include <map>
#include <memory> #include <memory>
#include <mutex> #include <mutex>
@ -15,6 +16,7 @@
#include <utility> #include <utility>
#include <vector> #include <vector>
#include <fmt/chrono.h>
#include <fmt/format.h> #include <fmt/format.h>
#include <lz4.h> #include <lz4.h>
@ -278,21 +280,11 @@ static double GetSystemTimeAsDouble()
static std::string SystemTimeAsDoubleToString(double time) static std::string SystemTimeAsDoubleToString(double time)
{ {
// revert adjustments from GetSystemTimeAsDouble() to get a normal Unix timestamp again // revert adjustments from GetSystemTimeAsDouble() to get a normal Unix timestamp again
time_t seconds = static_cast<time_t>(time) + DOUBLE_TIME_OFFSET; const time_t seconds = static_cast<time_t>(time) + DOUBLE_TIME_OFFSET;
errno = 0; const tm local_time = fmt::localtime(seconds);
tm* local_time = localtime(&seconds);
if (errno != 0 || !local_time)
return "";
#ifdef _WIN32 // fmt is locale agnostic by default, so explicitly use current locale.
wchar_t tmp[32] = {}; return fmt::format(std::locale{""}, "{:%x %X}", local_time);
wcsftime(tmp, std::size(tmp), L"%x %X", local_time);
return WStringToUTF8(tmp);
#else
char tmp[32] = {};
strftime(tmp, sizeof(tmp), "%x %X", local_time);
return tmp;
#endif
} }
static std::string MakeStateFilename(int number); static std::string MakeStateFilename(int number);