X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=saveresume.c;h=c1b5eb202bb52f09b1f3ab963c7ec6bb666c2384;hb=f496bff9452415ea1babf9aab1019f905ca8735a;hp=889794596ae2325e8500e909e7765f9f567b0a32;hpb=36f72f190259b3ff72a87d1e888a578d6fd5b8da;p=open-adventure.git diff --git a/saveresume.c b/saveresume.c index 8897945..c1b5eb2 100644 --- a/saveresume.c +++ b/saveresume.c @@ -144,6 +144,45 @@ bool is_valid(struct game_t valgame) valgame.oldloc < -1 || valgame.oldloc > NLOCATIONS) { return false; } + /* Bounds check for location arrays + */ + for (int i = 0; i <= NDWARVES; i++) { + if (valgame.dloc[i] < -1 || valgame.dloc[i] > NLOCATIONS || + valgame.odloc[i] < -1 || valgame.odloc[i] > NLOCATIONS) { + return false; + } + } + + for (int i = 0; i <= NOBJECTS; i++) { + if (valgame.place[i] < -1 || valgame.place[i] > NLOCATIONS || + valgame.fixed[i] < -1 || valgame.fixed[i] > NLOCATIONS) { + return false; + } + } + + /* Bounds check for dwarves */ + if (valgame.dtotal < 0 || valgame.dtotal > NDWARVES || + valgame.dkill < 0 || valgame.dkill > NDWARVES) { + return false; + } + + /* Validate that we didn't die too many times in save */ + if (valgame.numdie >= NDEATHS) { + return false; + } + + /* Recalculate tally, throw the towel if in disagreement */ + long temp_tally = 0; + for (int treasure = 1; treasure <= NOBJECTS; treasure++) { + if (objects[treasure].is_treasure) { + if (valgame.prop[treasure] == STATE_NOTFOUND) { + ++temp_tally; + } + } + } + if (temp_tally != valgame.tally) { + return false; + } return true; }