X-Git-Url: https://git.artsoft.org/?p=rocksndiamonds.git;a=blobdiff_plain;f=src%2Ffiles.c;h=e1a4b80c42c4720fa256b2bffacbf186c29d4a9e;hp=e349c062a9366d9971933f415ade98c6a96dd33d;hb=e5c5bf5c4a76a04f9bf64e92227bf2ef969fd25c;hpb=c3d03cdffce070695ba0520d00667b42b8460087 diff --git a/src/files.c b/src/files.c index e349c062..e1a4b80c 100644 --- a/src/files.c +++ b/src/files.c @@ -1,13 +1,12 @@ /*********************************************************** * Rocks'n'Diamonds -- McDuffin Strikes Back! * *----------------------------------------------------------* -* ©1995 Artsoft Development * -* Holger Schemel * -* 33659 Bielefeld-Senne * -* Telefon: (0521) 493245 * -* eMail: aeglos@valinor.owl.de * -* aeglos@uni-paderborn.de * -* q99492@pbhrzx.uni-paderborn.de * +* (c) 1995-98 Artsoft Entertainment * +* Holger Schemel * +* Oststrasse 11a * +* 33604 Bielefeld * +* phone: ++49 +521 290471 * +* email: aeglos@valinor.owl.de * *----------------------------------------------------------* * files.h * ***********************************************************/ @@ -15,16 +14,18 @@ #include "files.h" #include "tools.h" #include "misc.h" +#include "tape.h" +#include "joystick.h" -BOOL CreateNewScoreFile() +boolean CreateNewScoreFile() { int i,j,k; - char filename[MAX_FILENAME]; + char filename[MAX_FILENAME_LEN]; char empty_alias[MAX_NAMELEN]; FILE *file; sprintf(filename,"%s/%s/%s", - SCORE_PATH,leveldir[leveldir_nr].filename,SCORE_FILENAME); + level_directory,leveldir[leveldir_nr].filename,SCORE_FILENAME); if (!(file=fopen(filename,"w"))) return(FALSE); @@ -34,7 +35,7 @@ BOOL CreateNewScoreFile() strncpy(empty_alias,EMPTY_ALIAS,MAX_NAMELEN-1); fputs(SCORE_COOKIE,file); /* Formatkennung */ - for(i=0;i=MAX_TAPELEN) + int j; + + if (i >= MAX_TAPELEN) break; - tape.pos[i].joystickdata = fgetc(file); - tape.pos[i].delay = fgetc(file); + + for(j=0; j0) + { + tape.pos[i].action[j] = MV_NO_MOVING; + continue; + } + tape.pos[i].action[j] = fgetc(file); + } + + tape.pos[i].delay = fgetc(file); + if (feof(file)) break; } - if (i != tape.length) - fprintf(stderr,"%s: level recording file '%s' corrupted!\n", - progname,filename); - fclose(file); - master_tape = tape; + if (i != tape.length) + Error(ERR_RETURN, "level recording file '%s' corrupted", filename); + + tape.length_seconds = GetTapeLength(); } void LoadScore(int level_nr) { int i,j; - char filename[MAX_FILENAME]; - char cookie[MAX_FILENAME]; + char filename[MAX_FILENAME_LEN]; + char cookie[MAX_FILENAME_LEN]; FILE *file; sprintf(filename,"%s/%s/%s", - SCORE_PATH,leveldir[leveldir_nr].filename,SCORE_FILENAME); + level_directory,leveldir[leveldir_nr].filename,SCORE_FILENAME); - if (!(file=fopen(filename,"r"))) + if (!(file = fopen(filename,"r"))) { if (!CreateNewScoreFile()) - { - fprintf(stderr,"%s: cannot create score file '%s'!\n", - progname,filename); - } - else if (!(file=fopen(filename,"r"))) - { - fprintf(stderr,"%s: cannot load score for level %d!\n", - progname,level_nr); - } + Error(ERR_RETURN, "cannot create score file '%s'", filename); + else if (!(file = fopen(filename,"r"))) + Error(ERR_RETURN, "cannot load score for level %d", level_nr); } if (file) @@ -297,7 +310,7 @@ void LoadScore(int level_nr) fgets(cookie,SCORE_COOKIE_LEN,file); if (strcmp(cookie,SCORE_COOKIE)) /* ungültiges Format? */ { - fprintf(stderr,"%s: wrong format of score file!\n",progname); + Error(ERR_RETURN, "wrong format of score file '%s'", filename); fclose(file); file = NULL; } @@ -329,15 +342,16 @@ void LoadScore(int level_nr) void LoadPlayerInfo(int mode) { int i; - char filename[MAX_FILENAME]; - char cookie[MAX_FILENAME]; + char filename[MAX_FILENAME_LEN]; + char cookie[MAX_FILENAME_LEN]; FILE *file; char *login_name = GetLoginName(); struct PlayerInfo default_player, new_player; + int version_10_file = FALSE; if (mode==PLAYER_LEVEL) sprintf(filename,"%s/%s/%s", - NAMES_PATH,leveldir[leveldir_nr].filename,NAMES_FILENAME); + level_directory,leveldir[leveldir_nr].filename,NAMES_FILENAME); else sprintf(filename,"%s/%s",CONFIG_PATH,NAMES_FILENAME); @@ -348,30 +362,26 @@ void LoadPlayerInfo(int mode) default_player.handicap = 0; default_player.setup = DEFAULT_SETUP; default_player.leveldir_nr = 0; + default_player.level_nr = 0; new_player = default_player; - if (!(file=fopen(filename,"r"))) + if (!(file = fopen(filename,"r"))) { if (!CreateNewNamesFile(mode)) - { - fprintf(stderr,"%s: cannot create names file '%s'!\n", - progname,filename); - } - else if (!(file=fopen(filename,"r"))) - { - fprintf(stderr,"%s: cannot load player information '%s'!\n", - progname,filename); - } + Error(ERR_RETURN, "cannot create names file '%s'", filename); + else if (!(file = fopen(filename,"r"))) + Error(ERR_RETURN, "cannot load player information file '%s'", filename); } if (file) { fgets(cookie,NAMES_COOKIE_LEN,file); - if (strcmp(cookie,NAMES_COOKIE)) /* ungültiges Format? */ + if (!strcmp(cookie,NAMES_COOKIE_10)) /* altes Format? */ + version_10_file = TRUE; + else if (strcmp(cookie,NAMES_COOKIE)) /* ungültiges Format? */ { - fprintf(stderr,"%s: wrong format of names file '%s'!\n", - progname,filename); + Error(ERR_RETURN, "wrong format of names file '%s'", filename); fclose(file); file = NULL; } @@ -379,8 +389,8 @@ void LoadPlayerInfo(int mode) if (!file) { - player = default_player; - level_nr = default_player.handicap; + *local_player = default_player; + level_nr = default_player.level_nr; return; } @@ -393,17 +403,23 @@ void LoadPlayerInfo(int mode) new_player.handicap = fgetc(file); new_player.setup = (fgetc(file)<<8) | fgetc(file); new_player.leveldir_nr = fgetc(file); + if (!version_10_file) + { + new_player.level_nr = fgetc(file); + for(i=0;i<10;i++) /* currently unused bytes */ + fgetc(file); + } + else + new_player.level_nr = new_player.handicap; if (feof(file)) /* Spieler noch nicht in Liste enthalten */ { new_player = default_player; fclose(file); - if (!(file=fopen(filename,"a"))) - { - fprintf(stderr,"%s: cannot append new player to names file '%s'!\n", - progname,filename); - } + if (!(file = fopen(filename,"a"))) + Error(ERR_RETURN, "cannot append new player to names file '%s'", + filename); else { for(i=0;ileveldir_nr < num_leveldirs) + leveldir_nr = local_player->leveldir_nr; else leveldir_nr = 0; } else - player.handicap = new_player.handicap; + { + local_player->handicap = new_player.handicap; + local_player->level_nr = new_player.level_nr; + } - level_nr = player.handicap; - fclose(file); + level_nr = local_player->level_nr; + + if (file) + fclose(file); } void SaveLevel(int level_nr) { int i,x,y; - char filename[MAX_FILENAME]; + char filename[MAX_FILENAME_LEN]; FILE *file; sprintf(filename,"%s/%s/%d", - LEVEL_PATH,leveldir[leveldir_nr].filename,level_nr); + level_directory,leveldir[leveldir_nr].filename,level_nr); if (!(file=fopen(filename,"w"))) { - fprintf(stderr,"%s: cannot save level file '%s'!\n",progname,filename); + Error(ERR_RETURN, "cannot save level file '%s'", filename); return; } @@ -464,9 +491,8 @@ void SaveLevel(int level_nr) for(i=0;i> 24) & 0xff,file); fputc((tape.random_seed >> 16) & 0xff,file); fputc((tape.random_seed >> 8) & 0xff,file); @@ -536,7 +565,11 @@ void SaveLevelTape(int level_nr) for(i=0;ilogin_name, MAX_NAMELEN-1)) { - fseek(file,-(2*MAX_NAMELEN+1+2+1),SEEK_CUR); + fseek(file,-(2*MAX_NAMELEN+1+2+1+(version_10_file ? 0 : 11)),SEEK_CUR); break; } } + local_player->level_nr = level_nr; + for(i=0;ilogin_name[i],file); for(i=0;ialias_name[i],file); + fputc(local_player->handicap,file); + fputc(local_player->setup / 256,file); + fputc(local_player->setup % 256,file); + fputc(local_player->leveldir_nr,file); + if (!version_10_file) + { + fputc(local_player->level_nr,file); + for(i=0;i<10;i++) /* currently unused bytes */ + fputc(0,file); + } fclose(file); } @@ -648,13 +700,14 @@ void LoadJoystickData() if (joystick_status==JOYSTICK_OFF) return; +#ifndef MSDOS if (!(file=fopen(JOYDAT_FILE,"r"))) return; fscanf(file,"%s",cookie); if (strcmp(cookie,JOYSTICK_COOKIE)) /* ungültiges Format? */ { - fprintf(stderr,"%s: wrong format of joystick file!\n",progname); + Error(ERR_RETURN, "wrong format of joystick file '%s'", JOYDAT_FILE); fclose(file); return; } @@ -670,6 +723,9 @@ void LoadJoystickData() fclose(file); CheckJoystickData(); +#else + load_joystick_data(JOYDAT_FILE); +#endif } void SaveJoystickData() @@ -680,11 +736,13 @@ void SaveJoystickData() if (joystick_status==JOYSTICK_OFF) return; +#ifndef MSDOS CheckJoystickData(); if (!(file=fopen(JOYDAT_FILE,"w"))) { - fprintf(stderr,"%s: cannot save joystick calibration data!\n",progname); + Error(ERR_RETURN, "cannot save joystick calibration data to file '%s'", + JOYDAT_FILE); return; } @@ -700,4 +758,8 @@ void SaveJoystickData() fclose(file); chmod(JOYDAT_FILE, JOYDAT_PERMS); +#else + save_joystick_data(JOYDAT_FILE); +#endif + }