mirror of https://github.com/mgba-emu/mgba.git
Core: Fix crashes if core directories aren't set
This commit is contained in:
parent
fc2b043207
commit
61d128a160
1
CHANGES
1
CHANGES
|
@ -5,6 +5,7 @@ Emulation fixes:
|
||||||
Other fixes:
|
Other fixes:
|
||||||
- Switch: Fix threading-related crash on second launch
|
- Switch: Fix threading-related crash on second launch
|
||||||
- Qt: Fix FPS target maxing out at 59.727 (fixes mgba.io/i/1421)
|
- Qt: Fix FPS target maxing out at 59.727 (fixes mgba.io/i/1421)
|
||||||
|
- Core: Fix crashes if core directories aren't set
|
||||||
Misc:
|
Misc:
|
||||||
- Qt: Make mute menu option also toggle fast-forward mute (fixes mgba.io/i/1424)
|
- Qt: Make mute menu option also toggle fast-forward mute (fixes mgba.io/i/1424)
|
||||||
|
|
||||||
|
|
|
@ -157,10 +157,16 @@ bool mCorePreloadFile(struct mCore* core, const char* path) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool mCoreAutoloadSave(struct mCore* core) {
|
bool mCoreAutoloadSave(struct mCore* core) {
|
||||||
|
if (!core->dirs.save) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
return core->loadSave(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.save, ".sav", O_CREAT | O_RDWR));
|
return core->loadSave(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.save, ".sav", O_CREAT | O_RDWR));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool mCoreAutoloadPatch(struct mCore* core) {
|
bool mCoreAutoloadPatch(struct mCore* core) {
|
||||||
|
if (!core->dirs.patch) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
return core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".ups", O_RDONLY)) ||
|
return core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".ups", O_RDONLY)) ||
|
||||||
core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".ips", O_RDONLY)) ||
|
core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".ips", O_RDONLY)) ||
|
||||||
core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".bps", O_RDONLY));
|
core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".bps", O_RDONLY));
|
||||||
|
@ -217,6 +223,9 @@ bool mCoreLoadState(struct mCore* core, int slot, int flags) {
|
||||||
}
|
}
|
||||||
|
|
||||||
struct VFile* mCoreGetState(struct mCore* core, int slot, bool write) {
|
struct VFile* mCoreGetState(struct mCore* core, int slot, bool write) {
|
||||||
|
if (!core->dirs.state) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
char name[PATH_MAX];
|
char name[PATH_MAX];
|
||||||
snprintf(name, sizeof(name), "%s.ss%i", core->dirs.baseName, slot);
|
snprintf(name, sizeof(name), "%s.ss%i", core->dirs.baseName, slot);
|
||||||
return core->dirs.state->openFile(core->dirs.state, name, write ? (O_CREAT | O_TRUNC | O_RDWR) : O_RDONLY);
|
return core->dirs.state->openFile(core->dirs.state, name, write ? (O_CREAT | O_TRUNC | O_RDWR) : O_RDONLY);
|
||||||
|
|
Loading…
Reference in New Issue