// Copyright 2014 Citra Emulator Project // Licensed under GPLv2 or any later version // Refer to the license.txt file included. #pragma once #include #include #include #include #include #include "common/settings.h" #include "yuzu/uisettings.h" class QSettings; class Config { public: enum class ConfigType { GlobalConfig, PerGameConfig, InputProfile, }; explicit Config(const std::string& config_name = "qt-config", ConfigType config_type = ConfigType::GlobalConfig); ~Config(); void Reload(); void Save(); void ReadControlPlayerValue(std::size_t player_index); void SaveControlPlayerValue(std::size_t player_index); const std::string& GetConfigFilePath() const; static const std::array default_buttons; static const std::array default_motions; static const std::array, Settings::NativeAnalog::NumAnalogs> default_analogs; static const std::array default_stick_mod; static const std::array default_mouse_buttons; static const std::array default_keyboard_keys; static const std::array default_keyboard_mods; static const std::array default_hotkeys; private: void Initialize(const std::string& config_name); void ReadValues(); void ReadPlayerValue(std::size_t player_index); void ReadDebugValues(); void ReadKeyboardValues(); void ReadMouseValues(); void ReadTouchscreenValues(); void ReadMotionTouchValues(); // Read functions bases off the respective config section names. void ReadAudioValues(); void ReadControlValues(); void ReadCoreValues(); void ReadDataStorageValues(); void ReadDebuggingValues(); void ReadServiceValues(); void ReadDisabledAddOnValues(); void ReadMiscellaneousValues(); void ReadPathValues(); void ReadCpuValues(); void ReadRendererValues(); void ReadScreenshotValues(); void ReadShortcutValues(); void ReadSystemValues(); void ReadUIValues(); void ReadUIGamelistValues(); void ReadUILayoutValues(); void ReadWebServiceValues(); void SaveValues(); void SavePlayerValue(std::size_t player_index); void SaveDebugValues(); void SaveMouseValues(); void SaveTouchscreenValues(); void SaveMotionTouchValues(); // Save functions based off the respective config section names. void SaveAudioValues(); void SaveControlValues(); void SaveCoreValues(); void SaveDataStorageValues(); void SaveDebuggingValues(); void SaveServiceValues(); void SaveDisabledAddOnValues(); void SaveMiscellaneousValues(); void SavePathValues(); void SaveCpuValues(); void SaveRendererValues(); void SaveScreenshotValues(); void SaveShortcutValues(); void SaveSystemValues(); void SaveUIValues(); void SaveUIGamelistValues(); void SaveUILayoutValues(); void SaveWebServiceValues(); /** * Reads a setting from the qt_config. * * @param name The setting's identifier * @param default_value The value to use when the setting is not already present in the config */ QVariant ReadSetting(const QString& name) const; QVariant ReadSetting(const QString& name, const QVariant& default_value) const; /** * Only reads a setting from the qt_config if the current config is a global config, or if the * current config is a custom config and the setting is overriding the global setting. Otherwise * it does nothing. * * @param setting The variable to be modified * @param name The setting's identifier * @param default_value The value to use when the setting is not already present in the config */ template void ReadSettingGlobal(Type& setting, const QString& name, const QVariant& default_value) const; /** * Writes a setting to the qt_config. * * @param name The setting's idetentifier * @param value Value of the setting * @param default_value Default of the setting if not present in qt_config * @param use_global Specifies if the custom or global config should be in use, for custom * configs */ void WriteSetting(const QString& name, const QVariant& value); void WriteSetting(const QString& name, const QVariant& value, const QVariant& default_value); void WriteSetting(const QString& name, const QVariant& value, const QVariant& default_value, bool use_global); /** * Reads a value from the qt_config and applies it to the setting, using its label and default * value. If the config is a custom config, this will also read the global state of the setting * and apply that information to it. * * @param The setting */ template void ReadGlobalSetting(Settings::Setting& setting); /** * Sets a value to the qt_config using the setting's label and default value. If the config is a * custom config, it will apply the global state, and the custom value if needed. * * @param The setting */ template void WriteGlobalSetting(const Settings::Setting& setting); /** * Reads a value from the qt_config using the setting's label and default value and applies the * value to the setting. * * @param The setting */ template void ReadBasicSetting(Settings::BasicSetting& setting); /** Sets a value from the setting in the qt_config using the setting's label and default value. * * @param The setting */ template void WriteBasicSetting(const Settings::BasicSetting& setting); ConfigType type; std::unique_ptr qt_config; std::string qt_config_loc; bool global; }; // These metatype declarations cannot be in common/settings.h because core is devoid of QT Q_DECLARE_METATYPE(Settings::CPUAccuracy); Q_DECLARE_METATYPE(Settings::GPUAccuracy); Q_DECLARE_METATYPE(Settings::RendererBackend); Q_DECLARE_METATYPE(Settings::ShaderBackend);