Make PatchAddEdit complain and not modify entry if fields are invalid instead of just filling in zeros. Fixes issue 4291.

git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7672 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
Shawn Hoffman 2011-07-09 21:00:30 +00:00
parent d9ad549349
commit 2b9b4a3306
5 changed files with 68 additions and 11 deletions

View File

@ -130,6 +130,9 @@ bool TryParse(const std::string &str, u32 *const output)
if (!endptr || *endptr) if (!endptr || *endptr)
return false; return false;
if (value == ULONG_MAX && errno == ERANGE)
return false;
*output = value; *output = value;
return true; return true;
} }

View File

@ -59,6 +59,7 @@ std::vector<std::string> discList;
void LoadPatchSection(const char *section, std::vector<Patch> &patches, IniFile &ini) void LoadPatchSection(const char *section, std::vector<Patch> &patches, IniFile &ini)
{ {
std::vector<std::string> lines; std::vector<std::string> lines;
if (!ini.GetLines(section, lines)) if (!ini.GetLines(section, lines))
return; return;
@ -67,12 +68,14 @@ void LoadPatchSection(const char *section, std::vector<Patch> &patches, IniFile
for (std::vector<std::string>::const_iterator iter = lines.begin(); iter != lines.end(); ++iter) for (std::vector<std::string>::const_iterator iter = lines.begin(); iter != lines.end(); ++iter)
{ {
std::string line = *iter; std::string line = *iter;
if (line.size()) if (line.size())
{ {
if (line[0] == '+' || line[0] == '$') if (line[0] == '+' || line[0] == '$')
{ {
// Take care of the previous code // Take care of the previous code
if (currentPatch.name.size()) patches.push_back(currentPatch); if (currentPatch.name.size())
patches.push_back(currentPatch);
currentPatch.entries.clear(); currentPatch.entries.clear();
// Set active and name // Set active and name
@ -85,12 +88,15 @@ void LoadPatchSection(const char *section, std::vector<Patch> &patches, IniFile
} }
std::string::size_type loc = line.find_first_of('=', 0); std::string::size_type loc = line.find_first_of('=', 0);
if (loc != std::string::npos) if (loc != std::string::npos)
line[loc] = ':'; line[loc] = ':';
std::vector<std::string> items; std::vector<std::string> items;
SplitString(line, ':', items); SplitString(line, ':', items);
if (items.size() >= 3) {
if (items.size() >= 3)
{
PatchEntry pE; PatchEntry pE;
bool success = true; bool success = true;
success &= TryParse(items[0], &pE.address); success &= TryParse(items[0], &pE.address);
@ -103,7 +109,9 @@ void LoadPatchSection(const char *section, std::vector<Patch> &patches, IniFile
} }
} }
} }
if (currentPatch.name.size()) patches.push_back(currentPatch);
if (currentPatch.name.size() && currentPatch.entries.size())
patches.push_back(currentPatch);
} }
static void LoadDiscList(const char *section, std::vector<std::string> &_discList, IniFile &ini) { static void LoadDiscList(const char *section, std::vector<std::string> &_discList, IniFile &ini) {

View File

@ -53,6 +53,27 @@ void LoadPatchSection(const char *section, std::vector<Patch> &patches, IniFile
void LoadPatches(const char *gameID); void LoadPatches(const char *gameID);
void ApplyFramePatches(); void ApplyFramePatches();
void ApplyARPatches(); void ApplyARPatches();
inline int GetPatchTypeCharLength(PatchType type)
{
int size = 8;
switch (type)
{
case PatchEngine::PATCH_8BIT:
size = 2;
break;
case PatchEngine::PATCH_16BIT:
size = 4;
break;
case PatchEngine::PATCH_32BIT:
size = 8;
break;
}
return size;
}
} // namespace } // namespace
#endif //_PATCHENGINE_H #endif //_PATCHENGINE_H

View File

@ -71,7 +71,7 @@ void CPatchAddEdit::CreateGUIControls(int _selection)
EditPatchType->SetSelection((int)tempEntries.at(0).type); EditPatchType->SetSelection((int)tempEntries.at(0).type);
wxStaticText* EditPatchValueText = new wxStaticText(this, ID_EDITPATCH_VALUE_TEXT, _("Value:")); wxStaticText* EditPatchValueText = new wxStaticText(this, ID_EDITPATCH_VALUE_TEXT, _("Value:"));
EditPatchValue = new wxTextCtrl(this, ID_EDITPATCH_VALUE); EditPatchValue = new wxTextCtrl(this, ID_EDITPATCH_VALUE);
EditPatchValue->SetValue(wxString::Format(wxT("%08X"), tempEntries.at(0).value)); EditPatchValue->SetValue(wxString::Format(wxT("%0*X"), PatchEngine::GetPatchTypeCharLength(tempEntries.at(0).type), tempEntries.at(0).value));
wxButton *EntryAdd = new wxButton(this, ID_ENTRY_ADD, _("Add")); wxButton *EntryAdd = new wxButton(this, ID_ENTRY_ADD, _("Add"));
EntryRemove = new wxButton(this, ID_ENTRY_REMOVE, _("Remove")); EntryRemove = new wxButton(this, ID_ENTRY_REMOVE, _("Remove"));
if ((int)tempEntries.size() <= 1) if ((int)tempEntries.size() <= 1)
@ -105,7 +105,8 @@ void CPatchAddEdit::CreateGUIControls(int _selection)
void CPatchAddEdit::ChangeEntry(wxSpinEvent& event) void CPatchAddEdit::ChangeEntry(wxSpinEvent& event)
{ {
SaveEntryData(itCurEntry); if (!UpdateTempEntryData(itCurEntry))
return;
itCurEntry = tempEntries.end() - event.GetPosition() - 1; itCurEntry = tempEntries.end() - event.GetPosition() - 1;
currentItem = (int)tempEntries.size() - event.GetPosition(); currentItem = (int)tempEntries.size() - event.GetPosition();
@ -114,7 +115,8 @@ void CPatchAddEdit::ChangeEntry(wxSpinEvent& event)
void CPatchAddEdit::SavePatchData(wxCommandEvent& event) void CPatchAddEdit::SavePatchData(wxCommandEvent& event)
{ {
SaveEntryData(itCurEntry); if (!UpdateTempEntryData(itCurEntry))
return;
if (selection == -1) if (selection == -1)
{ {
@ -141,7 +143,8 @@ void CPatchAddEdit::AddRemoveEntry(wxCommandEvent& event)
{ {
case ID_ENTRY_ADD: case ID_ENTRY_ADD:
{ {
SaveEntryData(itCurEntry); if (!UpdateTempEntryData(itCurEntry))
break;
PatchEngine::PatchEntry peEmptyEntry(PatchEngine::PATCH_8BIT, 0x00000000, 0x00000000); PatchEngine::PatchEntry peEmptyEntry(PatchEngine::PATCH_8BIT, 0x00000000, 0x00000000);
++itCurEntry; ++itCurEntry;
@ -188,16 +191,38 @@ void CPatchAddEdit::UpdateEntryCtrls(PatchEngine::PatchEntry pE)
(int)tempEntries.size())); (int)tempEntries.size()));
EditPatchOffset->SetValue(wxString::Format(wxT("%08X"), pE.address)); EditPatchOffset->SetValue(wxString::Format(wxT("%08X"), pE.address));
EditPatchType->SetSelection(pE.type); EditPatchType->SetSelection(pE.type);
EditPatchValue->SetValue(wxString::Format(wxT("%08X"), pE.value)); EditPatchValue->SetValue(wxString::Format(wxT("%0*X"),
PatchEngine::GetPatchTypeCharLength(pE.type), pE.value));
} }
void CPatchAddEdit::SaveEntryData(std::vector<PatchEngine::PatchEntry>::iterator iterEntry) bool CPatchAddEdit::UpdateTempEntryData(std::vector<PatchEngine::PatchEntry>::iterator iterEntry)
{ {
unsigned long value; unsigned long value;
bool parsed_ok = true;
if (EditPatchOffset->GetValue().ToULong(&value, 16)) if (EditPatchOffset->GetValue().ToULong(&value, 16))
(*iterEntry).address = value; (*iterEntry).address = value;
(*iterEntry).type = (PatchEngine::PatchType) EditPatchType->GetSelection(); else
parsed_ok = false;
PatchEngine::PatchType tempType =
(*iterEntry).type = (PatchEngine::PatchType)EditPatchType->GetSelection();
if (EditPatchValue->GetValue().ToULong(&value, 16)) if (EditPatchValue->GetValue().ToULong(&value, 16))
{
(*iterEntry).value = value; (*iterEntry).value = value;
if (tempType == PatchEngine::PATCH_8BIT && value > 0xff)
parsed_ok = false;
else if (tempType == PatchEngine::PATCH_16BIT && value > 0xffff)
parsed_ok = false;
}
else
parsed_ok = false;
if (!parsed_ok)
{
PanicAlertT("Unable to create patch from given values.\nEntry not modified.");
}
return parsed_ok;
} }

View File

@ -62,7 +62,7 @@ class CPatchAddEdit : public wxDialog
void SavePatchData(wxCommandEvent& event); void SavePatchData(wxCommandEvent& event);
void AddRemoveEntry(wxCommandEvent& event); void AddRemoveEntry(wxCommandEvent& event);
void UpdateEntryCtrls(PatchEngine::PatchEntry pE); void UpdateEntryCtrls(PatchEngine::PatchEntry pE);
void SaveEntryData(std::vector<PatchEngine::PatchEntry>::iterator iterEntry); bool UpdateTempEntryData(std::vector<PatchEngine::PatchEntry>::iterator iterEntry);
int selection, currentItem; int selection, currentItem;
std::vector<PatchEngine::PatchEntry> tempEntries; std::vector<PatchEngine::PatchEntry> tempEntries;