diff --git a/src/activity_actor.cpp b/src/activity_actor.cpp index 8e3a2de88c280..e2a8a20c59211 100644 --- a/src/activity_actor.cpp +++ b/src/activity_actor.cpp @@ -824,7 +824,10 @@ void hacking_activity_actor::finish( player_activity &act, Character &who ) act.set_to_null(); } -void hacking_activity_actor::serialize( JsonOut & ) const {} +void hacking_activity_actor::serialize( JsonOut &jsout ) const +{ + jsout.write_null(); +} std::unique_ptr hacking_activity_actor::deserialize( JsonValue & ) { diff --git a/src/avatar.h b/src/avatar.h index 286b157191ff3..fc0bd607f1ed4 100644 --- a/src/avatar.h +++ b/src/avatar.h @@ -369,7 +369,7 @@ class avatar : public Character // amount of turns since last check for pocket noise time_point last_pocket_noise = time_point( 0 ); - vproto_id starting_vehicle; + vproto_id starting_vehicle = vproto_id::NULL_ID(); std::vector starting_pets; std::set follower_ids; diff --git a/src/player_display.cpp b/src/player_display.cpp index 8220149543566..befdc365c2d86 100644 --- a/src/player_display.cpp +++ b/src/player_display.cpp @@ -1281,7 +1281,9 @@ static bool handle_player_display_action( Character &you, unsigned int &line, ++info_line; ui_info.invalidate_ui(); } else if( action == "MEDICAL_MENU" ) { - you.as_avatar()->disp_medical(); + if( you.is_avatar() ) { + you.as_avatar()->disp_medical(); + } } return done; } diff --git a/src/savegame_json.cpp b/src/savegame_json.cpp index 8df4947f4c41c..90991283030a5 100644 --- a/src/savegame_json.cpp +++ b/src/savegame_json.cpp @@ -1122,6 +1122,7 @@ void Character::load( const JsonObject &data ) item_location weapon = get_wielded_item(); bool has_old_bionic_weapon = !is_using_bionic_weapon() && weapon && + ( weapon->has_flag( flag_BIONIC_WEAPON ) || weapon->has_flag( flag_BIONIC_GUN ) ) && weapon->has_flag( flag_NO_UNWIELD ) && !weapon->ethereal; const auto find_parent = [this]( bionic_id & bio_id ) {