-NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.308 $ $NHDT-Date: 1600909016 2020/09/24 00:56:56 $
+NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.309 $ $NHDT-Date: 1600933440 2020/09/24 07:44:00 $
General Fixes and Modified Features
-----------------------------------
if hero attacked a peaceful monster, some other peaceful monsters with humanoid
shape (minotaur, zruty, perhaps others) that witnessed it but which
shouldn't be capable of normal speech expressed their surprise audibly
+make gasp/exclamation message from peaceful monsters be more verbose to
+ indicate which monster is doing the gasping or exclaiming
when make was invoked with -j makedefs instances could end up running in
parallel and could trample on each other's temp files; default to
using mkstemp(); allow a port runtime library implementation that lacks
-/* NetHack 3.7 extern.h $NHDT-Date: 1600652305 2020/09/21 01:38:25 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.858 $ */
+/* NetHack 3.7 extern.h $NHDT-Date: 1600933440 2020/09/24 07:44:00 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.859 $ */
/* Copyright (c) Steve Creps, 1988. */
/* NetHack may be freely redistributed. See license for details. */
E void FDECL(yelp, (struct monst *));
E void FDECL(whimper, (struct monst *));
E void FDECL(beg, (struct monst *));
-E boolean FDECL(maybe_gasp, (struct monst *));
+E const char *FDECL(maybe_gasp, (struct monst *));
E int NDECL(dotalk);
E int NDECL(tiphat);
#ifdef USER_SOUNDS
-/* NetHack 3.7 flag.h $NHDT-Date: 1593953335 2020/07/05 12:48:55 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.183 $ */
+/* NetHack 3.7 flag.h $NHDT-Date: 1600933440 2020/09/24 07:44:00 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.185 $ */
/* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1985. */
/*-Copyright (c) Michael Allison, 2006. */
/* NetHack may be freely redistributed. See license for details. */
PLNMSG_OBJNAM_ONLY, /* xname/doname only, for #tip */
PLNMSG_OK_DONT_DIE, /* overriding death in explore/wizard mode */
PLNMSG_BACK_ON_GROUND, /* leaving water */
+ PLNMSG_GROWL, /* growl() gave some message */
PLNMSG_enum /* allows inserting new entries with unconditional trailing comma */
};
-/* NetHack 3.7 mon.c $NHDT-Date: 1600652305 2020/09/21 01:38:25 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.347 $ */
+/* NetHack 3.7 mon.c $NHDT-Date: 1600933441 2020/09/24 07:44:01 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.348 $ */
/* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1985. */
/*-Copyright (c) Derek S. Ray, 2015. */
/* NetHack may be freely redistributed. See license for details. */
mtmp->mstrategy &= ~STRAT_WAITMASK;
if (!mtmp->mpeaceful)
return;
+ /* [FIXME: this logic seems wrong; peaceful humanoids gasp or exclaim
+ when they see you attack a peaceful monster but they just casually
+ look the other way when you attack a pet?] */
if (mtmp->mtame)
return;
mtmp->mpeaceful = 0;
if (!mindless(mon->data) && mon->mpeaceful
&& couldsee(mon->mx, mon->my) && !mon->msleeping
&& mon->mcansee && m_canseeu(mon)) {
- boolean exclaimed = FALSE;
+ char buf[BUFSZ];
+ boolean exclaimed = FALSE, needpunct = FALSE, alreadyfleeing;
+ buf[0] = '\0';
if (humanoid(mon->data) || mon->isshk || mon->ispriest) {
if (is_watch(mon->data)) {
verbalize("Halt! You're under arrest!");
(void) angry_guards(!!Deaf);
} else {
- if (!rn2(5)) {
- exclaimed = maybe_gasp(mon);
+ if (!Deaf && !rn2(5)) {
+ const char *gasp = maybe_gasp(mon);
+
+ if (gasp) {
+ if (!strncmpi(gasp, "gasp", 4)) {
+ Sprintf(buf, "%s gasps", Monnam(mon));
+ needpunct = TRUE;
+ } else {
+ Sprintf(buf, "%s exclaims \"%s\"",
+ Monnam(mon), gasp);
+ }
+ exclaimed = TRUE;
+ }
}
/* shopkeepers and temple priests might gasp in
surprise, but they won't become angry here */
- if (mon->isshk || mon->ispriest)
+ if (mon->isshk || mon->ispriest) {
+ if (exclaimed)
+ pline("%s%s", buf, " then shrugs.");
continue;
+ }
if (mon->data->mlevel < rn2(10)) {
+ alreadyfleeing = (mon->mflee || mon->mfleetim);
monflee(mon, rn2(50) + 25, TRUE, !exclaimed);
- exclaimed = TRUE;
+ if (exclaimed) {
+ if (flags.verbose && !alreadyfleeing) {
+ Strcat(buf, " and then turns to flee.");
+ needpunct = FALSE;
+ }
+ } else
+ exclaimed = TRUE; /* got msg from monflee() */
}
+ if (*buf)
+ pline("%s%s", buf, needpunct ? "." : "");
if (mon->mtame) {
; /* mustn't set mpeaceful to 0 as below;
* perhaps reduce tameness? */
} else if (mon->data->mlet == mtmp->data->mlet
&& big_little_match(mndx, monsndx(mon->data))
&& !rn2(3)) {
- if (!rn2(4)) {
+ if (!Deaf && !rn2(4)) {
growl(mon);
- exclaimed = TRUE;
+ exclaimed = (iflags.last_msg == PLNMSG_GROWL);
}
- if (rn2(6))
+ if (rn2(6)) {
+ alreadyfleeing = (mon->mflee || mon->mfleetim);
monflee(mon, rn2(25) + 15, TRUE, !exclaimed);
+ if (exclaimed && !alreadyfleeing)
+ /* word like a separate sentence so that we
+ don't have to poke around inside growl() */
+ pline("And then starts to flee.");
+ }
}
}
}
-/* NetHack 3.7 sounds.c $NHDT-Date: 1600652306 2020/09/21 01:38:26 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.102 $ */
+/* NetHack 3.7 sounds.c $NHDT-Date: 1600933442 2020/09/24 07:44:02 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.103 $ */
/* Copyright (c) 1989 Janet Walz, Mike Threepoint */
/* NetHack may be freely redistributed. See license for details. */
growl_verb = growl_sound(mtmp);
if (growl_verb) {
pline("%s %s!", Monnam(mtmp), vtense((char *) 0, growl_verb));
+ iflags.last_msg = PLNMSG_GROWL;
if (g.context.run)
nomul(0);
wake_nearto(mtmp->mx, mtmp->my, mtmp->data->mlevel * 18);
}
/* hero has attacked a peaceful monster within 'mon's view */
-boolean
+const char *
maybe_gasp(mon)
struct monst *mon;
{
break;
}
if (dogasp) {
- verbalize("%s", Exclam[mon->m_id % SIZE(Exclam)]);
- return TRUE;
+ return Exclam[rn2(SIZE(Exclam))]; /* [mon->m_id % SIZE(Exclam)]; */
}
- return FALSE;
+ return (const char *) 0;
}
/* return True if mon is a gecko or seems to look like one (hallucination) */