Merge pull request #12256 from malleoz/savestate_read_header_fix

Core: Fix UI slowdown for savestate timestamp reads
This commit is contained in:
Admiral H. Curtiss 2023-10-30 10:45:14 +01:00 committed by GitHub
commit 045868bbb4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 9 additions and 2 deletions

View File

@ -560,7 +560,8 @@ static bool GetVersionFromLZO(StateHeader& header, File::IOFile& f)
return true;
}
static bool ReadStateHeaderFromFile(StateHeader& header, File::IOFile& f)
static bool ReadStateHeaderFromFile(StateHeader& header, File::IOFile& f,
bool get_version_header = true)
{
if (!f.IsOpen())
{
@ -574,6 +575,11 @@ static bool ReadStateHeaderFromFile(StateHeader& header, File::IOFile& f)
return false;
}
// Bail out if we only care for retrieving the legacy header.
// This is the case with ReadHeader() calls.
if (!get_version_header)
return true;
if (header.legacy_header.lzo_size != 0)
{
// Parse out version from legacy LZO compressed states
@ -608,7 +614,8 @@ bool ReadHeader(const std::string& filename, StateHeader& header)
std::lock_guard lk(s_save_thread_mutex);
File::IOFile f(filename, "rb");
return ReadStateHeaderFromFile(header, f);
bool get_version_header = false;
return ReadStateHeaderFromFile(header, f, get_version_header);
}
std::string GetInfoStringOfSlot(int slot, bool translate)