container status bits (trunk only)

Couple of post-3.4.3 things:  using ':' to view the contents when
looting or applying a container wasn't setting its cknown flag (contents
known); probing a container wasn't setting lknown flag (lock state known).
This commit is contained in:
nethack.rankin
2005-11-03 06:15:59 +00:00
parent 7921c6ea3e
commit b9ae4361af
3 changed files with 10 additions and 5 deletions

View File

@@ -1,4 +1,4 @@
/* SCCS Id: @(#)end.c 3.5 2005/03/11 */
/* SCCS Id: @(#)end.c 3.5 2005/11/02 */
/* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1985. */
/* NetHack may be freely redistributed. See license for details. */
@@ -972,6 +972,8 @@ boolean identified, all_containers;
for (box = list; box; box = box->nobj) {
if (Is_container(box) || box->otyp == STATUE) {
box->cknown = 1; /* we're looking at the contents now */
if (identified) box->lknown = 1;
cat = deadcat = FALSE;
if (box->otyp == LARGE_BOX &&
box->spe == 1 && !Schroedingers_cat) {
@@ -980,7 +982,6 @@ boolean identified, all_containers;
if (cat) Schroedingers_cat = TRUE;
else deadcat = TRUE;
box->spe = 0;
box->cknown = box->lknown = 1;
}
if (box->otyp == BAG_OF_TRICKS) {
continue; /* wrong type of container */

View File

@@ -1,4 +1,4 @@
/* SCCS Id: @(#)pickup.c 3.5 2005/06/02 */
/* SCCS Id: @(#)pickup.c 3.5 2005/11/02 */
/* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1985. */
/* NetHack may be freely redistributed. See license for details. */
@@ -219,6 +219,10 @@ ask_again:
else if (sym == 'a') *everything = TRUE;
else if (sym == ':') {
simple_look(objs, here); /* dumb if objs==invent */
/* if we just scanned the contents of a container
then mark it as having known contents */
if (objs->where == OBJ_CONTAINED)
objs->ocontainer->cknown = 1;
goto ask_again;
} else if (sym == 'i') {
(void) display_inventory((char *)0, TRUE);

View File

@@ -1,4 +1,4 @@
/* SCCS Id: @(#)zap.c 3.5 2005/09/20 */
/* SCCS Id: @(#)zap.c 3.5 2005/11/02 */
/* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1985. */
/* NetHack may be freely redistributed. See license for details. */
@@ -1527,6 +1527,7 @@ struct obj *obj, *otmp;
/* target object has now been "seen (up close)" */
obj->dknown = 1;
if (Is_container(obj) || obj->otyp == STATUE) {
obj->cknown = obj->lknown = 1;
if (!obj->cobj)
pline("%s empty.", Tobjnam(obj, "are"));
else {
@@ -1536,7 +1537,6 @@ struct obj *obj, *otmp;
o->dknown = 1; /* "seen", even if blind */
(void) display_cinventory(obj);
}
obj->cknown = 1;
res = 1;
}
if (res) makeknown(WAN_PROBING);