X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Ftape.c;h=cd07263f007f2e4842c1395e13a5c17f6d6adecf;hb=d0c35d05e88d7c3761c074135af990fc14302ace;hp=d93c6632a97e7f2112db654aec44c700f6987b6a;hpb=c0f9aa871d5922a6343facd23b44c2d1cb1f8c92;p=rocksndiamonds.git diff --git a/src/tape.c b/src/tape.c index d93c6632..cd07263f 100644 --- a/src/tape.c +++ b/src/tape.c @@ -18,6 +18,8 @@ #include "files.h" #include "network.h" #include "anim.h" +#include "api.h" + #define DEBUG_TAPE_WHEN_PLAYING FALSE @@ -1090,7 +1092,7 @@ void TapeStop(void) static void TapeStopGameOrTape(boolean stop_game) { - if (!tape.playing && stop_game) + if (score_info_tape_play || (!tape.playing && stop_game)) RequestQuitGame(FALSE); else TapeStop(); @@ -1292,6 +1294,13 @@ static boolean checkRestartGame(char *message) void TapeRestartGame(void) { + if (score_info_tape_play) + { + TapeStartGamePlaying(); + + return; + } + if (!checkRestartGame("Restart game?")) return; @@ -1300,6 +1309,9 @@ void TapeRestartGame(void) void TapeReplayAndPauseBeforeEnd(void) { + if (score_info_tape_play) + return; + if (TAPE_IS_EMPTY(tape) && !tape.recording) { Request("No tape for this level!", REQ_CONFIRM); @@ -1366,6 +1378,94 @@ boolean PlaySolutionTape(void) return TRUE; } +static boolean PlayScoreTape_WaitForDownload(void) +{ + unsigned int download_delay = 0; + unsigned int download_delay_value = 10000; + + ResetDelayCounter(&download_delay); + + // wait for score tape to be successfully downloaded (and fail on timeout) + while (!server_scores.tape_downloaded) + { + if (DelayReached(&download_delay, download_delay_value)) + return FALSE; + + UPDATE_BUSY_STATE_NOT_LOADING(); + + Delay(20); + } + + return TRUE; +} + +boolean PlayScoreTape(int entry_nr) +{ + struct ScoreEntry *entry = &scores.entry[entry_nr]; + char *tape_filename = + (entry->id == -1 ? + getScoreTapeFilename(entry->tape_basename, level_nr) : + getScoreCacheTapeFilename(entry->tape_basename, level_nr)); + boolean download_tape = (!fileExists(tape_filename)); + + if (download_tape && entry->id == -1) + { + FadeSkipNextFadeIn(); + + Request("Cannot find score tape!", REQ_CONFIRM); + + return FALSE; + } + + server_scores.tape_downloaded = FALSE; + + if (download_tape) + ApiGetScoreTapeAsThread(level_nr, entry->id, entry->tape_basename); + + SetGameStatus(GAME_MODE_PLAYING); + + FadeOut(REDRAW_FIELD); + + if (download_tape && !PlayScoreTape_WaitForDownload()) + { + SetGameStatus(GAME_MODE_SCOREINFO); + ClearField(); + + Request("Cannot download score tape from score server!", REQ_CONFIRM); + + return FALSE; + } + + if (!TAPE_IS_STOPPED(tape)) + TapeStop(); + + // if tape recorder already contains a tape, remove it without asking + TapeErase(); + + if (entry->id == -1) + LoadScoreTape(entry->tape_basename, level_nr); + else + LoadScoreCacheTape(entry->tape_basename, level_nr); + + if (TAPE_IS_EMPTY(tape)) + { + SetGameStatus(GAME_MODE_SCOREINFO); + ClearField(); + + Request("Cannot load score tape for this level!", REQ_CONFIRM); + + return FALSE; + } + + FadeSkipNextFadeOut(); + + TapeStartGamePlaying(); + + score_info_tape_play = TRUE; + + return TRUE; +} + static boolean checkTapesFromSameLevel(struct TapeInfo *t1, struct TapeInfo *t2) { return (strEqual(t1->level_identifier, t2->level_identifier) &&