Merge pull request #12521 from lioncash/reent
Core: Make use of reentrant time utilities where applicable
This commit is contained in:
commit
b09b59c125
|
@ -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(¤t_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(¤t_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);
|
||||||
|
|
|
@ -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(¤t_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);
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue