From 677640ac52c2ea0c08aa82758ebfaa8c9fe9d10b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?L=C3=A9o=20Lam?= Date: Sat, 27 May 2017 12:15:07 +0200 Subject: [PATCH 1/2] Drop m_LastFilename This makes it hard to support different boot params for different boot types. We should not be making the assumption that Dolphin will always be booting directly from a file (and in particular, only using a string). It's incompatible with future changes that will allow Dolphin to boot a NAND title properly from well, the NAND, as opposed to booting from WADs. (And no, treating the title TMD as a "bootable" path doesn't count. Especially when that approach won't work with NAND images or IOS LLE.) And it's confusing to expose this functionality from the UI. It's pretty bad for UX to change the play button's behaviour depending on whether the user has launched something before, configured a default file to boot, added a directory to their game paths. --- Source/Core/Core/BootManager.cpp | 1 - Source/Core/Core/ConfigManager.cpp | 2 -- Source/Core/Core/ConfigManager.h | 3 --- Source/Core/DolphinWX/FrameTools.cpp | 21 ++------------------- 4 files changed, 2 insertions(+), 25 deletions(-) diff --git a/Source/Core/Core/BootManager.cpp b/Source/Core/Core/BootManager.cpp index 295ac883de..5e18e4a1fc 100644 --- a/Source/Core/Core/BootManager.cpp +++ b/Source/Core/Core/BootManager.cpp @@ -224,7 +224,6 @@ bool BootCore(const std::string& filename, SConfig::EBootBS2 type) StartUp.m_BootType = SConfig::BOOT_ISO; StartUp.m_strFilename = filename; - StartUp.m_LastFilename = filename; StartUp.SaveSettings(); StartUp.bRunCompareClient = false; StartUp.bRunCompareServer = false; diff --git a/Source/Core/Core/ConfigManager.cpp b/Source/Core/Core/ConfigManager.cpp index 0a1917791d..0eee3bd5e7 100644 --- a/Source/Core/Core/ConfigManager.cpp +++ b/Source/Core/Core/ConfigManager.cpp @@ -109,7 +109,6 @@ void SConfig::SaveGeneralSettings(IniFile& ini) IniFile::Section* general = ini.GetOrCreateSection("General"); // General - general->Set("LastFilename", m_LastFilename); general->Set("ShowLag", m_ShowLag); general->Set("ShowFrameCount", m_ShowFrameCount); @@ -418,7 +417,6 @@ void SConfig::LoadGeneralSettings(IniFile& ini) { IniFile::Section* general = ini.GetOrCreateSection("General"); - general->Get("LastFilename", &m_LastFilename); general->Get("ShowLag", &m_ShowLag, false); general->Get("ShowFrameCount", &m_ShowFrameCount, false); #ifdef USE_GDBSTUB diff --git a/Source/Core/Core/ConfigManager.h b/Source/Core/Core/ConfigManager.h index 75b8526b75..be01c9c23d 100644 --- a/Source/Core/Core/ConfigManager.h +++ b/Source/Core/Core/ConfigManager.h @@ -58,9 +58,6 @@ struct SConfig : NonCopyable bool m_WiimoteContinuousScanning; bool m_WiimoteEnableSpeaker; - // name of the last used filename - std::string m_LastFilename; - // ISO folder std::vector m_ISOFolder; bool m_RecursiveISOFolder; diff --git a/Source/Core/DolphinWX/FrameTools.cpp b/Source/Core/DolphinWX/FrameTools.cpp index 0ba143172f..7f538563b5 100644 --- a/Source/Core/DolphinWX/FrameTools.cpp +++ b/Source/Core/DolphinWX/FrameTools.cpp @@ -309,16 +309,8 @@ void CFrame::BootGame(const std::string& filename) } else { - if (!SConfig::GetInstance().m_LastFilename.empty() && - File::Exists(SConfig::GetInstance().m_LastFilename)) - { - bootfile = SConfig::GetInstance().m_LastFilename; - } - else - { - m_game_list_ctrl->BrowseForDirectory(); - return; - } + m_game_list_ctrl->BrowseForDirectory(); + return; } } if (!bootfile.empty()) @@ -1550,15 +1542,6 @@ void CFrame::UpdateGUI() GetMenuBar()->FindItem(IDM_RECORD)->Enable(); GetMenuBar()->FindItem(IDM_PLAY_RECORD)->Enable(); } - // Prepare to load last selected file, enable play button - else if (!SConfig::GetInstance().m_LastFilename.empty() && - File::Exists(SConfig::GetInstance().m_LastFilename)) - { - GetToolBar()->EnableTool(IDM_PLAY, true); - GetMenuBar()->FindItem(IDM_PLAY)->Enable(); - GetMenuBar()->FindItem(IDM_RECORD)->Enable(); - GetMenuBar()->FindItem(IDM_PLAY_RECORD)->Enable(); - } else { // No game has been selected yet, disable play button From 6e02af1b34345362038734ea883458388ae3adde Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?L=C3=A9o=20Lam?= Date: Sat, 3 Jun 2017 18:08:50 +0200 Subject: [PATCH 2/2] Core: Remove unneeded config save We don't touch the user config during booting, so there is nothing to manually save. --- Source/Core/Core/BootManager.cpp | 1 - 1 file changed, 1 deletion(-) diff --git a/Source/Core/Core/BootManager.cpp b/Source/Core/Core/BootManager.cpp index 5e18e4a1fc..75276fb40b 100644 --- a/Source/Core/Core/BootManager.cpp +++ b/Source/Core/Core/BootManager.cpp @@ -224,7 +224,6 @@ bool BootCore(const std::string& filename, SConfig::EBootBS2 type) StartUp.m_BootType = SConfig::BOOT_ISO; StartUp.m_strFilename = filename; - StartUp.SaveSettings(); StartUp.bRunCompareClient = false; StartUp.bRunCompareServer = false;