more artifact tracking
Move some code that was used to decide whether to call distant_name or doname into distant_name so that the places which were doing that don't need to anymore and fewer places can care about whether an artifact is being found. There were two or three instances of distant_name maybe being called, based on distance from hero, and yesterday's artifact livelog change added two or three more and made all of them override the distance limit for artifacts. After that change to distant_name, make sure that conditional calls to it become unconditional--just not displayed for the cases where !flags.verbose had been excluding them. That way distant_name can decide whether an item is up close and arrange for xname to find it if it as an artifact. Also, implement an old TODO. Wearing the Eyes of the Overworld extends the distance that an item can be from the hero and still be considered near anough to be seen "up close" when monsters pick it up or drop it. The explicit cases were using distu(x,y) <= 5, the distance of a knight's jump. Each quadrant around the hero is a 2x2 square with the diagonal corner chopped off. The replacement code in distant_name calculates a value of 6, which is functionally equivalent since the next value of interest beyond 5 is 8. Wearing the Eyes (deduced by having Xray vision) extends that threshold an extra step in addition to overriding blindness and seeing through walls: 15, a 3x3 square in each quadrant, still with the far diagonal corner (16) treated as out of range.
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
/* NetHack 3.7 wizard.c $NHDT-Date: 1596498229 2020/08/03 23:43:49 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.68 $ */
|
||||
/* NetHack 3.7 wizard.c $NHDT-Date: 1646688073 2022/03/07 21:21:13 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.85 $ */
|
||||
/* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1985. */
|
||||
/*-Copyright (c) Robert Patrick Rankin, 2016. */
|
||||
/* NetHack may be freely redistributed. See license for details. */
|
||||
@@ -414,9 +414,7 @@ tactics(struct monst *mtmp)
|
||||
if ((otmp = on_ground(which_arti(targ))) != 0) {
|
||||
if (cansee(mtmp->mx, mtmp->my))
|
||||
pline("%s picks up %s.", Monnam(mtmp),
|
||||
(distu(mtmp->mx, mtmp->my) <= 5)
|
||||
? doname(otmp)
|
||||
: distant_name(otmp, doname));
|
||||
distant_name(otmp, doname));
|
||||
obj_extract_self(otmp);
|
||||
(void) mpickobj(mtmp, otmp);
|
||||
return 1;
|
||||
|
||||
Reference in New Issue
Block a user