mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2024-11-26 15:45:42 +00:00
IniSettingsInterface: Prevent multiple threads loading/saving at once
This commit is contained in:
parent
7134af509c
commit
1db24e8014
|
@ -4,9 +4,13 @@
|
|||
#include "common/string_util.h"
|
||||
#include <algorithm>
|
||||
#include <iterator>
|
||||
|
||||
#include <mutex>
|
||||
Log_SetChannel(INISettingsInterface);
|
||||
|
||||
// To prevent races between saving and loading settings, particularly with game settings,
|
||||
// we only allow one ini to be parsed at any point in time.
|
||||
static std::mutex s_ini_load_save_mutex;
|
||||
|
||||
INISettingsInterface::INISettingsInterface(std::string filename) : m_filename(std::move(filename)), m_ini(true, true) {}
|
||||
|
||||
INISettingsInterface::~INISettingsInterface()
|
||||
|
@ -20,6 +24,7 @@ bool INISettingsInterface::Load()
|
|||
if (m_filename.empty())
|
||||
return false;
|
||||
|
||||
std::unique_lock lock(s_ini_load_save_mutex);
|
||||
SI_Error err = SI_FAIL;
|
||||
auto fp = FileSystem::OpenManagedCFile(m_filename.c_str(), "rb");
|
||||
if (fp)
|
||||
|
@ -33,6 +38,7 @@ bool INISettingsInterface::Save()
|
|||
if (m_filename.empty())
|
||||
return false;
|
||||
|
||||
std::unique_lock lock(s_ini_load_save_mutex);
|
||||
SI_Error err = SI_FAIL;
|
||||
std::FILE* fp = FileSystem::OpenCFile(m_filename.c_str(), "wb");
|
||||
if (fp)
|
||||
|
|
Loading…
Reference in a new issue