Refactor hinting logic to pull more code out of mainline.
This commit is contained in:
parent
bd6e402512
commit
d7ae7efd30
1 changed files with 137 additions and 123 deletions
112
main.c
112
main.c
|
@ -164,9 +164,23 @@ static bool fallback_handler(char *buf)
|
|||
return false;
|
||||
}
|
||||
|
||||
static void dohint(FILE *cmdin, int hint)
|
||||
/* Check if this loc is eligible for any hints. If been here
|
||||
* long enough, branch to help section (on later page). Hints
|
||||
* all come back here eventually to finish the loop. Ignore
|
||||
* "HINTS" < 4 (special stuff, see database notes).
|
||||
*/
|
||||
static void checkhints(FILE *cmdin)
|
||||
{
|
||||
if (COND[game.loc] >= game.conds) {
|
||||
for (int hint=1; hint<=HNTMAX; hint++) {
|
||||
if (game.hinted[hint])
|
||||
continue;
|
||||
if (!CNDBIT(game.loc,hint+10))
|
||||
game.hintlc[hint]= -1;
|
||||
++game.hintlc[hint];
|
||||
/* Come here if he's been long enough at required loc(s) for some
|
||||
* unused hint. */
|
||||
if (game.hintlc[hint] >= HINTS[hint][1])
|
||||
{
|
||||
int i;
|
||||
|
||||
|
@ -242,6 +256,9 @@ static void dohint(FILE *cmdin, int hint)
|
|||
if (game.hinted[hint] && game.limit > 30)
|
||||
game.limit=game.limit+30*HINTS[hint][2];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static bool dwarfmove(void)
|
||||
/* Dwarves move. Return true if player survives, false if he dies. */
|
||||
|
@ -786,6 +803,42 @@ static bool closecheck(void)
|
|||
return false;
|
||||
}
|
||||
|
||||
static void lampcheck(void)
|
||||
/* Check game limit and lamp timers */
|
||||
{
|
||||
if (game.prop[LAMP] == 1)
|
||||
--game.limit;
|
||||
|
||||
/* Another way we can force an end to things is by having the
|
||||
* lamp give out. When it gets close, we come here to warn
|
||||
* him. First following ar, if the lamp and fresh batteries are
|
||||
* here, in which case we replace the batteries and continue.
|
||||
* Second is for other cases of lamp dying. 12400 is when it
|
||||
* goes out. Even then, he can explore outside for a while
|
||||
* if desired. */
|
||||
if (game.limit<=30 && HERE(BATTER) && game.prop[BATTER]==0 && HERE(LAMP))
|
||||
{
|
||||
RSPEAK(188);
|
||||
game.prop[BATTER]=1;
|
||||
if (TOTING(BATTER))
|
||||
DROP(BATTER,game.loc);
|
||||
game.limit=game.limit+2500;
|
||||
game.lmwarn=false;
|
||||
} else if (game.limit == 0) {
|
||||
game.limit= -1;
|
||||
game.prop[LAMP]=0;
|
||||
if (HERE(LAMP))
|
||||
RSPEAK(184);
|
||||
} else if (game.limit <= 30) {
|
||||
if (!game.lmwarn && HERE(LAMP)) {
|
||||
game.lmwarn=true;
|
||||
int spk=187;
|
||||
if (game.place[BATTER] == 0)spk=183;
|
||||
if (game.prop[BATTER] == 1)spk=189;
|
||||
RSPEAK(spk);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static bool do_command(FILE *cmdin)
|
||||
{
|
||||
|
@ -883,32 +936,21 @@ L2004:
|
|||
* or trident, and the effects propagate. So the whole thing was flushed.
|
||||
* anyone who makes such a gross blunder isn't likely to find everything
|
||||
* else anyway (so goes the rationalisation). */
|
||||
L2006: KK=game.prop[obj];
|
||||
L2006:
|
||||
KK=game.prop[obj];
|
||||
if (obj == STEPS && game.loc == game.fixed[STEPS])KK=1;
|
||||
PSPEAK(obj,KK);
|
||||
L2008: i=game.link[i];
|
||||
L2008:
|
||||
i=game.link[i];
|
||||
goto L2004;
|
||||
|
||||
L2012: VERB=0;
|
||||
L2012:
|
||||
VERB=0;
|
||||
game.oldobj=obj;
|
||||
obj=0;
|
||||
|
||||
/* Check if this loc is eligible for any hints. If been here
|
||||
* long enough, branch to help section (on later page). Hints
|
||||
* all come back here eventually to finish the loop. Ignore
|
||||
* "HINTS" < 4 (special stuff, see database notes).
|
||||
*/
|
||||
L2600: if (COND[game.loc] >= game.conds) {
|
||||
for (int hint=1; hint<=HNTMAX; hint++) {
|
||||
if (game.hinted[hint])
|
||||
continue;
|
||||
if (!CNDBIT(game.loc,hint+10))
|
||||
game.hintlc[hint]= -1;
|
||||
++game.hintlc[hint];
|
||||
if (game.hintlc[hint] >= HINTS[hint][1])
|
||||
dohint(cmdin, hint);
|
||||
}
|
||||
}
|
||||
L2600:
|
||||
checkhints(cmdin);
|
||||
|
||||
/* If closing time, check for any objects being toted with
|
||||
* game.prop < 0 and set the prop to -1-game.prop. This way
|
||||
|
@ -957,36 +999,8 @@ L2607:
|
|||
else
|
||||
goto L19999;
|
||||
|
||||
if (game.prop[LAMP] == 1)
|
||||
--game.limit;
|
||||
lampcheck();
|
||||
|
||||
/* Another way we can force an end to things is by having the
|
||||
* lamp give out. When it gets close, we come here to warn
|
||||
* him. First following ar, if the lamp and fresh batteries are
|
||||
* here, in which case we replace the batteries and continue.
|
||||
* Second is for other cases of lamp dying. 12400 is when it
|
||||
* goes out. Even then, he can explore outside for a while
|
||||
* if desired. */
|
||||
if (game.limit<=30 && HERE(BATTER) && game.prop[BATTER]==0 && HERE(LAMP))
|
||||
{
|
||||
RSPEAK(188);
|
||||
game.prop[BATTER]=1;
|
||||
if (TOTING(BATTER))DROP(BATTER,game.loc);
|
||||
game.limit=game.limit+2500;
|
||||
game.lmwarn=false;
|
||||
} else if (game.limit == 0) {
|
||||
game.limit= -1;
|
||||
game.prop[LAMP]=0;
|
||||
if (HERE(LAMP))RSPEAK(184);
|
||||
} else if (game.limit <= 30) {
|
||||
if (!game.lmwarn && HERE(LAMP)) {
|
||||
game.lmwarn=true;
|
||||
int spk=187;
|
||||
if (game.place[BATTER] == 0)spk=183;
|
||||
if (game.prop[BATTER] == 1)spk=189;
|
||||
RSPEAK(spk);
|
||||
}
|
||||
}
|
||||
L19999:
|
||||
k=43;
|
||||
if (LIQLOC(game.loc) == WATER)k=70;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue