+/* ========================================================================= */
+/* tape logging functions */
+/* ========================================================================= */
+
+static void PrintTapeReplayProgress(boolean replay_finished)
+{
+ static unsigned int counter_last = -1;
+ unsigned int counter = Counter();
+ unsigned int counter_seconds = counter / 1000;
+
+ if (!replay_finished)
+ {
+ unsigned int counter_delay = 50;
+
+ if (counter > counter_last + counter_delay)
+ {
+ PrintNoLog("\r");
+ PrintNoLog("Level %03d [%02d:%02d]: [%02d:%02d] - playing tape ... ",
+ level_nr, tape.length_seconds / 60, tape.length_seconds % 60,
+ TapeTime / 60, TapeTime % 60);
+
+ counter_last = counter;
+ }
+ }
+ else
+ {
+ float tape_length_seconds = GetTapeLengthSecondsFloat();
+
+ PrintNoLog("\r");
+ Print("Level %03d [%02d:%02d]: (%02d:%02d.%03d / %.2f %%) - %s.\n",
+ level_nr, tape.length_seconds / 60, tape.length_seconds % 60,
+ counter_seconds / 60, counter_seconds % 60, counter % 1000,
+ (float)counter / tape_length_seconds / 10,
+ tape.auto_play_level_solved ? "solved" : "NOT SOLVED");
+
+ counter_last = -1;
+ }
+}
+
+