mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 15:31:17 +01:00
Merge pull request #3067 from JosJuice/cheat-manager-regression
Fix Cheat Manager not saving created codes
This commit is contained in:
commit
b0dbb6ef46
@ -933,9 +933,4 @@ bool RunCode(const ARCode &arcode)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<ARCode>* GetARCodes()
|
|
||||||
{
|
|
||||||
return &arCodes;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace ActionReplay
|
} // namespace ActionReplay
|
||||||
|
@ -40,5 +40,4 @@ void UpdateActiveList();
|
|||||||
void EnableSelfLogging(bool enable);
|
void EnableSelfLogging(bool enable);
|
||||||
const std::vector<std::string> &GetSelfLog();
|
const std::vector<std::string> &GetSelfLog();
|
||||||
bool IsSelfLogging();
|
bool IsSelfLogging();
|
||||||
std::vector<ARCode>* GetARCodes();
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
@ -169,7 +169,7 @@ void CheatSearchTab::OnCreateARCodeClicked(wxCommandEvent&)
|
|||||||
|
|
||||||
const u32 address = m_search_results[idx].address | ((m_search_type_size & ~1) << 24);
|
const u32 address = m_search_results[idx].address | ((m_search_type_size & ~1) << 24);
|
||||||
|
|
||||||
CreateCodeDialog arcode_dlg(this, address, ActionReplay::GetARCodes());
|
CreateCodeDialog arcode_dlg(this, address);
|
||||||
arcode_dlg.SetExtraStyle(arcode_dlg.GetExtraStyle() & ~wxWS_EX_BLOCK_EVENTS);
|
arcode_dlg.SetExtraStyle(arcode_dlg.GetExtraStyle() & ~wxWS_EX_BLOCK_EVENTS);
|
||||||
arcode_dlg.ShowModal();
|
arcode_dlg.ShowModal();
|
||||||
}
|
}
|
||||||
|
@ -17,10 +17,9 @@
|
|||||||
// Fired when an ActionReplay code is created.
|
// Fired when an ActionReplay code is created.
|
||||||
wxDEFINE_EVENT(UPDATE_CHEAT_LIST_EVENT, wxCommandEvent);
|
wxDEFINE_EVENT(UPDATE_CHEAT_LIST_EVENT, wxCommandEvent);
|
||||||
|
|
||||||
CreateCodeDialog::CreateCodeDialog(wxWindow* const parent, const u32 address, std::vector<ActionReplay::ARCode>* _arCodes)
|
CreateCodeDialog::CreateCodeDialog(wxWindow* const parent, const u32 address)
|
||||||
: wxDialog(parent, wxID_ANY, _("Create AR Code"))
|
: wxDialog(parent, wxID_ANY, _("Create AR Code"))
|
||||||
, m_code_address(address)
|
, m_code_address(address)
|
||||||
, arCodes(_arCodes)
|
|
||||||
{
|
{
|
||||||
wxStaticText* const label_name = new wxStaticText(this, wxID_ANY, _("Name: "));
|
wxStaticText* const label_name = new wxStaticText(this, wxID_ANY, _("Name: "));
|
||||||
m_textctrl_name = new wxTextCtrl(this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxSize(256, -1));
|
m_textctrl_name = new wxTextCtrl(this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxSize(256, -1));
|
||||||
@ -89,7 +88,7 @@ void CreateCodeDialog::PressOK(wxCommandEvent& ev)
|
|||||||
{
|
{
|
||||||
CISOProperties isoprops(GameListItem(SConfig::GetInstance().m_LastFilename, std::unordered_map<std::string, std::string>()), this);
|
CISOProperties isoprops(GameListItem(SConfig::GetInstance().m_LastFilename, std::unordered_map<std::string, std::string>()), this);
|
||||||
// add the code to the isoproperties arcode list
|
// add the code to the isoproperties arcode list
|
||||||
arCodes->push_back(new_cheat);
|
isoprops.AddARCode(new_cheat);
|
||||||
// save the gameini
|
// save the gameini
|
||||||
isoprops.SaveGameConfig();
|
isoprops.SaveGameConfig();
|
||||||
isoprops.ActionReplayList_Load(); // loads the new arcodes
|
isoprops.ActionReplayList_Load(); // loads the new arcodes
|
||||||
|
@ -17,11 +17,10 @@ wxDECLARE_EVENT(UPDATE_CHEAT_LIST_EVENT, wxCommandEvent);
|
|||||||
class CreateCodeDialog final : public wxDialog
|
class CreateCodeDialog final : public wxDialog
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CreateCodeDialog(wxWindow* const parent, const u32 address, std::vector<ActionReplay::ARCode>* _arCodes);
|
CreateCodeDialog(wxWindow* const parent, const u32 address);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const u32 m_code_address;
|
const u32 m_code_address;
|
||||||
std::vector<ActionReplay::ARCode>* arCodes;
|
|
||||||
|
|
||||||
wxTextCtrl* m_textctrl_name;
|
wxTextCtrl* m_textctrl_name;
|
||||||
wxTextCtrl* m_textctrl_code;
|
wxTextCtrl* m_textctrl_code;
|
||||||
|
@ -1486,6 +1486,11 @@ void CISOProperties::ActionReplayButtonClicked(wxCommandEvent& event)
|
|||||||
RemoveCheat->Disable();
|
RemoveCheat->Disable();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CISOProperties::AddARCode(const ActionReplay::ARCode& code)
|
||||||
|
{
|
||||||
|
arCodes.emplace_back(code);
|
||||||
|
}
|
||||||
|
|
||||||
void CISOProperties::OnChangeBannerLang(wxCommandEvent& event)
|
void CISOProperties::OnChangeBannerLang(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
ChangeBannerDetails(OpenGameListItem.GetLanguages()[event.GetSelection()]);
|
ChangeBannerDetails(OpenGameListItem.GetLanguages()[event.GetSelection()]);
|
||||||
|
@ -70,9 +70,13 @@ public:
|
|||||||
|
|
||||||
bool bRefreshList;
|
bool bRefreshList;
|
||||||
|
|
||||||
|
// These are only public because of the ugly hack in CreateCodeDialog.cpp
|
||||||
void ActionReplayList_Load();
|
void ActionReplayList_Load();
|
||||||
bool SaveGameConfig();
|
bool SaveGameConfig();
|
||||||
|
|
||||||
|
// This only exists because of the ugly hack in CreateCodeDialog.cpp
|
||||||
|
void AddARCode(const ActionReplay::ARCode& code);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_EVENT_TABLE();
|
DECLARE_EVENT_TABLE();
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user