forced displaying last added high score entry
[rocksndiamonds.git] / src / game.c
index f5ed675623811390c1cfce5d1c8ce150f0b7ab69..914c25206477f1e8cd9516af34d8571618128ac4 100644 (file)
@@ -5144,9 +5144,13 @@ void NewHighScore(int level_nr)
 
 void MergeServerScore(void)
 {
+  struct ScoreEntry last_added_entry;
   boolean one_per_name = !program.many_scores_per_name;
   int i;
 
+  if (scores.last_added >= 0)
+    last_added_entry = scores.entry[scores.last_added];
+
   for (i = 0; i < server_scores.num_entries; i++)
   {
     int pos = addScoreEntry(&scores, &server_scores.entry[i], one_per_name);
@@ -5156,7 +5160,12 @@ void MergeServerScore(void)
   }
 
   if (scores.last_added >= MAX_SCORE_ENTRIES)
-    scores.last_added = -1;
+  {
+    scores.last_added = MAX_SCORE_ENTRIES - 1;
+    scores.force_last_added = TRUE;
+
+    scores.entry[scores.last_added] = last_added_entry;
+  }
 }
 
 static int getElementMoveStepsizeExt(int x, int y, int direction)