HostInterface: Share settings between SDL and Qt frontends

This commit is contained in:
Connor McLaughlin 2020-01-24 14:51:03 +10:00
parent 2c3a0a6af9
commit b3db3a1cc0
5 changed files with 14 additions and 8 deletions

View File

@ -462,7 +462,7 @@ void HostInterface::SetUserDirectory()
} }
} }
std::string HostInterface::GetUserDirectoryRelativePath(const char* format, ...) std::string HostInterface::GetUserDirectoryRelativePath(const char* format, ...) const
{ {
std::va_list ap; std::va_list ap;
va_start(ap, format); va_start(ap, format);
@ -480,6 +480,11 @@ std::string HostInterface::GetUserDirectoryRelativePath(const char* format, ...)
} }
} }
std::string HostInterface::GetSettingsFileName() const
{
return GetUserDirectoryRelativePath("settings.ini");
}
void HostInterface::RunFrame() void HostInterface::RunFrame()
{ {
m_frame_timer.Reset(); m_frame_timer.Reset();

View File

@ -65,7 +65,7 @@ public:
const std::string& GetUserDirectory() const { return m_user_directory; } const std::string& GetUserDirectory() const { return m_user_directory; }
/// Returns a path relative to the user directory. /// Returns a path relative to the user directory.
std::string GetUserDirectoryRelativePath(const char* format, ...); std::string GetUserDirectoryRelativePath(const char* format, ...) const;
protected: protected:
using ThrottleClock = std::chrono::steady_clock; using ThrottleClock = std::chrono::steady_clock;
@ -90,6 +90,9 @@ protected:
void SetUserDirectory(); void SetUserDirectory();
/// Returns the path of the settings file.
std::string GetSettingsFileName() const;
void RunFrame(); void RunFrame();
/// Throttles the system, i.e. sleeps until it's time to execute the next frame. /// Throttles the system, i.e. sleeps until it's time to execute the next frame.

View File

@ -22,7 +22,7 @@ Log_SetChannel(QtHostInterface);
#endif #endif
QtHostInterface::QtHostInterface(QObject* parent) QtHostInterface::QtHostInterface(QObject* parent)
: QObject(parent), m_qsettings("duckstation-qt.ini", QSettings::IniFormat) : QObject(parent), HostInterface(), m_qsettings(QString::fromStdString(GetSettingsFileName()), QSettings::IniFormat)
{ {
checkSettings(); checkSettings();
createGameList(); createGameList();

View File

@ -25,7 +25,7 @@ Log_SetChannel(SDLHostInterface);
#include <mmsystem.h> #include <mmsystem.h>
#endif #endif
SDLHostInterface::SDLHostInterface() : m_settings_filename("settings.ini") SDLHostInterface::SDLHostInterface()
{ {
// Increase timer/sleep resolution since we use it for throttling. // Increase timer/sleep resolution since we use it for throttling.
#ifdef WIN32 #ifdef WIN32
@ -152,7 +152,7 @@ void SDLHostInterface::CreateAudioStream()
void SDLHostInterface::SaveSettings() void SDLHostInterface::SaveSettings()
{ {
SDLSettingsInterface si(m_settings_filename.c_str()); SDLSettingsInterface si(GetSettingsFileName().c_str());
m_settings.Save(si); m_settings.Save(si);
} }
@ -238,7 +238,7 @@ std::unique_ptr<SDLHostInterface> SDLHostInterface::Create(const char* filename
std::unique_ptr<SDLHostInterface> intf = std::make_unique<SDLHostInterface>(); std::unique_ptr<SDLHostInterface> intf = std::make_unique<SDLHostInterface>();
// Settings need to be loaded prior to creating the window for OpenGL bits. // Settings need to be loaded prior to creating the window for OpenGL bits.
SDLSettingsInterface si(intf->m_settings_filename.c_str()); SDLSettingsInterface si(intf->GetSettingsFileName().c_str());
intf->m_settings.Load(si); intf->m_settings.Load(si);
if (!intf->CreateSDLWindow()) if (!intf->CreateSDLWindow())

View File

@ -128,8 +128,6 @@ private:
SDL_Window* m_window = nullptr; SDL_Window* m_window = nullptr;
std::unique_ptr<HostDisplayTexture> m_app_icon_texture; std::unique_ptr<HostDisplayTexture> m_app_icon_texture;
std::string m_settings_filename;
KeyboardControllerActionMap m_keyboard_button_mapping; KeyboardControllerActionMap m_keyboard_button_mapping;
std::map<int, ControllerData> m_sdl_controllers; std::map<int, ControllerData> m_sdl_controllers;