More boolification.
[open-adventure.git] / score.c
1 #include <stdlib.h>
2 #include "misc.h"
3 #include "main.h"
4 #include "share.h"
5
6 /*
7  * SCORING AND WRAP-UP
8  */
9
10 void score(long MODE) {
11         /* <0 if scoring, >0 if quitting, =0 if died or won */
12
13 /*  THE PRESENT SCORING ALGORITHM IS AS FOLLOWS:
14  *     OBJECTIVE:          POINTS:        PRESENT TOTAL POSSIBLE:
15  *  GETTING WELL INTO CAVE   25                    25
16  *  EACH TREASURE < CHEST    12                    60
17  *  TREASURE CHEST ITSELF    14                    14
18  *  EACH TREASURE > CHEST    16                   224
19  *  SURVIVING             (MAX-NUM)*10             30
20  *  NOT QUITTING              4                     4
21  *  REACHING "CLOSNG"        25                    25
22  *  "CLOSED": QUIT/KILLED    10
23  *            KLUTZED        25
24  *            WRONG WAY      30
25  *            SUCCESS        45                    45
26  *  CAME TO WITT'S END        1                     1
27  *  ROUND OUT THE TOTAL       2                     2
28  *                                       TOTAL:   430
29  *  POINTS CAN ALSO BE DEDUCTED FOR USING HINTS OR TOO MANY TURNS, OR FOR
30  *  SAVING INTERMEDIATE POSITIONS. */
31
32 L20000: SCORE=0;
33         MXSCOR=0;
34
35 /*  FIRST TALLY UP THE TREASURES.  MUST BE IN BUILDING AND NOT BROKEN.
36  *  GIVE THE POOR GUY 2 POINTS JUST FOR FINDING EACH TREASURE. */
37
38         /* 20010 */ for (I=50; I<=MAXTRS; I++) {
39         if(PTEXT[I] == 0) goto L20010;
40         K=12;
41         if(I == CHEST)K=14;
42         if(I > CHEST)K=16;
43         if(PROP[I] >= 0)SCORE=SCORE+2;
44         if(PLACE[I] == 3 && PROP[I] == 0)SCORE=SCORE+K-2;
45         MXSCOR=MXSCOR+K;
46 L20010: /*etc*/ ;
47         } /* end loop */
48
49 /*  NOW LOOK AT HOW HE FINISHED AND HOW FAR HE GOT.  MAXDIE AND NUMDIE TELL US
50  *  HOW WELL HE SURVIVED.  DFLAG WILL
51  *  TELL US IF HE EVER GOT SUITABLY DEEP INTO THE CAVE.  CLOSNG STILL INDICATES
52  *  WHETHER HE REACHED THE ENDGAME.  AND IF HE GOT AS FAR AS "CAVE CLOSED"
53  *  (INDICATED BY "CLOSED"), THEN BONUS IS ZERO FOR MUNDANE EXITS OR 133, 134,
54  *  135 IF HE BLEW IT (SO TO SPEAK). */
55
56         SCORE=SCORE+(MAXDIE-NUMDIE)*10;
57         MXSCOR=MXSCOR+MAXDIE*10;
58         if(MODE == 0)SCORE=SCORE+4;
59         MXSCOR=MXSCOR+4;
60         if(DFLAG != 0)SCORE=SCORE+25;
61         MXSCOR=MXSCOR+25;
62         if(CLOSNG)SCORE=SCORE+25;
63         MXSCOR=MXSCOR+25;
64         if(!CLOSED) goto L20020;
65         if(BONUS == 0)SCORE=SCORE+10;
66         if(BONUS == 135)SCORE=SCORE+25;
67         if(BONUS == 134)SCORE=SCORE+30;
68         if(BONUS == 133)SCORE=SCORE+45;
69 L20020: MXSCOR=MXSCOR+45;
70
71 /*  DID HE COME TO WITT'S END AS HE SHOULD? */
72
73         if(PLACE[MAGZIN] == 108)SCORE=SCORE+1;
74         MXSCOR=MXSCOR+1;
75
76 /*  ROUND IT OFF. */
77
78         SCORE=SCORE+2;
79         MXSCOR=MXSCOR+2;
80
81 /*  DEDUCT FOR HINTS/TURNS/SAVES.  HINTS < 4 ARE SPECIAL; SEE DATABASE DESC. */
82
83         /* 20030 */ for (I=1; I<=HNTMAX; I++) {
84 L20030: if(HINTED[I])SCORE=SCORE-HINTS[I][2];
85         } /* end loop */
86         if(NOVICE)SCORE=SCORE-5;
87         if(CLSHNT)SCORE=SCORE-10;
88         SCORE=SCORE-TRNLUZ-SAVED;
89
90 /*  RETURN TO SCORE COMMAND IF THAT'S WHERE WE CAME FROM. */
91
92         if(MODE < 0) return;
93
94 /*  THAT SHOULD BE GOOD ENOUGH.  LET'S TELL HIM ALL ABOUT IT. */
95
96         if(SCORE+TRNLUZ+1 >= MXSCOR && TRNLUZ != 0)RSPEAK(242);
97         if(SCORE+SAVED+1 >= MXSCOR && SAVED != 0)RSPEAK(143);
98         SETPRM(1,SCORE,MXSCOR);
99         SETPRM(3,TURNS,TURNS);
100         RSPEAK(262);
101         /* 20200 */ for (I=1; I<=CLSSES; I++) {
102         if(CVAL[I] >= SCORE) goto L20210;
103 L20200: /*etc*/ ;
104         } /* end loop */
105         SPK=265;
106          goto L25000;
107
108 L20210: SPEAK(CTEXT[I]);
109         SPK=264;
110         if(I >= CLSSES) goto L25000;
111         I=CVAL[I]+1-SCORE;
112         SETPRM(1,I,I);
113         SPK=263;
114 L25000: RSPEAK(SPK);
115         exit(0);
116
117 }