+ Print("Tape %03d: (no tape found)\n", level_nr);
+
+ continue;
+ }
+
+ if (global.autoplay_mode == AUTOPLAY_MODE_FIX)
+ {
+ boolean skip_patch = FALSE;
+
+ if (tape.engine_version < patch_version_first[patch_nr] ||
+ tape.engine_version > patch_version_last[patch_nr])
+ {
+ Print("Tape %03d %s[%02d:%02d]: (%s %d.%d.%d.%d) - skipped.\n",
+ level_nr, tape_patch_info,
+ tape.length_seconds / 60, tape.length_seconds % 60,
+ "not suitable for version",
+ (tape.engine_version / 1000000) % 100,
+ (tape.engine_version / 10000 ) % 100,
+ (tape.engine_version / 100 ) % 100,
+ (tape.engine_version ) % 100);
+
+ skip_patch = TRUE;
+ }
+
+ if (strEqual(patch_name[patch_nr], "screen_34x34") &&
+ tape.num_participating_players == 1)
+ {
+ Print("Tape %03d %s[%02d:%02d]: (%s) - skipped.\n",
+ level_nr, tape_patch_info,
+ tape.length_seconds / 60, tape.length_seconds % 60,
+ "not suitable for single player tapes");
+
+ skip_patch = TRUE;
+ }
+
+ if (skip_patch)
+ {
+ if (patch_name[patch_nr + 1] != NULL)
+ {
+ // continue with next patch
+ patch_nr++;
+ }
+ else
+ {
+ // continue with next tape
+ patch_nr = 0;
+ }
+
+ continue;
+ }
+
+ if (strEqual(patch_name[patch_nr], "screen_34x34"))
+ {
+ tape.scr_fieldx = SCR_FIELDX_DEFAULT * 2;
+ tape.scr_fieldy = SCR_FIELDY_DEFAULT * 2;
+ }
+ else
+ {
+ tape.property_bits |= patch_property_bit[patch_nr];
+ }
+ }
+
+ if (global.autoplay_mode == AUTOPLAY_MODE_UPLOAD)
+ {
+ // set unique basename for score tape (for uploading to score server)
+ strcpy(tape.score_tape_basename, getScoreTapeBasename(setup.player_name));
+
+ // store score in first score entry
+ scores.last_added = 0;
+
+ struct ScoreEntry *entry = &scores.entry[scores.last_added];
+
+ strncpy(entry->tape_basename, tape.score_tape_basename, MAX_FILENAME_LEN);
+ strncpy(entry->name, setup.player_name, MAX_PLAYER_NAME_LEN);
+
+ entry->score = 0;
+ entry->time = 0;
+
+ Print("Tape %03d:\n", level_nr);
+ PrintNoLog("- uploading score tape to score server ... ");
+
+ server_scores.uploaded = FALSE;
+
+ if (tape_filename == NULL)
+ tape_filename = (options.mytapes ? getTapeFilename(level_nr) :
+ getSolutionTapeFilename(level_nr));
+
+ SaveServerScoreFromFile(level_nr, tape_filename);
+
+ // required for uploading multiple tapes
+ tape_filename = NULL;
+
+ unsigned int upload_delay = 0;
+ unsigned int upload_delay_value = 10000;
+
+ ResetDelayCounter(&upload_delay);
+
+ // wait for score tape to be successfully uploaded (and fail on timeout)
+ while (!server_scores.uploaded)
+ {
+ if (DelayReached(&upload_delay, upload_delay_value))
+ {
+ PrintNoLog("\r");
+ Print("- uploading score tape to score server - TIMEOUT.\n");
+
+ Fail("cannot upload score tape to score server");
+ }
+
+ Delay(20);
+ }
+
+ PrintNoLog("\r");
+ Print("- uploading score tape to score server - uploaded.\n");