From 4525321caadf2c2f2e5c4994c055ddeef4bf0a60 Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Thu, 24 Aug 2023 12:35:11 +0300 Subject: [PATCH 2/2] Savegame: Fix shuffled players order loading warning Clang analyzer warned about garbage value being used. See osdn #48536 Signed-off-by: Marko Lindqvist --- server/savegame2.c | 32 +++++++++++++++++--------------- server/savegame3.c | 32 +++++++++++++++++--------------- 2 files changed, 34 insertions(+), 30 deletions(-) diff --git a/server/savegame2.c b/server/savegame2.c index 3dab779243..8351920f21 100644 --- a/server/savegame2.c +++ b/server/savegame2.c @@ -2570,21 +2570,21 @@ static void sg_load_players_basic(struct loaddata *loading) * handles this ... */ if (secfile_lookup_int_default(loading->file, -1, "players.shuffled_player_%d", 0) >= 0) { - int shuffled_players[player_slot_count()]; - bool shuffled_player_set[player_slot_count()]; - - player_slots_iterate(pslot) { - int plrid = player_slot_index(pslot); + int slots = player_slot_count(); + int plrcount = player_count(); + int shuffled_players[slots]; + bool shuffled_player_set[slots]; + for (i = 0; i < slots; i++) { /* Array to save used numbers. */ - shuffled_player_set[plrid] = FALSE; + shuffled_player_set[i] = FALSE; /* List of all player IDs (needed for set_shuffled_players()). It is * initialised with the value -1 to indicate that no value is set. */ - shuffled_players[plrid] = -1; - } player_slots_iterate_end; + shuffled_players[i] = -1; + } /* Load shuffled player list. */ - for (i = 0; i < player_count(); i++){ + for (i = 0; i < plrcount; i++){ int shuffle = secfile_lookup_int_default(loading->file, -1, "players.shuffled_player_%d", i); @@ -2609,14 +2609,15 @@ static void sg_load_players_basic(struct loaddata *loading) if (shuffle_loaded) { /* Insert missing numbers. */ - int shuffle_index = player_count(); - for (i = 0; i < player_slot_count(); i++){ + int shuffle_index = plrcount; + + for (i = 0; i < slots; i++){ if (!shuffled_player_set[i]) { - shuffled_players[shuffle_index] = i; - shuffle_index++; + shuffled_players[shuffle_index++] = i; } - /* shuffle_index must not grow behind the size of shuffled_players. */ - sg_failure_ret(shuffle_index <= player_slot_count(), + + /* shuffle_index must not grow higher than size of shuffled_players. */ + sg_failure_ret(shuffle_index <= slots, "Invalid player shuffle data!"); } @@ -2624,6 +2625,7 @@ static void sg_load_players_basic(struct loaddata *loading) log_debug("[load shuffle] player_count() = %d", player_count()); player_slots_iterate(pslot) { int plrid = player_slot_index(pslot); + log_debug("[load shuffle] id: %3d => slot: %3d | slot %3d: %s", plrid, shuffled_players[plrid], plrid, shuffled_player_set[plrid] ? "is used" : "-"); diff --git a/server/savegame3.c b/server/savegame3.c index 98d4dffe34..af82308e80 100644 --- a/server/savegame3.c +++ b/server/savegame3.c @@ -3454,21 +3454,21 @@ static void sg_load_players_basic(struct loaddata *loading) * handles this ... */ if (secfile_lookup_int_default(loading->file, -1, "players.shuffled_player_%d", 0) >= 0) { - int shuffled_players[player_slot_count()]; - bool shuffled_player_set[player_slot_count()]; - - player_slots_iterate(pslot) { - int plrid = player_slot_index(pslot); + int slots = player_slot_count(); + int plrcount = player_count(); + int shuffled_players[slots]; + bool shuffled_player_set[slots]; + for (i = 0; i < slots; i++) { /* Array to save used numbers. */ - shuffled_player_set[plrid] = FALSE; + shuffled_player_set[i] = FALSE; /* List of all player IDs (needed for set_shuffled_players()). It is * initialised with the value -1 to indicate that no value is set. */ - shuffled_players[plrid] = -1; - } player_slots_iterate_end; + shuffled_players[i] = -1; + } /* Load shuffled player list. */ - for (i = 0; i < player_count(); i++){ + for (i = 0; i < plrcount; i++){ int shuffle = secfile_lookup_int_default(loading->file, -1, "players.shuffled_player_%d", i); @@ -3493,14 +3493,15 @@ static void sg_load_players_basic(struct loaddata *loading) if (shuffle_loaded) { /* Insert missing numbers. */ - int shuffle_index = player_count(); - for (i = 0; i < player_slot_count(); i++){ + int shuffle_index = plrcount; + + for (i = 0; i < slots; i++){ if (!shuffled_player_set[i]) { - shuffled_players[shuffle_index] = i; - shuffle_index++; + shuffled_players[shuffle_index++] = i; } - /* shuffle_index must not grow behind the size of shuffled_players. */ - sg_failure_ret(shuffle_index <= player_slot_count(), + + /* shuffle_index must not grow higher than size of shuffled_players. */ + sg_failure_ret(shuffle_index <= slots, "Invalid player shuffle data!"); } @@ -3508,6 +3509,7 @@ static void sg_load_players_basic(struct loaddata *loading) log_debug("[load shuffle] player_count() = %d", player_count()); player_slots_iterate(pslot) { int plrid = player_slot_index(pslot); + log_debug("[load shuffle] id: %3d => slot: %3d | slot %3d: %s", plrid, shuffled_players[plrid], plrid, shuffled_player_set[plrid] ? "is used" : "-"); -- 2.40.1