From 01cfcb11d24235ba7b3a25c05ce1bdabe5b3015d Mon Sep 17 00:00:00 2001 From: Michael Pavone Date: Sat, 25 Nov 2017 11:31:08 -0800 Subject: Get SMS savestates working in Nuklear UI --HG-- branch : nuklear_ui --- sms.c | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) (limited to 'sms.c') diff --git a/sms.c b/sms.c index 9bbad17..8e54619 100644 --- a/sms.c +++ b/sms.c @@ -318,17 +318,18 @@ static uint8_t load_state_path(sms_context *sms, char *path) static uint8_t load_state(system_header *system, uint8_t slot) { sms_context *sms = (sms_context *)system; - char numslotname[] = "slot_0.state"; - char *slotname; - if (slot == QUICK_SAVE_SLOT) { - slotname = "quicksave.state"; - } else { - numslotname[5] = '0' + slot; - slotname = numslotname; + char *statepath = get_slot_name(system, slot, "state"); + uint8_t ret; + if (!sms->z80->native_pc) { + ret = get_modification_time(statepath) != 0; + if (ret) { + system->delayed_load_slot = slot + 1; + } + goto done; + } - char const *parts[] = {sms->header.save_dir, PATH_SEP, slotname}; - char *statepath = alloc_concat_m(3, parts); - uint8_t ret = load_state_path(sms, statepath); + ret = load_state_path(sms, statepath); +done: free(statepath); return ret; } @@ -342,6 +343,11 @@ static void run_sms(system_header *system) render_set_video_standard(VID_NTSC); while (!sms->should_return) { + if (system->delayed_load_slot) { + load_state(system, system->delayed_load_slot - 1); + system->delayed_load_slot = 0; + + } if (system->enter_debugger && sms->z80->pc) { system->enter_debugger = 0; zdebugger(sms->z80, sms->z80->pc); -- cgit v1.2.3