X-Git-Url: https://jxself.org/git/?p=open-adventure.git;a=blobdiff_plain;f=saveresume.c;h=799e7af0b90225016ef03bb49150793cb439c529;hp=fdb9ffb2fbafdca479db816fc0efde60f2fde7bc;hb=0dd40bba32c9b5225e4d2126a50b7d6516791d06;hpb=17d94c46cd7b0691cee6f244f7d569870cdc57cf diff --git a/saveresume.c b/saveresume.c index fdb9ffb..799e7af 100644 --- a/saveresume.c +++ b/saveresume.c @@ -139,13 +139,19 @@ bool is_valid(struct game_t valgame) return false; } + /* Prevent RNG substitution. Why we are saving PRNG parameters? */ + + if (valgame.lcg_a != game.lcg_a || valgame.lcg_c != game.lcg_c || valgame.lcg_m != game.lcg_m) { + return false; + } + /* Bounds check for locations */ - if ( valgame.chloc < -1 || valgame.chloc > NLOCATIONS || - valgame.chloc < -1 || valgame.chloc > NLOCATIONS || - valgame.loc < -1 || valgame.loc > NLOCATIONS || + if ( valgame.chloc < -1 || valgame.chloc > NLOCATIONS || + valgame.chloc2 < -1 || valgame.chloc2 > NLOCATIONS || + valgame.loc < -1 || valgame.loc > NLOCATIONS || valgame.newloc < -1 || valgame.newloc > NLOCATIONS || valgame.oldloc < -1 || valgame.oldloc > NLOCATIONS || - valgame.oldloc < -1 || valgame.oldloc > NLOCATIONS) { + valgame.oldlc2 < -1 || valgame.oldlc2 > NLOCATIONS) { return false; } /* Bounds check for location arrays */ @@ -165,7 +171,7 @@ bool is_valid(struct game_t valgame) /* Bounds check for dwarves */ if (valgame.dtotal < 0 || valgame.dtotal > NDWARVES || - valgame.dkill < 0 || valgame.dkill > NDWARVES) { + valgame.dkill < 0 || valgame.dkill > NDWARVES) { return false; }