renamed command to create level sketch images
[rocksndiamonds.git] / src / game.c
index 355acab2d1b4f952a04205d1f38a0e1303dce0dc..23fe5f91eae8572a6dc463d56e2392806bf28970 100644 (file)
@@ -5066,7 +5066,9 @@ static int addScoreEntry(struct ScoreInfo *list, struct ScoreEntry *new_entry,
                              entry->time == 0);
 
     // prevent adding server score entries if also existing in local score file
-    if (strEqual(new_entry->tape_basename, entry->tape_basename))
+    // (special case: historic score entries have an empty tape basename entry)
+    if (strEqual(new_entry->tape_basename, entry->tape_basename) &&
+       !strEqual(new_entry->tape_basename, UNDEFINED_FILENAME))
       return -1;
 
     if (is_better || entry_is_empty)
@@ -5113,7 +5115,7 @@ static int addScoreEntry(struct ScoreInfo *list, struct ScoreEntry *new_entry,
 void NewHighScore(int level_nr)
 {
   struct ScoreEntry new_entry = {{ 0 }}; // (prevent warning from GCC bug 53119)
-  boolean one_per_name = !program.many_scores_per_name;
+  boolean one_per_name = FALSE;
 
   strncpy(new_entry.tape_basename, tape.score_tape_basename, MAX_FILENAME_LEN);
   strncpy(new_entry.name, setup.player_name, MAX_PLAYER_NAME_LEN);
@@ -5129,22 +5131,26 @@ void NewHighScore(int level_nr)
   {
     SaveScore(level_nr);
 
-    if (game.LevelSolved_SaveTape)
-    {
-      SaveScoreTape(level_nr);
-      SaveServerScore(level_nr);
-    }
-
     // store last added local score entry (before merging server scores)
     scores.last_added_local = scores.last_added;
   }
+
+  if (game.LevelSolved_SaveTape)
+  {
+    SaveScoreTape(level_nr);
+    SaveServerScore(level_nr);
+  }
 }
 
 void MergeServerScore(void)
 {
-  boolean one_per_name = !program.many_scores_per_name;
+  struct ScoreEntry last_added_entry;
+  boolean one_per_name = FALSE;
   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);
@@ -5154,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)