fixed potential off-by-one buffer overflow bug when recording tapes
[rocksndiamonds.git] / src / tape.c
index 71addab34829a8c1eab0a7152e98c384df1a35e7..5e55cb0453fad9166df5de9c971aaba03950abfc 100644 (file)
@@ -641,7 +641,10 @@ void TapeHaltRecording()
     return;
 
   tape.counter++;
-  tape.pos[tape.counter].delay = 0;
+
+  // initialize delay for next tape entry (to be able to continue recording)
+  if (tape.counter < MAX_TAPE_LEN)
+    tape.pos[tape.counter].delay = 0;
 
   tape.length = tape.counter;
   tape.length_frames = GetTapeLengthFrames();
@@ -1394,7 +1397,7 @@ static void HandleTapeButtonsExt(int id)
       else
       {
        if (tape.changed)
-         SaveTapeChecked(tape.level_nr);
+         SaveTapeChecked(level_nr);
 
        TapeErase();
       }