/* First tally up the treasures. Must be in building and not broken.
* Give the poor guy 2 points just for finding each treasure. */
mxscor = 0;
- for (long i = MINTRS; i <= MAXTRS; i++) {
+ for (int i = 1; i <= NOBJECTS; i++) {
+ if (!object_descriptions[i].is_treasure)
+ continue;
if (object_descriptions[i].inventory != 0) {
long k = 12;
if (i == CHEST)k = 14;
}
}
- /* Now look at how he finished and how far he got. MAXDIE and
+ /* Now look at how he finished and how far he got. NDEATHS and
* game.numdie tell us how well he survived. game.dflag will tell us
* if he ever got suitably deep into the cave. game.closng still
* indicates whether he reached the endgame. And if he got as far as
* "cave closed" (indicated by "game.closed"), then bonus is zero for
* mundane exits or 133, 134, 135 if he blew it (so to speak). */
- score += (MAXDIE - game.numdie) * 10;
- mxscor += MAXDIE * 10;
+ score += (NDEATHS - game.numdie) * 10;
+ mxscor += NDEATHS * 10;
if (mode == endgame)
score += 4;
mxscor += 4;
mxscor += 45;
/* Did he come to Witt's End as he should? */
- if (game.place[MAGZIN] == LOC_WITTSEND)
+ if (game.place[MAGAZINE] == LOC_WITTSEND)
score += 1;
mxscor += 1;
mxscor += 2;
/* Deduct for hints/turns/saves. Hints < 4 are special; see database desc. */
- for (long i = 1; i <= HNTMAX; i++) {
+ for (long i = 0; i < NHINTS; i++) {
if (game.hinted[i])
- score = score - HINTS[i][2];
+ score = score - hints[i].penalty;
}
if (game.novice)
score -= 5;
/* Return to score command if that's where we came from. */
if (mode == scoregame) {
- SETPRM(1, score, mxscor);
- SETPRM(3, game.turns, game.turns);
- RSPEAK(GARNERED_POINTS);
+ rspeak(GARNERED_POINTS, score, mxscor, game.turns, game.turns);
}
return score;
long points = score(mode);
if (points + game.trnluz + 1 >= mxscor && game.trnluz != 0)
- RSPEAK(TOOK_LONG);
+ rspeak(TOOK_LONG);
if (points + game.saved + 1 >= mxscor && game.saved != 0)
- RSPEAK(WITHOUT_SUSPENDS);
- SETPRM(1, points, mxscor);
- SETPRM(3, game.turns, game.turns);
- RSPEAK(TOTAL_SCORE);
- for (long i = 1; i <= (long)CLSSES; i++) {
- if (CVAL[i] >= points) {
- newspeak(class_messages[i]);
- i = CVAL[i] + 1 - points;
- SETPRM(1, i, i);
- RSPEAK(NEXT_HIGHER);
+ rspeak(WITHOUT_SUSPENDS);
+ rspeak(TOTAL_SCORE, points, mxscor, game.turns, game.turns);
+ for (long i = 1; i <= (long)NCLASSES; i++) {
+ if (classes[i].threshold >= points) {
+ speak(classes[i].message);
+ i = classes[i].threshold + 1 - points;
+ rspeak(NEXT_HIGHER, i, i);
exit(0);
}
}
- RSPEAK(OFF_SCALE);
- RSPEAK(NO_HIGHER);
+ rspeak(OFF_SCALE);
+ rspeak(NO_HIGHER);
exit(0);
}