Merge pull request #8022 from spycrab/issue_11676

Qt/GameConfigWidget: Show revision specific INIs
This commit is contained in:
spycrab 2019-04-21 21:38:56 +02:00 committed by GitHub
commit fb841c75cb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -35,20 +35,17 @@ constexpr const char* DETERMINISM_AUTO_STRING = "auto";
constexpr const char* DETERMINISM_NONE_STRING = "none"; constexpr const char* DETERMINISM_NONE_STRING = "none";
constexpr const char* DETERMINISM_FAKE_COMPLETION_STRING = "fake-completion"; constexpr const char* DETERMINISM_FAKE_COMPLETION_STRING = "fake-completion";
static void PopulateTab(QTabWidget* tab, const std::string& path, std::string game_id, static void PopulateTab(QTabWidget* tab, const std::string& path, std::string& game_id,
bool read_only) u16 revision, bool read_only)
{ {
while (!game_id.empty()) for (const std::string& filename : ConfigLoaders::GetGameIniFilenames(game_id, revision))
{ {
const std::string ini_path = path + game_id + ".ini"; const std::string ini_path = path + filename;
if (File::Exists(ini_path)) if (File::Exists(ini_path))
{ {
auto* edit = auto* edit = new GameConfigEdit(nullptr, QString::fromStdString(ini_path), read_only);
new GameConfigEdit(nullptr, QString::fromStdString(path + game_id + ".ini"), read_only); tab->addTab(edit, QString::fromStdString(filename));
tab->addTab(edit, QString::fromStdString(game_id));
} }
game_id = game_id.substr(0, game_id.size() - 1);
} }
} }
@ -63,8 +60,10 @@ GameConfigWidget::GameConfigWidget(const UICommon::GameFile& game) : m_game(game
LoadSettings(); LoadSettings();
ConnectWidgets(); ConnectWidgets();
PopulateTab(m_default_tab, File::GetSysDirectory() + "GameSettings/", m_game_id, true); PopulateTab(m_default_tab, File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP, m_game_id,
PopulateTab(m_local_tab, File::GetUserPath(D_GAMESETTINGS_IDX), m_game_id, false); m_game.GetRevision(), true);
PopulateTab(m_local_tab, File::GetUserPath(D_GAMESETTINGS_IDX), m_game_id, m_game.GetRevision(),
false);
// Always give the user the opportunity to create a new INI // Always give the user the opportunity to create a new INI
if (m_local_tab->count() == 0) if (m_local_tab->count() == 0)
@ -72,7 +71,7 @@ GameConfigWidget::GameConfigWidget(const UICommon::GameFile& game) : m_game(game
auto* edit = new GameConfigEdit( auto* edit = new GameConfigEdit(
nullptr, QString::fromStdString(File::GetUserPath(D_GAMESETTINGS_IDX) + m_game_id + ".ini"), nullptr, QString::fromStdString(File::GetUserPath(D_GAMESETTINGS_IDX) + m_game_id + ".ini"),
false); false);
m_local_tab->addTab(edit, QString::fromStdString(m_game_id)); m_local_tab->addTab(edit, QString::fromStdString(m_game_id + ".ini"));
} }
} }