Merge pull request #12380 from flodavid/save-profile
Save configuration profile name used by players
This commit is contained in:
		@@ -21,7 +21,7 @@ void AndroidConfig::ReloadAllValues() {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void AndroidConfig::SaveAllValues() {
 | 
					void AndroidConfig::SaveAllValues() {
 | 
				
			||||||
    Save();
 | 
					    SaveValues();
 | 
				
			||||||
    SaveAndroidValues();
 | 
					    SaveAndroidValues();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,7 @@
 | 
				
			|||||||
#include <array>
 | 
					#include <array>
 | 
				
			||||||
#include "common/fs/fs.h"
 | 
					#include "common/fs/fs.h"
 | 
				
			||||||
#include "common/fs/path_util.h"
 | 
					#include "common/fs/path_util.h"
 | 
				
			||||||
 | 
					#include "common/logging/log.h"
 | 
				
			||||||
#include "common/settings.h"
 | 
					#include "common/settings.h"
 | 
				
			||||||
#include "common/settings_common.h"
 | 
					#include "common/settings_common.h"
 | 
				
			||||||
#include "common/settings_enums.h"
 | 
					#include "common/settings_enums.h"
 | 
				
			||||||
@@ -58,6 +59,19 @@ void Config::Initialize(const std::optional<std::string> config_path) {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void Config::WriteToIni() const {
 | 
					void Config::WriteToIni() const {
 | 
				
			||||||
 | 
					    std::string config_type;
 | 
				
			||||||
 | 
					    switch (type) {
 | 
				
			||||||
 | 
					    case ConfigType::GlobalConfig:
 | 
				
			||||||
 | 
					        config_type = "Global";
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case ConfigType::PerGameConfig:
 | 
				
			||||||
 | 
					        config_type = "Game Specific";
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case ConfigType::InputProfile:
 | 
				
			||||||
 | 
					        config_type = "Input Profile";
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    LOG_INFO(Config, "Writing {} configuration to: {}", config_type, config_loc);
 | 
				
			||||||
    FILE* fp = nullptr;
 | 
					    FILE* fp = nullptr;
 | 
				
			||||||
#ifdef _WIN32
 | 
					#ifdef _WIN32
 | 
				
			||||||
    fp = _wfopen(Common::UTF8ToUTF16W(config_loc).data(), L"wb");
 | 
					    fp = _wfopen(Common::UTF8ToUTF16W(config_loc).data(), L"wb");
 | 
				
			||||||
@@ -117,10 +131,10 @@ void Config::ReadPlayerValues(const std::size_t player_index) {
 | 
				
			|||||||
        player_prefix.append("player_").append(ToString(player_index)).append("_");
 | 
					        player_prefix.append("player_").append(ToString(player_index)).append("_");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    const auto profile_name = ReadStringSetting(std::string(player_prefix).append("profile_name"));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    auto& player = Settings::values.players.GetValue()[player_index];
 | 
					    auto& player = Settings::values.players.GetValue()[player_index];
 | 
				
			||||||
    if (IsCustomConfig()) {
 | 
					    if (IsCustomConfig()) {
 | 
				
			||||||
        const auto profile_name =
 | 
					 | 
				
			||||||
            ReadStringSetting(std::string(player_prefix).append("profile_name"));
 | 
					 | 
				
			||||||
        if (profile_name.empty()) {
 | 
					        if (profile_name.empty()) {
 | 
				
			||||||
            // Use the global input config
 | 
					            // Use the global input config
 | 
				
			||||||
            player = Settings::values.players.GetValue(true)[player_index];
 | 
					            player = Settings::values.players.GetValue(true)[player_index];
 | 
				
			||||||
@@ -139,6 +153,10 @@ void Config::ReadPlayerValues(const std::size_t player_index) {
 | 
				
			|||||||
            player.controller_type = controller;
 | 
					            player.controller_type = controller;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
 | 
					        if (global) {
 | 
				
			||||||
 | 
					            auto& player_global = Settings::values.players.GetValue(true)[player_index];
 | 
				
			||||||
 | 
					            player_global.profile_name = profile_name;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        std::string connected_key = player_prefix;
 | 
					        std::string connected_key = player_prefix;
 | 
				
			||||||
        player.connected = ReadBooleanSetting(connected_key.append("connected"),
 | 
					        player.connected = ReadBooleanSetting(connected_key.append("connected"),
 | 
				
			||||||
                                              std::make_optional(player_index == 0));
 | 
					                                              std::make_optional(player_index == 0));
 | 
				
			||||||
@@ -412,6 +430,11 @@ void Config::SavePlayerValues(const std::size_t player_index) {
 | 
				
			|||||||
        std::make_optional(static_cast<u8>(Settings::ControllerType::ProController)));
 | 
					        std::make_optional(static_cast<u8>(Settings::ControllerType::ProController)));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (!player_prefix.empty() || !Settings::IsConfiguringGlobal()) {
 | 
					    if (!player_prefix.empty() || !Settings::IsConfiguringGlobal()) {
 | 
				
			||||||
 | 
					        if (global) {
 | 
				
			||||||
 | 
					            const auto& player_global = Settings::values.players.GetValue(true)[player_index];
 | 
				
			||||||
 | 
					            WriteStringSetting(std::string(player_prefix).append("profile_name"),
 | 
				
			||||||
 | 
					                               player_global.profile_name, std::make_optional(std::string("")));
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        WriteBooleanSetting(std::string(player_prefix).append("connected"), player.connected,
 | 
					        WriteBooleanSetting(std::string(player_prefix).append("connected"), player.connected,
 | 
				
			||||||
                            std::make_optional(player_index == 0));
 | 
					                            std::make_optional(player_index == 0));
 | 
				
			||||||
        WriteIntegerSetting(std::string(player_prefix).append("vibration_enabled"),
 | 
					        WriteIntegerSetting(std::string(player_prefix).append("vibration_enabled"),
 | 
				
			||||||
@@ -468,12 +491,15 @@ void Config::SaveMotionTouchValues() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
void Config::SaveValues() {
 | 
					void Config::SaveValues() {
 | 
				
			||||||
    if (global) {
 | 
					    if (global) {
 | 
				
			||||||
 | 
					        LOG_DEBUG(Config, "Saving global generic configuration values");
 | 
				
			||||||
        SaveDataStorageValues();
 | 
					        SaveDataStorageValues();
 | 
				
			||||||
        SaveDebuggingValues();
 | 
					        SaveDebuggingValues();
 | 
				
			||||||
        SaveDisabledAddOnValues();
 | 
					        SaveDisabledAddOnValues();
 | 
				
			||||||
        SaveNetworkValues();
 | 
					        SaveNetworkValues();
 | 
				
			||||||
        SaveWebServiceValues();
 | 
					        SaveWebServiceValues();
 | 
				
			||||||
        SaveMiscellaneousValues();
 | 
					        SaveMiscellaneousValues();
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        LOG_DEBUG(Config, "Saving only generic configuration values");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    SaveControlValues();
 | 
					    SaveControlValues();
 | 
				
			||||||
    SaveCoreValues();
 | 
					    SaveCoreValues();
 | 
				
			||||||
@@ -814,10 +840,6 @@ void Config::Reload() {
 | 
				
			|||||||
    SaveValues();
 | 
					    SaveValues();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void Config::Save() {
 | 
					 | 
				
			||||||
    SaveValues();
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void Config::ClearControlPlayerValues() const {
 | 
					void Config::ClearControlPlayerValues() const {
 | 
				
			||||||
    // If key is an empty string, all keys in the current group() are removed.
 | 
					    // If key is an empty string, all keys in the current group() are removed.
 | 
				
			||||||
    const char* section = Settings::TranslateCategory(Settings::Category::Controls);
 | 
					    const char* section = Settings::TranslateCategory(Settings::Category::Controls);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -51,7 +51,6 @@ protected:
 | 
				
			|||||||
    [[nodiscard]] bool IsCustomConfig() const;
 | 
					    [[nodiscard]] bool IsCustomConfig() const;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    void Reload();
 | 
					    void Reload();
 | 
				
			||||||
    void Save();
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Derived config classes must implement this so they can reload all platform-specific
 | 
					     * Derived config classes must implement this so they can reload all platform-specific
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1650,9 +1650,21 @@ void ConfigureInputPlayer::SaveProfile() {
 | 
				
			|||||||
void ConfigureInputPlayer::UpdateInputProfiles() {
 | 
					void ConfigureInputPlayer::UpdateInputProfiles() {
 | 
				
			||||||
    ui->comboProfiles->clear();
 | 
					    ui->comboProfiles->clear();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    for (const auto& profile_name : profiles->GetInputProfileNames()) {
 | 
					    // Set current profile as empty by default
 | 
				
			||||||
 | 
					    int profile_index = -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Add every available profile and search the player profile to set it as current one
 | 
				
			||||||
 | 
					    auto& current_profile = Settings::values.players.GetValue()[player_index].profile_name;
 | 
				
			||||||
 | 
					    std::vector<std::string> profile_names = profiles->GetInputProfileNames();
 | 
				
			||||||
 | 
					    std::string profile_name;
 | 
				
			||||||
 | 
					    for (size_t i = 0; i < profile_names.size(); i++) {
 | 
				
			||||||
 | 
					        profile_name = profile_names[i];
 | 
				
			||||||
        ui->comboProfiles->addItem(QString::fromStdString(profile_name));
 | 
					        ui->comboProfiles->addItem(QString::fromStdString(profile_name));
 | 
				
			||||||
 | 
					        if (current_profile == profile_name) {
 | 
				
			||||||
 | 
					            profile_index = (int)i;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    ui->comboProfiles->setCurrentIndex(-1);
 | 
					    LOG_DEBUG(Frontend, "Setting the current input profile to index {}", profile_index);
 | 
				
			||||||
 | 
					    ui->comboProfiles->setCurrentIndex(profile_index);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#include "common/fs/fs.h"
 | 
					#include "common/fs/fs.h"
 | 
				
			||||||
#include "common/fs/path_util.h"
 | 
					#include "common/fs/path_util.h"
 | 
				
			||||||
 | 
					#include "common/logging/log.h"
 | 
				
			||||||
#include "frontend_common/config.h"
 | 
					#include "frontend_common/config.h"
 | 
				
			||||||
#include "yuzu/configuration/input_profiles.h"
 | 
					#include "yuzu/configuration/input_profiles.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -113,6 +114,8 @@ bool InputProfiles::LoadProfile(const std::string& profile_name, std::size_t pla
 | 
				
			|||||||
        return false;
 | 
					        return false;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    LOG_INFO(Config, "Loading input profile `{}`", profile_name);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    map_profiles[profile_name]->ReadQtControlPlayerValues(player_index);
 | 
					    map_profiles[profile_name]->ReadQtControlPlayerValues(player_index);
 | 
				
			||||||
    return true;
 | 
					    return true;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,7 @@
 | 
				
			|||||||
// SPDX-FileCopyrightText: 2023 yuzu Emulator Project
 | 
					// SPDX-FileCopyrightText: 2023 yuzu Emulator Project
 | 
				
			||||||
// SPDX-License-Identifier: GPL-2.0-or-later
 | 
					// SPDX-License-Identifier: GPL-2.0-or-later
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "common/logging/log.h"
 | 
				
			||||||
#include "input_common/main.h"
 | 
					#include "input_common/main.h"
 | 
				
			||||||
#include "qt_config.h"
 | 
					#include "qt_config.h"
 | 
				
			||||||
#include "uisettings.h"
 | 
					#include "uisettings.h"
 | 
				
			||||||
@@ -65,7 +66,7 @@ void QtConfig::ReloadAllValues() {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void QtConfig::SaveAllValues() {
 | 
					void QtConfig::SaveAllValues() {
 | 
				
			||||||
    Save();
 | 
					    SaveValues();
 | 
				
			||||||
    SaveQtValues();
 | 
					    SaveQtValues();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -327,7 +328,10 @@ void QtConfig::ReadMultiplayerValues() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
void QtConfig::SaveQtValues() {
 | 
					void QtConfig::SaveQtValues() {
 | 
				
			||||||
    if (global) {
 | 
					    if (global) {
 | 
				
			||||||
 | 
					        LOG_DEBUG(Config, "Saving global Qt configuration values");
 | 
				
			||||||
        SaveUIValues();
 | 
					        SaveUIValues();
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        LOG_DEBUG(Config, "Saving Qt configuration values");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    SaveQtControlValues();
 | 
					    SaveQtControlValues();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -545,6 +549,7 @@ void QtConfig::ReadQtControlPlayerValues(std::size_t player_index) {
 | 
				
			|||||||
void QtConfig::SaveQtControlPlayerValues(std::size_t player_index) {
 | 
					void QtConfig::SaveQtControlPlayerValues(std::size_t player_index) {
 | 
				
			||||||
    BeginGroup(Settings::TranslateCategory(Settings::Category::Controls));
 | 
					    BeginGroup(Settings::TranslateCategory(Settings::Category::Controls));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    LOG_DEBUG(Config, "Saving players control configuration values");
 | 
				
			||||||
    SavePlayerValues(player_index);
 | 
					    SavePlayerValues(player_index);
 | 
				
			||||||
    SaveQtPlayerValues(player_index);
 | 
					    SaveQtPlayerValues(player_index);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,7 @@
 | 
				
			|||||||
#define SDL_MAIN_HANDLED
 | 
					#define SDL_MAIN_HANDLED
 | 
				
			||||||
#include <SDL.h>
 | 
					#include <SDL.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "common/logging/log.h"
 | 
				
			||||||
#include "input_common/main.h"
 | 
					#include "input_common/main.h"
 | 
				
			||||||
#include "sdl_config.h"
 | 
					#include "sdl_config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -64,7 +65,7 @@ void SdlConfig::ReloadAllValues() {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void SdlConfig::SaveAllValues() {
 | 
					void SdlConfig::SaveAllValues() {
 | 
				
			||||||
    Save();
 | 
					    SaveValues();
 | 
				
			||||||
    SaveSdlValues();
 | 
					    SaveSdlValues();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -177,6 +178,7 @@ void SdlConfig::ReadHidbusValues() {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void SdlConfig::SaveSdlValues() {
 | 
					void SdlConfig::SaveSdlValues() {
 | 
				
			||||||
 | 
					    LOG_DEBUG(Config, "Saving SDL configuration values");
 | 
				
			||||||
    SaveSdlControlValues();
 | 
					    SaveSdlControlValues();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    WriteToIni();
 | 
					    WriteToIni();
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user