DolphinWX: Propagate event to refresh the game list

Prior to this refactor, certain options would cause the game list to refresh when the config modal dialog is closed (such as adding a folder to the path list). This restores that functionality.
This commit is contained in:
Lioncash 2015-03-18 20:33:20 -04:00
parent febd3909c6
commit b459a8ec61
4 changed files with 22 additions and 7 deletions

View File

@ -19,15 +19,20 @@
#include "DolphinWX/Config/PathConfigPane.h" #include "DolphinWX/Config/PathConfigPane.h"
#include "DolphinWX/Config/WiiConfigPane.h" #include "DolphinWX/Config/WiiConfigPane.h"
// Sent by child panes to signify that the game list should
// be updated when this modal dialog closes.
wxDEFINE_EVENT(wxDOLPHIN_CFG_REFRESH_LIST, wxCommandEvent);
CConfigMain::CConfigMain(wxWindow* parent, wxWindowID id, const wxString& title, CConfigMain::CConfigMain(wxWindow* parent, wxWindowID id, const wxString& title,
const wxPoint& position, const wxSize& size, long style) const wxPoint& position, const wxSize& size, long style)
: wxDialog(parent, id, title, position, size, style) : wxDialog(parent, id, title, position, size, style)
{ {
// Control refreshing of the ISOs list // Control refreshing of the ISOs list
bRefreshList = false; m_refresh_game_list_on_close = false;
Bind(wxEVT_CLOSE_WINDOW, &CConfigMain::OnClose, this); Bind(wxEVT_CLOSE_WINDOW, &CConfigMain::OnClose, this);
Bind(wxEVT_BUTTON, &CConfigMain::OnOk, this, wxID_OK); Bind(wxEVT_BUTTON, &CConfigMain::OnOk, this, wxID_OK);
Bind(wxDOLPHIN_CFG_REFRESH_LIST, &CConfigMain::OnSetRefreshGameListOnClose, this);
CreateGUIControls(); CreateGUIControls();
} }
@ -79,7 +84,7 @@ void CConfigMain::CreateGUIControls()
void CConfigMain::OnClose(wxCloseEvent& WXUNUSED(event)) void CConfigMain::OnClose(wxCloseEvent& WXUNUSED(event))
{ {
EndModal((bRefreshList) ? wxID_OK : wxID_CANCEL); EndModal((m_refresh_game_list_on_close) ? wxID_OK : wxID_CANCEL);
} }
void CConfigMain::OnOk(wxCommandEvent& WXUNUSED(event)) void CConfigMain::OnOk(wxCommandEvent& WXUNUSED(event))
@ -89,3 +94,8 @@ void CConfigMain::OnOk(wxCommandEvent& WXUNUSED(event))
// Save the config. Dolphin crashes too often to only save the settings on closing // Save the config. Dolphin crashes too often to only save the settings on closing
SConfig::GetInstance().SaveSettings(); SConfig::GetInstance().SaveSettings();
} }
void CConfigMain::OnSetRefreshGameListOnClose(wxCommandEvent& WXUNUSED(event))
{
m_refresh_game_list_on_close = true;
}

View File

@ -11,6 +11,8 @@ class wxNotebook;
class wxPanel; class wxPanel;
class wxWindow; class wxWindow;
wxDECLARE_EVENT(wxDOLPHIN_CFG_REFRESH_LIST, wxCommandEvent);
class CConfigMain : public wxDialog class CConfigMain : public wxDialog
{ {
public: public:
@ -40,8 +42,9 @@ private:
void CreateGUIControls(); void CreateGUIControls();
void OnClose(wxCloseEvent& event); void OnClose(wxCloseEvent& event);
void OnOk(wxCommandEvent& event); void OnOk(wxCommandEvent& event);
void OnSetRefreshGameListOnClose(wxCommandEvent& event);
wxNotebook* Notebook; wxNotebook* Notebook;
bool bRefreshList; bool m_refresh_game_list_on_close;
}; };

View File

@ -20,6 +20,7 @@
#include "Core/HW/EXI.h" #include "Core/HW/EXI.h"
#include "Core/HW/GCMemcard.h" #include "Core/HW/GCMemcard.h"
#include "DolphinWX/WxUtils.h" #include "DolphinWX/WxUtils.h"
#include "DolphinWX/Config/ConfigMain.h"
#include "DolphinWX/Config/GameCubeConfigPane.h" #include "DolphinWX/Config/GameCubeConfigPane.h"
#define DEV_NONE_STR _trans("<Nothing>") #define DEV_NONE_STR _trans("<Nothing>")
@ -206,7 +207,7 @@ void GameCubeConfigPane::OnSystemLanguageChange(wxCommandEvent& event)
{ {
SConfig::GetInstance().m_LocalCoreStartupParameter.SelectedLanguage = m_system_lang_choice->GetSelection(); SConfig::GetInstance().m_LocalCoreStartupParameter.SelectedLanguage = m_system_lang_choice->GetSelection();
// TODO: Signal back to config_main to set bRefreshList to true. AddPendingEvent(wxCommandEvent(wxDOLPHIN_CFG_REFRESH_LIST));
} }
void GameCubeConfigPane::OnSkipBiosCheckBoxChanged(wxCommandEvent& event) void GameCubeConfigPane::OnSkipBiosCheckBoxChanged(wxCommandEvent& event)

View File

@ -19,6 +19,7 @@
#include "DolphinWX/Frame.h" #include "DolphinWX/Frame.h"
#include "DolphinWX/Main.h" #include "DolphinWX/Main.h"
#include "DolphinWX/WxUtils.h" #include "DolphinWX/WxUtils.h"
#include "DolphinWX/Config/ConfigMain.h"
#include "DolphinWX/Config/PathConfigPane.h" #include "DolphinWX/Config/PathConfigPane.h"
PathConfigPane::PathConfigPane(wxWindow* panel, wxWindowID id) PathConfigPane::PathConfigPane(wxWindow* panel, wxWindowID id)
@ -118,7 +119,7 @@ void PathConfigPane::OnRecursiveISOCheckBoxChanged(wxCommandEvent& event)
{ {
SConfig::GetInstance().m_RecursiveISOFolder = m_recursive_iso_paths_checkbox->IsChecked(); SConfig::GetInstance().m_RecursiveISOFolder = m_recursive_iso_paths_checkbox->IsChecked();
// TODO: Fire an event back to ConfigMain, setting bRefreshList to true. AddPendingEvent(wxCommandEvent(wxDOLPHIN_CFG_REFRESH_LIST));
} }
void PathConfigPane::OnAddISOPath(wxCommandEvent& event) void PathConfigPane::OnAddISOPath(wxCommandEvent& event)
@ -134,7 +135,7 @@ void PathConfigPane::OnAddISOPath(wxCommandEvent& event)
} }
else else
{ {
// TODO: Send event back to ConfigMain setting bRefreshList to true. AddPendingEvent(wxCommandEvent(wxDOLPHIN_CFG_REFRESH_LIST));
m_iso_paths_listbox->Append(dialog.GetPath()); m_iso_paths_listbox->Append(dialog.GetPath());
} }
} }
@ -144,7 +145,7 @@ void PathConfigPane::OnAddISOPath(wxCommandEvent& event)
void PathConfigPane::OnRemoveISOPath(wxCommandEvent& event) void PathConfigPane::OnRemoveISOPath(wxCommandEvent& event)
{ {
// TODO: Set event back to ConfigMain to set bRefreshList to true. AddPendingEvent(wxCommandEvent(wxDOLPHIN_CFG_REFRESH_LIST));
m_iso_paths_listbox->Delete(m_iso_paths_listbox->GetSelection()); m_iso_paths_listbox->Delete(m_iso_paths_listbox->GetSelection());
// This seems to not be activated on Windows when it should be. wxw bug? // This seems to not be activated on Windows when it should be. wxw bug?