Compare commits

..

1 Commits

Author SHA1 Message Date
DeaTh-G 460bc583a5 Respect update check timeout without the same session too 2026-02-01 19:35:54 +01:00
4 changed files with 9 additions and 27 deletions
+3
View File
@@ -1,5 +1,8 @@
#pragma once
// 6 hour long timeout between checks.
static constexpr double g_timeBetweenUpdateChecksInSeconds = 6 * 60 * 60;
struct UpdateChecker
{
enum class Result
+3 -3
View File
@@ -307,11 +307,11 @@ int main(int argc, char *argv[])
}
#endif
// Check the time since the last time an update was checked. Store the new time if the difference is more than six hours.
constexpr double TimeBetweenUpdateChecksInSeconds = 6 * 60 * 60;
// Check the time since the last time an update was checked.
// Store the new time if the difference is more than g_timeBetweenUpdateChecksInSeconds hours.
time_t timeNow = std::time(nullptr);
double timeDifferenceSeconds = difftime(timeNow, Config::LastChecked);
if (timeDifferenceSeconds > TimeBetweenUpdateChecksInSeconds)
if (timeDifferenceSeconds > g_timeBetweenUpdateChecksInSeconds)
{
UpdateChecker::initialize();
UpdateChecker::start();
@@ -129,7 +129,9 @@ PPC_FUNC(sub_822C55B0)
void PressStartSaveLoadThreadMidAsmHook()
{
if (UpdateChecker::check() == UpdateChecker::Result::UpdateAvailable)
time_t timeNow = std::time(nullptr);
double timeDifferenceSeconds = difftime(timeNow, Config::LastChecked);
if (UpdateChecker::check() == UpdateChecker::Result::UpdateAvailable && timeDifferenceSeconds > g_timeBetweenUpdateChecksInSeconds)
{
g_updateAvailableMessageOpen = true;
g_updateAvailableMessageOpen.wait(true);
-23
View File
@@ -141,26 +141,3 @@ PPC_FUNC(sub_82E38650)
__imp__sub_82E38650(ctx, base);
}
// Part of the building right after exiting the tunnel after the drift turn after the first checkpoint
// is placed on an transparent mesh slot. This somehow works. Except on high-performance Windows machines,
// hinting at the fact that its related to some scheduler issue with the asset loading.
// We can fix it by detecting the asset runtime, and combining the opaque and transparent mesh slots by
// using the name offset field on the mesh group as an additional value in the array and shifting the
// opaque mesh slot's offset back by one and then correcting the offset table for this change.
// Hedgehog::Mirage::CTerrainModelData::Make
PPC_FUNC_IMPL(__imp__sub_82E39618);
PPC_FUNC(sub_82E39618)
{
if (ctx.r5.u32 == 0xA470 && XXH3_64bits(base + ctx.r4.u32, ctx.r5.u32) == 0x8474C14C113626D2)
{
PPC_STORE_U32(ctx.r4.u32 + 0x28, 7);
PPC_STORE_U32(ctx.r4.u32 + 0x2C, 0x38);
PPC_STORE_U32(ctx.r4.u32 + 0x30, 0);
PPC_STORE_U32(ctx.r4.u32 + 0x50, 0x88C4);
PPC_STORE_U32(ctx.r4.u32 + 0xA438, 0x38);
}
__imp__sub_82E39618(ctx, base);
}