mirror of https://github.com/mgba-emu/mgba.git
Qt: Improve cheat parsing (fixes #2297)
This commit is contained in:
parent
7b4850024a
commit
21e2ccb025
1
CHANGES
1
CHANGES
|
@ -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)
|
||||||
|
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue