diff --git a/autogen/convert_functions.py b/autogen/convert_functions.py index 3e25b2c59..b0a14bdbd 100644 --- a/autogen/convert_functions.py +++ b/autogen/convert_functions.py @@ -52,6 +52,7 @@ in_files = [ "src/game/object_list_processor.h", "src/game/behavior_actions.h", "src/game/mario_misc.h", + "src/pc/utils/misc.h", "src/game/level_update.h" ] @@ -59,11 +60,12 @@ override_allowed_functions = { "src/audio/external.h": [ " play_", "fade", "current_background", "stop_" ], "src/game/rumble_init.c": [ "queue_rumble_", "reset_rumble_timers" ], "src/pc/djui/djui_popup.h" : [ "create" ], - "src/game/save_file.h": [ "save_file_get_", "save_file_set_flags", "save_file_clear_flags", "save_file_reload", "save_file_set_star_flags" ], + "src/game/save_file.h": [ "save_file_get_", "save_file_set_flags", "save_file_clear_flags", "save_file_reload", "save_file_erase_current_backup_save", "save_file_set_star_flags" ], "src/pc/lua/utils/smlua_model_utils.h": [ "smlua_model_util_get_id" ], "src/game/object_list_processor.h": [ "set_object_respawn_info_bits" ], "src/game/mario_misc.h": [ "bhv_toad.*", "bhv_unlock_door.*" ], "src/game/level_update.h": [ "level_trigger_warp" ], + "src/pc/utils/misc.h": [ "update_all_mario_stars"], } override_disallowed_functions = { diff --git a/autogen/lua_definitions/functions.lua b/autogen/lua_definitions/functions.lua index 9f7761aa8..d3c5c6fd6 100644 --- a/autogen/lua_definitions/functions.lua +++ b/autogen/lua_definitions/functions.lua @@ -5211,6 +5211,11 @@ function vec3f_set_dist_and_angle(from, to, dist, pitch, yaw) -- ... end +--- @return nil +function update_all_mario_stars() + -- ... +end + --- @param courseNum integer --- @param actNum integer --- @param levelNum integer @@ -7271,6 +7276,11 @@ function save_file_clear_flags(flags) -- ... end +--- @return nil +function save_file_erase_current_backup_save() + -- ... +end + --- @param capPos Vec3s --- @return integer function save_file_get_cap_pos(capPos) @@ -7322,8 +7332,9 @@ function save_file_get_total_star_count(fileIndex, minCourse, maxCourse) -- ... end +--- @param load_all integer --- @return nil -function save_file_reload() +function save_file_reload(load_all) -- ... end diff --git a/docs/lua/functions-3.md b/docs/lua/functions-3.md index d7707e792..ff2bc0339 100644 --- a/docs/lua/functions-3.md +++ b/docs/lua/functions-3.md @@ -7095,6 +7095,30 @@
+--- +# functions from misc.h + +
+ + +## [update_all_mario_stars](#update_all_mario_stars) + +### Lua Example +`update_all_mario_stars()` + +### Parameters +- None + +### Returns +- None + +### C Prototype +`void update_all_mario_stars(void);` + +[:arrow_up_small:](#) + +
+ --- # functions from network_player.h diff --git a/docs/lua/functions-4.md b/docs/lua/functions-4.md index f7caf398f..7d1593348 100644 --- a/docs/lua/functions-4.md +++ b/docs/lua/functions-4.md @@ -5364,6 +5364,24 @@
+## [save_file_erase_current_backup_save](#save_file_erase_current_backup_save) + +### Lua Example +`save_file_erase_current_backup_save()` + +### Parameters +- None + +### Returns +- None + +### C Prototype +`void save_file_erase_current_backup_save(void);` + +[:arrow_up_small:](#) + +
+ ## [save_file_get_cap_pos](#save_file_get_cap_pos) ### Lua Example @@ -5528,16 +5546,18 @@ ## [save_file_reload](#save_file_reload) ### Lua Example -`save_file_reload()` +`save_file_reload(load_all)` ### Parameters -- None +| Field | Type | +| ----- | ---- | +| load_all | `integer` | ### Returns - None ### C Prototype -`void save_file_reload(void);` +`void save_file_reload(u8 load_all);` [:arrow_up_small:](#) diff --git a/docs/lua/functions.md b/docs/lua/functions.md index 8da004085..2bf3e70a1 100644 --- a/docs/lua/functions.md +++ b/docs/lua/functions.md @@ -1012,6 +1012,11 @@
+- misc.h + - [update_all_mario_stars](functions-3.md#update_all_mario_stars) + +
+ - network_player.h - [get_network_player_from_area](functions-3.md#get_network_player_from_area) - [get_network_player_from_level](functions-3.md#get_network_player_from_level) @@ -1354,6 +1359,7 @@ - save_file.h - [save_file_clear_flags](functions-4.md#save_file_clear_flags) + - [save_file_erase_current_backup_save](functions-4.md#save_file_erase_current_backup_save) - [save_file_get_cap_pos](functions-4.md#save_file_get_cap_pos) - [save_file_get_course_coin_score](functions-4.md#save_file_get_course_coin_score) - [save_file_get_course_star_count](functions-4.md#save_file_get_course_star_count) diff --git a/src/game/save_file.c b/src/game/save_file.c index cf5656574..0480eedff 100644 --- a/src/game/save_file.c +++ b/src/game/save_file.c @@ -14,6 +14,7 @@ #include "pc/ini.h" #include "pc/network/network.h" #include "pc/lua/utils/smlua_level_utils.h" +#include "pc/utils/misc.h" #ifndef bcopy #define bcopy(b1,b2,len) (memmove((b2), (b1), (len)), (void) 0) @@ -200,7 +201,7 @@ static u16 calc_checksum(u8 *data, s32 size) { /** * Verify the signature at the end of the block to check if the data is valid. */ -static s32 verify_save_block_signature(void *buffer, s32 size, u16 magic) { +UNUSED static s32 verify_save_block_signature(void *buffer, s32 size, u16 magic) { struct SaveBlockSignature *sig = (struct SaveBlockSignature *) ((size - 4) + (u8 *) buffer); if (sig->magic != magic) { @@ -225,7 +226,7 @@ static void add_save_block_signature(void *buffer, s32 size, u16 magic) { /** * Copy main menu data from one backup slot to the other slot. */ -static void restore_main_menu_data(s32 srcSlot) { +UNUSED static void restore_main_menu_data(s32 srcSlot) { s32 destSlot = srcSlot ^ 1; // Compute checksum on source data @@ -253,7 +254,7 @@ static void save_main_menu_data(void) { } } -static void wipe_main_menu_data(void) { +UNUSED static void wipe_main_menu_data(void) { bzero(&gSaveBuffer.menuData[0], sizeof(gSaveBuffer.menuData[0])); // Set score ages for all courses to 3, 2, 1, and 0, respectively. @@ -311,7 +312,7 @@ static void touch_high_score_ages(s32 fileIndex) { /** * Copy save file data from one backup slot to the other slot. */ -static void restore_save_file_data(s32 fileIndex, s32 srcSlot) { +UNUSED static void restore_save_file_data(s32 fileIndex, s32 srcSlot) { s32 destSlot = srcSlot ^ 1; // Compute checksum on source data @@ -392,6 +393,28 @@ void save_file_erase(s32 fileIndex) { save_file_do_save(fileIndex, TRUE); } +void save_file_reload(u8 load_all) { + gSaveFileModified = TRUE; + update_all_mario_stars(); + + if (load_all == TRUE) { + save_file_load_all(TRUE); + save_file_do_save(gCurrSaveFileNum-1, TRUE); + update_all_mario_stars(); + } +} + +void save_file_erase_current_backup_save(void) { + if (network_is_server()) { + bzero(&gSaveBuffer.files[gCurrSaveFileNum-1][1], sizeof(gSaveBuffer.files[gCurrSaveFileNum-1][1])); + + save_file_reload(FALSE); + + save_file_do_save(gCurrSaveFileNum-1, TRUE); + network_send_save_file(gCurrSaveFileNum-1); + } +} + //! Needs to be s32 to match on -O2, despite no return value. BAD_RETURN(s32) save_file_copy(s32 srcFileIndex, s32 destFileIndex) { if (srcFileIndex < 0 || srcFileIndex >= NUM_SAVE_FILES || destFileIndex < 0 || destFileIndex >= NUM_SAVE_FILES) @@ -457,23 +480,6 @@ void save_file_load_all(UNUSED u8 reload) { stub_save_file_1(); } -/** - * Reload the current save file from its backup copy, which is effectively a - * a cached copy of what has been written to EEPROM. - * This is used after getting a game over. - */ -void save_file_reload(void) { - // Copy save file data from backup - /*bcopy(&gSaveBuffer.files[gCurrSaveFileNum - 1][1], &gSaveBuffer.files[gCurrSaveFileNum - 1][0], - sizeof(gSaveBuffer.files[gCurrSaveFileNum - 1][0])); - - // Copy main menu data from backup - bcopy(&gSaveBuffer.menuData[1], &gSaveBuffer.menuData[0], sizeof(gSaveBuffer.menuData[0]));*/ - - gMainMenuDataModified = FALSE; - gSaveFileModified = FALSE; -} - /** * Update the current save file after collecting a star or a key. * If coin score is greater than the current high score, update it. diff --git a/src/game/save_file.h b/src/game/save_file.h index 97d3f3793..6aca72218 100644 --- a/src/game/save_file.h +++ b/src/game/save_file.h @@ -131,9 +131,10 @@ extern s8 gSaveFileModified; s8 get_level_course_num(s16 levelNum); void save_file_do_save(s32 fileIndex, s8 forceSave); void save_file_erase(s32 fileIndex); +void save_file_erase_current_backup_save(void); BAD_RETURN(s32) save_file_copy(s32 srcFileIndex, s32 destFileIndex); void save_file_load_all(u8 reload); -void save_file_reload(void); +void save_file_reload(u8 load_all); void save_file_collect_star_or_key(s16 coinScore, s16 starIndex, u8 fromNetwork); s32 save_file_exists(s32 fileIndex); u32 save_file_get_max_coin_score(s32 courseIndex); diff --git a/src/pc/lua/smlua_functions_autogen.c b/src/pc/lua/smlua_functions_autogen.c index 7699bf838..a1db9a5d1 100644 --- a/src/pc/lua/smlua_functions_autogen.c +++ b/src/pc/lua/smlua_functions_autogen.c @@ -31,6 +31,7 @@ #include "src/game/object_list_processor.h" #include "src/game/behavior_actions.h" #include "src/game/mario_misc.h" +#include "src/pc/utils/misc.h" #include "src/game/level_update.h" @@ -11717,6 +11718,19 @@ int smlua_func_vec3s_to_vec3f(lua_State* L) { } */ + //////////// + // misc.h // +//////////// + +int smlua_func_update_all_mario_stars(UNUSED lua_State* L) { + if(!smlua_functions_valid_param_count(L, 0)) { return 0; } + + + update_all_mario_stars(); + + return 1; +} + ////////////////////// // network_player.h // ////////////////////// @@ -16154,6 +16168,15 @@ int smlua_func_save_file_clear_flags(lua_State* L) { return 1; } +int smlua_func_save_file_erase_current_backup_save(UNUSED lua_State* L) { + if(!smlua_functions_valid_param_count(L, 0)) { return 0; } + + + save_file_erase_current_backup_save(); + + return 1; +} + int smlua_func_save_file_get_cap_pos(lua_State* L) { if(!smlua_functions_valid_param_count(L, 1)) { return 0; } @@ -16256,11 +16279,13 @@ int smlua_func_save_file_get_total_star_count(lua_State* L) { return 1; } -int smlua_func_save_file_reload(UNUSED lua_State* L) { - if(!smlua_functions_valid_param_count(L, 0)) { return 0; } +int smlua_func_save_file_reload(lua_State* L) { + if(!smlua_functions_valid_param_count(L, 1)) { return 0; } + u8 load_all = smlua_to_integer(L, 1); + if (!gSmLuaConvertSuccess) { LOG_LUA("Failed to convert parameter 1 for function 'save_file_reload'"); return 0; } - save_file_reload(); + save_file_reload(load_all); return 1; } @@ -19177,6 +19202,9 @@ void smlua_bind_functions_autogen(void) { //smlua_bind_function(L, "vec3s_sum", smlua_func_vec3s_sum); <--- UNIMPLEMENTED //smlua_bind_function(L, "vec3s_to_vec3f", smlua_func_vec3s_to_vec3f); <--- UNIMPLEMENTED + // misc.h + smlua_bind_function(L, "update_all_mario_stars", smlua_func_update_all_mario_stars); + // network_player.h smlua_bind_function(L, "get_network_player_from_area", smlua_func_get_network_player_from_area); smlua_bind_function(L, "get_network_player_from_level", smlua_func_get_network_player_from_level); @@ -19519,6 +19547,7 @@ void smlua_bind_functions_autogen(void) { // save_file.h smlua_bind_function(L, "save_file_clear_flags", smlua_func_save_file_clear_flags); + smlua_bind_function(L, "save_file_erase_current_backup_save", smlua_func_save_file_erase_current_backup_save); smlua_bind_function(L, "save_file_get_cap_pos", smlua_func_save_file_get_cap_pos); smlua_bind_function(L, "save_file_get_course_coin_score", smlua_func_save_file_get_course_coin_score); smlua_bind_function(L, "save_file_get_course_star_count", smlua_func_save_file_get_course_star_count); diff --git a/src/pc/network/network.c b/src/pc/network/network.c index c29624ec6..3b3d776a9 100644 --- a/src/pc/network/network.c +++ b/src/pc/network/network.c @@ -529,6 +529,8 @@ void network_shutdown(bool sendLeaving, bool exiting, bool popup) { extern void save_file_load_all(UNUSED u8 reload); save_file_load_all(TRUE); + extern void save_file_set_using_backup_slot(bool usingBackupSlot); + save_file_set_using_backup_slot(false); extern s16 gMenuMode; gMenuMode = -1;