5 * AT(OBJ) = TRUE IF ON EITHER SIDE OF TWO-PLACED OBJECT
6 * CNDBIT(L,N) = TRUE IF COND(L) HAS BIT N SET (BIT 0 IS UNITS BIT)
7 * DARK(DUMMY) = TRUE IF LOCATION "LOC" IS DARK
8 * FORCED(LOC) = TRUE IF LOC MOVES WITHOUT ASKING FOR INPUT (COND=2)
9 * FOREST(LOC) = TRUE IF LOC IS PART OF THE FOREST
10 * GSTONE(OBJ) = TRUE IF OBJ IS A GEMSTONE
11 * HERE(OBJ) = TRUE IF THE OBJ IS AT "LOC" (OR IS BEING CARRIED)
12 * LIQ(DUMMY) = OBJECT NUMBER OF LIQUID IN BOTTLE
13 * LIQLOC(LOC) = OBJECT NUMBER OF LIQUID (IF ANY) AT LOC
14 * PCT(N) = TRUE N% OF THE TIME (N INTEGER FROM 0 TO 100)
15 * TOTING(OBJ) = TRUE IF THE OBJ IS BEING CARRIED */
17 #define TOTING(OBJ) (PLACE[OBJ] == -1)
18 #define AT(OBJ) (PLACE[OBJ] == LOC || FIXED[OBJ] == LOC)
19 #define HERE(OBJ) (AT(OBJ) || TOTING(OBJ))
20 #define LIQ2(PBOTL) ((1-(PBOTL))*WATER+((PBOTL)/2)*(WATER+OIL))
21 #define LIQ(DUMMY) (LIQ2(PROP[BOTTLE]<0 ? -1-PROP[BOTTLE] : PROP[BOTTLE]))
22 #define LIQLOC(LOC) (LIQ2((MOD(COND[LOC]/2*2,8)-5)*MOD(COND[LOC]/4,2)+1))
23 #define CNDBIT(L,N) (TSTBIT(COND[L],N))
24 #define FORCED(LOC) (COND[LOC] == 2)
25 #define DARK(DUMMY) ((!CNDBIT(LOC,0)) && (PROP[LAMP] == 0 || !HERE(LAMP)))
26 #define PCT(N) (RAN(100) < (N))
27 #define GSTONE(OBJ) ((OBJ) == EMRALD || (OBJ) == RUBY || (OBJ) == AMBER || (OBJ) == SAPPH)
28 #define FOREST(LOC) ((LOC) >= 145 && (LOC) <= 166)
29 #define VOCWRD(LETTRS,SECT) (VOCAB(MAKEWD(LETTRS),SECT))
31 /* THE FOLLOWING TWO FUNCTIONS WERE ADDED TO FIX A BUG (CLOCK1 DECREMENTED
32 * WHILE IN FOREST). THEY SHOULD PROBABLY BE REPLACED BY USING ANOTHER
33 * "COND" BIT. FOR NOW, HOWEVER, A QUICK FIX... OUTSID(LOC) IS TRUE IF
34 * LOC IS OUTSIDE, INDEEP(LOC) IS TRUE IF LOC IS "DEEP" IN THE CAVE (HALL
35 * OF MISTS OR DEEPER). NOTE SPECIAL KLUDGES FOR "FOOF" LOCS. */
37 #define OUTSID(LOC) ((LOC) <= 8 || FOREST(LOC) || (LOC) == PLAC[SAPPH] || (LOC) == 180 || (LOC) == 182)
38 #define INDEEP(LOC) ((LOC) >= 15 && !OUTSID(LOC) && (LOC) != 179)
40 extern int carry(void), discard(bool), attack(void), throw(void), feed(void), fill(void);