10 /* mode is <0 if scoring, >0 if quitting, =0 if died or won */
12 long i, score = 0, mxscor = 0;
14 /* The present scoring algorithm is as follows:
15 * Objective: Points: Present total possible:
16 * Getting well into cave 25 25
17 * Each treasure < chest 12 60
18 * Treasure chest itself 14 14
19 * Each treasure > chest 16 224
20 * Surviving (MAX-NUM)*10 30
22 * Reaching "game.closng" 25 25
23 * "Closed": Quit/Killed 10
27 * Came to Witt's End 1 1
28 * Round out the total 2 2
30 * Points can also be deducted for using hints or too many turns, or for
31 * saving intermediate positions. */
33 /* First tally up the treasures. Must be in building and not broken.
34 * Give the poor guy 2 points just for finding each treasure. */
36 for (i=MINTRS; i<=MAXTRS; i++) {
43 if(game.place[i] == 3 && game.prop[i] == 0)
49 /* Now look at how he finished and how far he got. MAXDIE and
50 * game.numdie tell us how well he survived. game.dflag will tell us
51 * if he ever got suitably deep into the cave. game.closng still
52 * indicates whether he reached the endgame. And if he got as far as
53 * "cave closed" (indicated by "game.closed"), then bonus is zero for
54 * mundane exits or 133, 134, 135 if he blew it (so to speak). */
56 score=score+(MAXDIE-game.numdie)*10;
57 mxscor=mxscor+MAXDIE*10;
58 if(mode == 0)score=score+4;
60 if(game.dflag != 0)score=score+25;
62 if(game.closng)score=score+25;
76 /* Did he come to Witt's End as he should? */
77 if(game.place[MAGZIN] == 108)
85 /* Deduct for hints/turns/saves. Hints < 4 are special; see database desc. */
86 for (i=1; i<=HNTMAX; i++) {
88 score=score-HINTS[i][2];
94 score=score-game.trnluz-game.saved;
96 /* Return to score command if that's where we came from. */
98 SETPRM(1,score,mxscor);
99 SETPRM(3,game.turns,game.turns);
104 /* that should be good enough. Let's tell him all about it. */
105 if(score+game.trnluz+1 >= mxscor && game.trnluz != 0)
107 if(score+game.saved+1 >= mxscor && game.saved != 0)
109 SETPRM(1,score,mxscor);
110 SETPRM(3,game.turns,game.turns);
112 for (i=1; i<=CLSSES; i++) {
113 if(CVAL[i] >= score) goto L20210;
118 L20210: SPEAK(CTEXT[i]);
120 if(i >= CLSSES) goto L25000;