X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=funcs.h;h=e21fbd4be80aaa8ae544cd279b7a039a5c5490bf;hb=cc927058915e82c5e544748cf0414394278af693;hp=e86fb2cdf4bf90869c4d3bd411ea0f036bda47b4;hpb=18767d52dd053cf6c851ded2597697674ca255c1;p=open-adventure.git diff --git a/funcs.h b/funcs.h index e86fb2c..e21fbd4 100644 --- a/funcs.h +++ b/funcs.h @@ -1,4 +1,5 @@ #include +#include "database.h" /* Statement functions * @@ -14,30 +15,35 @@ * PCT(N) = true N% of the time (N integer from 0 to 100) * TOTING(OBJ) = true if the OBJ is being carried */ -#define TOTING(OBJ) (PLACE[OBJ] == -1) -#define AT(OBJ) (PLACE[OBJ] == LOC || FIXED[OBJ] == LOC) +#define TOTING(OBJ) (game.place[OBJ] == -1) +#define AT(OBJ) (game.place[OBJ] == game.loc || game.fixed[OBJ] == game.loc) #define HERE(OBJ) (AT(OBJ) || TOTING(OBJ)) #define LIQ2(PBOTL) ((1-(PBOTL))*WATER+((PBOTL)/2)*(WATER+OIL)) -#define LIQ(DUMMY) (LIQ2(PROP[BOTTLE]<0 ? -1-PROP[BOTTLE] : PROP[BOTTLE])) +#define LIQ(DUMMY) (LIQ2(game.prop[BOTTLE]<0 ? -1-game.prop[BOTTLE] : game.prop[BOTTLE])) #define LIQLOC(LOC) (LIQ2((MOD(COND[LOC]/2*2,8)-5)*MOD(COND[LOC]/4,2)+1)) #define CNDBIT(L,N) (TSTBIT(COND[L],N)) #define FORCED(LOC) (COND[LOC] == 2) -#define DARK(DUMMY) ((!CNDBIT(LOC,0)) && (PROP[LAMP] == 0 || !HERE(LAMP))) -#define PCT(N) (RAN(100) < (N)) +#define DARK(DUMMY) ((!CNDBIT(game.loc,0)) && (game.prop[LAMP] == 0 || !HERE(LAMP))) +#define PCT(N) (randrange(100) < (N)) #define GSTONE(OBJ) ((OBJ) == EMRALD || (OBJ) == RUBY || (OBJ) == AMBER || (OBJ) == SAPPH) #define FOREST(LOC) ((LOC) >= 145 && (LOC) <= 166) #define VOCWRD(LETTRS,SECT) (VOCAB(MAKEWD(LETTRS),SECT)) -/* The following two functions were added to fix a bug (CLOCK1 decremented +/* The following two functions were added to fix a bug (game.clock1 decremented * while in forest). They should probably be replaced by using another * "cond" bit. For now, however, a quick fix... OUTSID(LOC) is true if * LOC is outside, INDEEP(LOC) is true if LOC is "deep" in the cave (hall - * of mists or deeper). Note special kludges for "FOOF" locs. */ + * of mists or deeper). Note special kludges for "Foof!" locs. */ #define OUTSID(LOC) ((LOC) <= 8 || FOREST(LOC) || (LOC) == PLAC[SAPPH] || (LOC) == 180 || (LOC) == 182) #define INDEEP(LOC) ((LOC) >= 15 && !OUTSID(LOC) && (LOC) != 179) -extern int carry(void), discard(bool), attack(void), throw(void), feed(void), fill(void); +extern int carry(long); +extern int discard(long, bool); +extern int attack(FILE *, long, long); +extern int throw(FILE *, long, long); +extern int feed(long); +extern int fill(long); void score(long);