fix #H348 - "you trip over it" after non-"it" message (trunk only)

Reported to us by <email deleted>:
  'You are beginning to feel hungry.  You trip over it.'
and also recently in the newsgroup by "<Someone>":
  There is ice here.  *You see here an electric eel corpse.*
  Bib hits the electric eel.  Bib misses the electric eel.
  Bib misses the electric eel.  The electric eel misses Bib.
  The electric eel misses Bib.  *You trip over it.*

     slip_or_trip() was oversimplifying things by assuming that if there
is one object at the hero's location, a message about what that object is
has just been given.  Any timeout message which precedes Fumbling (lots
of candiates besides hunger) could intervene, as could monster activity
between the hero's move and timeout handling.  Aside from the reported
cases, that code hadn't been updated to account for the new pile_limit
option which could be set to 1 and force a popup display instead of the
usual "you see <an item> here".  This fix adds a flag that can be used
to track the most recent message.  It is cleared by pline for every
message, so pline's caller sets it _after_ the message of interest has
been displayed.
This commit is contained in:
nethack.rankin
2007-06-10 03:01:31 +00:00
parent 8dbbd1d2d0
commit 283b681072
6 changed files with 16 additions and 3 deletions

View File

@@ -246,6 +246,8 @@ applying an unpaid stack of potions of oil forced hero to buy all of them
instead of just the one which got split off and lit
sometimes when hero is forced to buy an unpaid shop item its price changed
monster could attack with a polearm even after attempt to wield that failed
sometimes got "you trip over it" after intervening messages following the
once which described "it"
Platform- and/or Interface-Specific Fixes

View File

@@ -159,6 +159,7 @@ struct instance_flags {
* a structure of their own elsewhere some day.
*/
int in_lava_effects; /* hack for Boots_off() */
int last_msg; /* indicator of last message player saw */
int purge_monsters; /* # of dead monsters still on fmon list */
int override_ID; /* true to force full identification of objects */
int suppress_price; /* controls doname() for unpaid objects */
@@ -320,6 +321,10 @@ extern NEARDATA struct sysflag sysflags;
#endif
extern NEARDATA struct instance_flags iflags;
/* last_msg values */
#define PLNMSG_UNKNOWN 0 /* arbitrary */
#define PLNMSG_ONE_ITEM_HERE 1 /* "you see <single item> here" */
/* runmode options */
#define RUN_TPORT 0 /* don't update display until movement stops */
#define RUN_LEAP 1 /* update display every 7 steps */

View File

@@ -3044,6 +3044,8 @@ char def;
{
char qbuf[QBUFSZ];
iflags.last_msg = PLNMSG_UNKNOWN; /* most recent pline is clobbered */
/* maximum acceptable length is QBUFSZ-1 */
if (strlen(query) < QBUFSZ)
return (*windowprocs.win_yn_function)(query, resp, def);

View File

@@ -2450,6 +2450,7 @@ boolean picked_some;
if (otmp->oinvis && !See_invisible) verb = "feel";
#endif
You("%s here %s.", verb, doname(otmp));
iflags.last_msg = PLNMSG_ONE_ITEM_HERE;
if (otmp->otyp == CORPSE) feel_cockatrice(otmp, FALSE);
} else {
char buf[BUFSZ];

View File

@@ -73,6 +73,7 @@ pline VA_DECL(const char *, line)
}
if (!iflags.window_inited) {
raw_print(line);
iflags.last_msg = PLNMSG_UNKNOWN;
return;
}
#ifndef MAC
@@ -86,6 +87,8 @@ pline VA_DECL(const char *, line)
if (vision_full_recalc) vision_recalc(0);
if (u.ux) flush_screen(1); /* %% */
putstr(WIN_MESSAGE, 0, line);
/* this gets cleared after every pline message */
iflags.last_msg = PLNMSG_UNKNOWN;
}
/*VARARGS1*/

View File

@@ -656,7 +656,7 @@ STATIC_OVL void
slip_or_trip()
{
struct obj *otmp = vobj_at(u.ux, u.uy);
const char *what, *pronoun;
const char *what;
char buf[BUFSZ];
boolean on_foot = TRUE;
#ifdef STEED
@@ -673,8 +673,8 @@ slip_or_trip()
name; if not, look for rocks to trip over; trip over
anonymous "something" if there aren't any rocks.
*/
pronoun = otmp->quan == 1L ? "it" : Hallucination ? "they" : "them";
what = !otmp->nexthere ? pronoun :
what = (iflags.last_msg == PLNMSG_ONE_ITEM_HERE) ?
((otmp->quan == 1L) ? "it" : Hallucination ? "they" : "them") :
(otmp->dknown || !Blind) ? doname(otmp) :
((otmp = sobj_at(ROCK, u.ux, u.uy)) == 0 ? something :
(otmp->quan == 1L ? "a rock" : "some rocks"));