X-Git-Url: https://jxself.org/git/?p=open-adventure.git;a=blobdiff_plain;f=saveresume.c;h=cf5a69626912d9bb166724c4d59ced0a48588a3a;hp=3546378a5ae6d4e7e6ae44db7fb18b7e91beeb46;hb=bf2fa227f0786952ae4a632a1520bf1cf6663c98;hpb=d6cb6f0d8d258f4125fd3a0cc3899541ea2efd5b diff --git a/saveresume.c b/saveresume.c index 3546378..cf5a696 100644 --- a/saveresume.c +++ b/saveresume.c @@ -2,8 +2,7 @@ #include #include "advent.h" -#include "database.h" -#include "newdb.h" +#include "dungeon.h" #include "linenoise/linenoise.h" /* @@ -27,18 +26,20 @@ struct save_t { }; struct save_t save; -int savefile(FILE *fp) - /* Save game to file. No input or output from user. */ +int savefile(FILE *fp, long version) +/* Save game to file. No input or output from user. */ { long i, k; datime(&i, &k); k = i + 650 * k; save.savetime = k; save.mode = -1; - save.version = VRSION; + + save.version = (version == 0) ? VRSION : version; + memcpy(&save.game, &game, sizeof(struct game_t)); IGNORE(fwrite(&save, sizeof(struct save_t), 1, fp)); - return(0); + return (0); } /* Suspend and resume */ @@ -68,8 +69,7 @@ int suspend(void) linenoiseFree(name); } - savefile(fp); - IGNORE(fwrite(&save, sizeof(struct save_t), 1, fp)); + savefile(fp, VRSION); fclose(fp); rspeak(RESUME_HELP); exit(0); @@ -118,7 +118,8 @@ int restore(FILE* fp) rspeak(VERSION_SKEW, save.version / 10, MOD(save.version, 10), VRSION / 10, MOD(VRSION, 10)); } else { memcpy(&game, &save.game, sizeof(struct game_t)); - game.zzword = rndvoc(3, game.zzword); + //game.zzword = rndvoc(3, game.zzword); + make_zzword(game.zzword); } return GO_TOP; }