Qt: Improve cheat parsing (fixes #2297)

This commit is contained in:
Vicki Pfau 2022-05-28 15:04:18 -07:00
parent 7b4850024a
commit 21e2ccb025
2 changed files with 29 additions and 4 deletions

View File

@ -75,6 +75,7 @@ Misc:
- Qt: Show warning if XQ audio is toggled while loaded (fixes mgba.io/i/2295) - Qt: Show warning if XQ audio is toggled while loaded (fixes mgba.io/i/2295)
- Qt: Add e-Card passing to the command line (closes mgba.io/i/2474) - Qt: Add e-Card passing to the command line (closes mgba.io/i/2474)
- Qt: Boot both a multiboot image and ROM with CLI args (closes mgba.io/i/1941) - Qt: Boot both a multiboot image and ROM with CLI args (closes mgba.io/i/1941)
- Qt: Improve cheat parsing (fixes mgba.io/i/2297)
- Windows: Attach to console if present - Windows: Attach to console if present
- Vita: Add bilinear filtering option (closes mgba.io/i/344) - Vita: Add bilinear filtering option (closes mgba.io/i/344)

View File

@ -7,11 +7,13 @@
#include "GBAApp.h" #include "GBAApp.h"
#include "CoreController.h" #include "CoreController.h"
#include "LogController.h"
#include <QBoxLayout> #include <QBoxLayout>
#include <QButtonGroup> #include <QButtonGroup>
#include <QClipboard> #include <QClipboard>
#include <QRadioButton> #include <QRadioButton>
#include <QRegularExpression>
#include <mgba/core/cheats.h> #include <mgba/core/cheats.h>
#ifdef M_CORE_GBA #ifdef M_CORE_GBA
@ -110,7 +112,7 @@ void CheatsView::removeSet() {
return; return;
} }
CoreController::Interrupter interrupter(m_controller); CoreController::Interrupter interrupter(m_controller);
for (const QModelIndex& index : selection) { for (const QModelIndex& index ATTRIBUTE_UNUSED : selection) {
m_model.removeAt(selection[0]); m_model.removeAt(selection[0]);
} }
} }
@ -149,18 +151,40 @@ void CheatsView::enterCheat() {
index = m_model.index(m_model.rowCount() - 1, 0, QModelIndex()); index = m_model.index(m_model.rowCount() - 1, 0, QModelIndex());
m_ui.cheatList->selectionModel()->select(index, QItemSelectionModel::SelectCurrent | QItemSelectionModel::Rows); m_ui.cheatList->selectionModel()->select(index, QItemSelectionModel::SelectCurrent | QItemSelectionModel::Rows);
} }
// TODO: Update API to handle this splitting in the core
QRegularExpression regexp("\\s");
#if (QT_VERSION >= QT_VERSION_CHECK(5, 14, 0)) #if (QT_VERSION >= QT_VERSION_CHECK(5, 14, 0))
QStringList cheats = m_ui.codeEntry->toPlainText().split('\n', Qt::SkipEmptyParts); QStringList cheats = m_ui.codeEntry->toPlainText().split(regexp, Qt::SkipEmptyParts);
#else #else
QStringList cheats = m_ui.codeEntry->toPlainText().split('\n', QString::SkipEmptyParts); QStringList cheats = m_ui.codeEntry->toPlainText().split(regexp, QString::SkipEmptyParts);
#endif #endif
int failure = 0;
QString buffer;
for (const QString& string : cheats) { for (const QString& string : cheats) {
m_model.beginAppendRow(index); m_model.beginAppendRow(index);
mCheatAddLine(set, string.toUtf8().constData(), m_codeType); if (!buffer.isEmpty()) {
buffer += " " + string;
if (mCheatAddLine(set, buffer.toUtf8().constData(), m_codeType)) {
buffer.clear();
} else if (mCheatAddLine(set, string.toUtf8().constData(), m_codeType)) {
buffer.clear();
} else {
buffer = string;
++failure;
}
} else if (!mCheatAddLine(set, string.toUtf8().constData(), m_codeType)) {
buffer = string;
}
m_model.endAppendRow(); m_model.endAppendRow();
} }
if (!buffer.isEmpty()) {
++failure;
}
if (set->refresh) { if (set->refresh) {
set->refresh(set, m_controller->cheatDevice()); set->refresh(set, m_controller->cheatDevice());
} }
if (failure) {
LOG(QT, ERROR) << tr("Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types.");
}
m_ui.codeEntry->clear(); m_ui.codeEntry->clear();
} }