From 6d3642da78e86dfe191870db8fb146247f28e0c6 Mon Sep 17 00:00:00 2001 From: rtxyd <65117312+rtxyd@users.noreply.github.com> Date: Mon, 20 May 2024 14:58:24 +0100 Subject: [PATCH] Fix invalid avatar when we have old memorial (#71328) Co-authored-by: Maleclypse <54345792+Maleclypse@users.noreply.github.com> --- src/savegame_json.cpp | 54 +++++++++++++++++++++++-------------------- 1 file changed, 29 insertions(+), 25 deletions(-) diff --git a/src/savegame_json.cpp b/src/savegame_json.cpp index 20d96fafef625..6fe388da9ea5b 100644 --- a/src/savegame_json.cpp +++ b/src/savegame_json.cpp @@ -4549,35 +4549,39 @@ void stats_tracker::deserialize( const JsonObject &jo ) event_multiset gan_evts = get_events( event_type::game_avatar_new ); if( !gan_evts.count() ) { event_multiset gs_evts = get_events( event_type::game_start ); - if( gs_evts.count() ) { - auto gs_evt = gs_evts.first().value(); - cata::event::data_type gs_data = gs_evt.first; - - // retroactively insert starting avatar - cata::event::data_type gan_data( gs_data ); - gan_data["is_new_game"] = cata_variant::make( true ); - gan_data["is_debug"] = cata_variant::make( false ); - gan_data.erase( "game_version" ); - get_event_bus().send( cata::event( event_type::game_avatar_new, calendar::start_of_game, - std::move( gan_data ) ) ); - - // retroactively insert current avatar, if different from starting avatar - // we don't know when they took over, so just use current time point - avatar &u = get_avatar(); - if( u.getID() != gs_data["avatar_id"].get() ) { + avatar &u = get_avatar(); + // check if character ID set, if loadsave, the ID will not be -1 + // if it's an old save without event_type::game_avatar_new, the event need to be done + // this function is invoked when load memorial, on this situation start a new game, below shouldn't be invoked. + if( u.getID() != character_id( -1 ) ) { + if( gs_evts.count() ) { + auto gs_evt = gs_evts.first().value(); + cata::event::data_type gs_data = gs_evt.first; + + // retroactively insert starting avatar + cata::event::data_type gan_data( gs_data ); + gan_data["is_new_game"] = cata_variant::make( true ); + gan_data["is_debug"] = cata_variant::make( false ); + gan_data.erase( "game_version" ); + get_event_bus().send( cata::event( event_type::game_avatar_new, calendar::start_of_game, + std::move( gan_data ) ) ); + + // retroactively insert current avatar, if different from starting avatar + // we don't know when they took over, so just use current time point + if( u.getID() != gs_data["avatar_id"].get() ) { + profession_id prof_id = u.prof ? u.prof->ident() : profession::generic()->ident(); + get_event_bus().send( cata::event::make( false, false, + u.getID(), u.name, u.male, prof_id, u.custom_profession ) ); + } + } else { + // last ditch effort for really old saves that don't even have event_type::game_start + // treat current avatar as the starting avatar; abuse is_new_game=false to flag such cases profession_id prof_id = u.prof ? u.prof->ident() : profession::generic()->ident(); + std::swap( calendar::turn, calendar::start_of_game ); get_event_bus().send( cata::event::make( false, false, u.getID(), u.name, u.male, prof_id, u.custom_profession ) ); + std::swap( calendar::turn, calendar::start_of_game ); } - } else { - // last ditch effort for really old saves that don't even have event_type::game_start - // treat current avatar as the starting avatar; abuse is_new_game=false to flag such cases - avatar &u = get_avatar(); - profession_id prof_id = u.prof ? u.prof->ident() : profession::generic()->ident(); - std::swap( calendar::turn, calendar::start_of_game ); - get_event_bus().send( cata::event::make( false, false, - u.getID(), u.name, u.male, prof_id, u.custom_profession ) ); - std::swap( calendar::turn, calendar::start_of_game ); } } }