Finish state conversion

for last save path
(hopefully not broken).
This commit is contained in:
Robin Jones 2023-10-21 01:57:50 +01:00
parent 1daa664fe0
commit d677712b51
3 changed files with 14 additions and 50 deletions

View File

@ -17,11 +17,6 @@
static ed64_pseudo_writeback_t current_state; static ed64_pseudo_writeback_t current_state;
// FIXME: Use one file using the ed64_pseudo_writeback_t struct.
#ifndef LAST_SAVE_FILE_PATH
#define LAST_SAVE_FILE_PATH "/menu/ed_last_rom.tmp"
#endif
extern int ed_exit (void); extern int ed_exit (void);
static flashcart_err_t ed64_init (void) { static flashcart_err_t ed64_init (void) {
@ -42,38 +37,17 @@ static flashcart_err_t ed64_init (void) {
current_state.is_warm_start = false; current_state.is_warm_start = false;
ed64_state_save(&current_state); ed64_state_save(&current_state);
// finds the last save location
FIL lrp_fil;
UINT lrp_br;
if (f_open(&lrp_fil, strip_sd_prefix(LAST_SAVE_FILE_PATH), FA_READ) != FR_OK) {
return FLASHCART_ERR_LOAD;
}
int lrp_size = f_size(&lrp_fil);
TCHAR lrp_path[lrp_size++];
if (f_read(&lrp_fil, lrp_path, lrp_size, &lrp_br) != FR_OK) {
f_close(&lrp_fil);
return FLASHCART_ERR_LOAD;
}
if (f_close(&lrp_fil) != FR_OK) {
return FLASHCART_ERR_LOAD;
}
// Now save the content back to the SD card! // Now save the content back to the SD card!
FIL fil; FIL fil;
UINT br; UINT bw;
uint8_t cartsave_data[KiB(128)]; uint8_t cartsave_data[KiB(128)];
// find the path to last save // find the path to last save
if (file_exists(strip_sd_prefix(lrp_path))) { if (file_exists(strip_sd_prefix(current_state.last_save_path))) {
int save_size = file_get_size(strip_sd_prefix(lrp_path)); int save_size = file_get_size(strip_sd_prefix(current_state.last_save_path));
if ((f_open(&fil, strip_sd_prefix(lrp_path), FA_CREATE_ALWAYS | FA_READ | FA_WRITE)) != FR_OK) { if ((f_open(&fil, strip_sd_prefix(current_state.last_save_path), FA_CREATE_ALWAYS | FA_READ | FA_WRITE)) != FR_OK) {
return FLASHCART_ERR_LOAD; return FLASHCART_ERR_LOAD;
} }
@ -92,7 +66,7 @@ static flashcart_err_t ed64_init (void) {
ed64_ll_get_eeprom(cartsave_data, save_size); ed64_ll_get_eeprom(cartsave_data, save_size);
} }
if (f_write(&fil, cartsave_data, save_size, &br) != FR_OK) { if (f_write(&fil, cartsave_data, save_size, &bw) != FR_OK) {
return FLASHCART_ERR_LOAD; return FLASHCART_ERR_LOAD;
} }
@ -100,6 +74,10 @@ static flashcart_err_t ed64_init (void) {
return FLASHCART_ERR_LOAD; return FLASHCART_ERR_LOAD;
} }
} }
else {
current_state.last_save_path = "";
ed64_state_save(&current_state);
}
} }
return FLASHCART_OK; return FLASHCART_OK;
} }
@ -258,21 +236,7 @@ static flashcart_err_t ed64_load_save (char *save_path) {
} }
FIL lsp_fil; current_state.last_save_path = save_path;
UINT lsp_bw;
if (f_open(&lsp_fil, strip_sd_prefix(LAST_SAVE_FILE_PATH), FA_WRITE | FA_CREATE_ALWAYS) != FR_OK) {
return FLASHCART_ERR_LOAD;
}
if (f_write(&lsp_fil, strip_sd_prefix(save_path), strlen(save_path), &lsp_bw) != FR_OK) {
f_close(&lsp_fil);
return FLASHCART_ERR_LOAD;
}
if (f_close(&lsp_fil) != FR_OK) {
return FLASHCART_ERR_LOAD;
}
current_state.is_warm_start = true; current_state.is_warm_start = true;
ed64_state_save(&current_state); ed64_state_save(&current_state);

View File

@ -11,7 +11,7 @@
static ed64_pseudo_writeback_t init = { static ed64_pseudo_writeback_t init = {
.is_warm_start = false, .is_warm_start = false,
.is_fram_save_type = false, .is_fram_save_type = false,
.last_rom_path = "" .last_save_path = ""
}; };
@ -24,7 +24,7 @@ void ed64_state_load (ed64_pseudo_writeback_t *state) {
state->is_warm_start = mini_get_bool(ini, "ed64", "is_warm_start", init.is_warm_start); state->is_warm_start = mini_get_bool(ini, "ed64", "is_warm_start", init.is_warm_start);
state->is_fram_save_type = mini_get_bool(ini, "ed64", "is_fram_save_type", init.is_fram_save_type); state->is_fram_save_type = mini_get_bool(ini, "ed64", "is_fram_save_type", init.is_fram_save_type);
state->last_rom_path = strdup(mini_get_string(ini, "ed64", "last_rom_path", init.last_rom_path)); state->last_save_path = strdup(mini_get_string(ini, "ed64", "last_save_path", init.last_save_path));
mini_free(ini); mini_free(ini);
} }
@ -34,7 +34,7 @@ void ed64_state_save (ed64_pseudo_writeback_t *state) {
mini_set_bool(ini, "ed64", "is_warm_start", state->is_warm_start); mini_set_bool(ini, "ed64", "is_warm_start", state->is_warm_start);
mini_set_bool(ini, "ed64", "is_fram_save_type", state->is_fram_save_type); mini_set_bool(ini, "ed64", "is_fram_save_type", state->is_fram_save_type);
mini_set_string(ini, "ed64", "last_rom_path", state->last_rom_path); mini_set_string(ini, "ed64", "last_save_path", state->last_save_path);
mini_save(ini); mini_save(ini);

View File

@ -14,7 +14,7 @@ typedef struct {
/** @brief The last save type was flash ram */ /** @brief The last save type was flash ram */
bool is_fram_save_type; bool is_fram_save_type;
/** @brief The path to the last loaded ROM */ /** @brief The path to the last loaded ROM */
char *last_rom_path; char *last_save_path;
} ed64_pseudo_writeback_t; } ed64_pseudo_writeback_t;
void ed64_state_load (ed64_pseudo_writeback_t *state); void ed64_state_load (ed64_pseudo_writeback_t *state);