Merge pull request #3 from camdenorrb/fix-config

Fix config
This commit is contained in:
Camden 2024-12-14 20:23:24 -06:00 committed by GitHub
commit 387e7ae1f3
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 16 additions and 0 deletions

View file

@ -6,6 +6,7 @@
#include <algorithm>
#include <cstddef>
#include <fstream>
#include <iostream>
#include <map>
#include <string>
#include <string_view>
@ -317,12 +318,22 @@ bool IniFile::Load(const std::string& filename, bool keep_current_data)
bool IniFile::Save(const std::string& filename)
{
// Create parent directories if they don't exist
std::filesystem::path path(filename);
std::filesystem::path parentPath = path.parent_path();
if (!exists(parentPath) && !create_directories(parentPath)) {
std::cerr << "Failed to create directory: " << parentPath << std::endl;
}
std::ofstream out;
std::string temp = File::GetTempFilenameForAtomicWrite(filename);
File::OpenFStream(out, temp, std::ios::out);
if (out.fail())
{
std::cerr << "Failed to open temporary file for writing: " << temp << std::endl;
return false;
}

View file

@ -68,6 +68,11 @@ SConfig::SConfig()
LoadDefaults();
// Make sure we have log manager
LoadSettings();
// Check if config exists before saving
if (!File::Exists(File::GetUserPath(F_DOLPHINCONFIG_IDX))) {
SaveSettings();
}
}
void SConfig::Init()