X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Ftape.c;h=cd07263f007f2e4842c1395e13a5c17f6d6adecf;hb=19368085952eb82c094767bf6d356963aaee50a0;hp=e9b7f4cc65e7018d43d4a08ae7c2799739b32164;hpb=13cd07af3c2a9378b6a89506ba869502a871877d;p=rocksndiamonds.git diff --git a/src/tape.c b/src/tape.c index e9b7f4cc..cd07263f 100644 --- a/src/tape.c +++ b/src/tape.c @@ -1402,11 +1402,20 @@ static boolean PlayScoreTape_WaitForDownload(void) boolean PlayScoreTape(int entry_nr) { struct ScoreEntry *entry = &scores.entry[entry_nr]; - char *tape_filename = getScoreTapeFilename(entry->tape_basename, level_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; @@ -1433,7 +1442,10 @@ boolean PlayScoreTape(int entry_nr) // if tape recorder already contains a tape, remove it without asking TapeErase(); - LoadScoreTape(entry->tape_basename, level_nr); + if (entry->id == -1) + LoadScoreTape(entry->tape_basename, level_nr); + else + LoadScoreCacheTape(entry->tape_basename, level_nr); if (TAPE_IS_EMPTY(tape)) {