Remove global definition of badCheatHandle

This commit is contained in:
wheremyfoodat 2024-01-27 20:38:17 +02:00
parent 31eea40ea5
commit 01b6380242
4 changed files with 19 additions and 23 deletions

View file

@ -9,8 +9,6 @@
// Forward-declare this since it's just passed and we don't want to include memory.hpp and increase compile time
class Memory;
constexpr u32 badCheatHandle = 0xFFFFFFFF;
class Cheats {
public:
enum class CheatType {
@ -35,6 +33,7 @@ class Cheats {
void clear();
bool haveCheats() const { return cheatsLoaded; }
static constexpr u32 badCheatHandle = 0xFFFFFFFF;
private:
ActionReplay ar; // An ActionReplay cheat machine for executing CTRPF codes

View file

@ -18,8 +18,7 @@
#include "panda_qt/text_editor.hpp"
#include "services/hid.hpp"
struct CheatMessage
{
struct CheatMessage {
u32 handle;
std::vector<uint8_t> cheat;
std::function<void(u32)> callback;

View file

@ -19,14 +19,13 @@
MainWindow* mainWindow = nullptr;
struct CheatMetadata {
u32 handle = badCheatHandle;
u32 handle = Cheats::badCheatHandle;
std::string name = "New cheat";
std::string code;
bool enabled = true;
};
void dispatchToMainThread(std::function<void()> callback)
{
void dispatchToMainThread(std::function<void()> callback) {
QTimer* timer = new QTimer();
timer->moveToThread(qApp->thread());
timer->setSingleShot(true);
@ -110,7 +109,7 @@ CheatEntryWidget::CheatEntryWidget(Emulator* emu, CheatMetadata metadata, QListW
void CheatEntryWidget::checkboxChanged(int state) {
bool enabled = state == Qt::Checked;
if (metadata.handle == badCheatHandle) {
if (metadata.handle == Cheats::badCheatHandle) {
printf("Cheat handle is bad, this shouldn't happen\n");
return;
}
@ -197,7 +196,7 @@ void CheatEditDialog::accepted() {
mainWindow->editCheat(cheatEntry.getMetadata().handle, bytes, [this](u32 handle) {
dispatchToMainThread([this, handle]() {
if (handle == badCheatHandle) {
if (handle == Cheats::badCheatHandle) {
cheatEntry.Remove();
return;
} else {
@ -211,7 +210,7 @@ void CheatEditDialog::accepted() {
}
void CheatEditDialog::rejected() {
bool isEditing = cheatEntry.getMetadata().handle != badCheatHandle;
bool isEditing = cheatEntry.getMetadata().handle != Cheats::badCheatHandle;
if (!isEditing) {
// Was adding a cheat but user pressed cancel
cheatEntry.Remove();
@ -253,7 +252,7 @@ CheatsWindow::CheatsWindow(Emulator* emu, const std::filesystem::path& cheatPath
void CheatsWindow::addEntry() {
// CheatEntryWidget is added to the list when it's created
CheatEntryWidget* entry = new CheatEntryWidget(emu, {badCheatHandle, "New cheat", "", true}, cheatList);
CheatEntryWidget* entry = new CheatEntryWidget(emu, {Cheats::badCheatHandle, "New cheat", "", true}, cheatList);
CheatEditDialog* dialog = new CheatEditDialog(emu, *entry);
dialog->show();
}

View file

@ -239,7 +239,6 @@ void MainWindow::showAboutMenu() {
}
void MainWindow::openLuaEditor() { luaEditor->show(); }
void MainWindow::openCheatsEditor() { cheatsEditor->show(); }
void MainWindow::dispatchMessage(const EmulatorMessage& message) {
@ -259,7 +258,7 @@ void MainWindow::dispatchMessage(const EmulatorMessage& message) {
u32 handle = message.cheat.c->handle;
const std::vector<uint8_t>& cheat = message.cheat.c->cheat;
const std::function<void(u32)>& callback = message.cheat.c->callback;
bool isEditing = handle != badCheatHandle;
bool isEditing = handle != Cheats::badCheatHandle;
if (isEditing) {
emu->getCheats().removeCheat(handle);
u32 handle = emu->getCheats().addCheat(cheat.data(), cheat.size());