From 952c883755b0feec2a808c6be651263e5b9c68d0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 4 Oct 2024 17:13:43 -0700 Subject: [PATCH] Core: Check for null when autoloading/saving cheats --- src/core/cheats.c | 3 +++ src/core/core.c | 6 ++++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/core/cheats.c b/src/core/cheats.c index 60f73abcc..fe34b033c 100644 --- a/src/core/cheats.c +++ b/src/core/cheats.c @@ -627,6 +627,9 @@ void mCheatAutosave(struct mCheatDevice* device) { if (!device->autosave) { return; } + if (!device->p->dirs.cheats) { + return; + } struct VFile* vf = mDirectorySetOpenSuffix(&device->p->dirs, device->p->dirs.cheats, ".cheats", O_WRONLY | O_CREAT | O_TRUNC); if (!vf) { return; diff --git a/src/core/core.c b/src/core/core.c index df330c3bd..6a64da670 100644 --- a/src/core/core.c +++ b/src/core/core.c @@ -243,14 +243,16 @@ bool mCoreAutoloadPatch(struct mCore* core) { } bool mCoreAutoloadCheats(struct mCore* core) { - bool success = true; + bool success = !!core->dirs.cheats; int cheatAuto; - if (!mCoreConfigGetIntValue(&core->config, "cheatAutoload", &cheatAuto) || cheatAuto) { + if (success && (!mCoreConfigGetIntValue(&core->config, "cheatAutoload", &cheatAuto) || cheatAuto)) { struct VFile* vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.cheats, ".cheats", O_RDONLY); if (vf) { struct mCheatDevice* device = core->cheatDevice(core); success = mCheatParseFile(device, vf); vf->close(vf); + } else { + success = false; } } if (!mCoreConfigGetIntValue(&core->config, "cheatAutosave", &cheatAuto) || cheatAuto) {