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