/* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1985. */
/* hack.search.c - version 1.0.3 */
extern struct monst
*makemon();
findit() /* returns number of things found */
register struct trap
*ttmp
;
register struct monst
*mtmp
;
if(u
.uswallow
) return(0);
for(lx
= u
.ux
; (num
= levl
[lx
-1][u
.uy
].typ
) && num
!= CORR
; lx
--) ;
for(hx
= u
.ux
; (num
= levl
[hx
+1][u
.uy
].typ
) && num
!= CORR
; hx
++) ;
for(ly
= u
.uy
; (num
= levl
[u
.ux
][ly
-1].typ
) && num
!= CORR
; ly
--) ;
for(hy
= u
.uy
; (num
= levl
[u
.ux
][hy
+1].typ
) && num
!= CORR
; hy
++) ;
for(zy
= ly
; zy
<= hy
; zy
++)
for(zx
= lx
; zx
<= hx
; zx
++) {
if(levl
[zx
][zy
].typ
== SDOOR
) {
} else if(levl
[zx
][zy
].typ
== SCORR
) {
} else if(ttmp
= t_at(zx
, zy
)) {
(void) makemon(PM_PIERCER
, zx
, zy
);
} else if(!ttmp
->tseen
) {
} else if(mtmp
= m_at(zx
,zy
)) if(mtmp
->mimic
){
register struct trap
*trap
;
register struct monst
*mtmp
;
pline("What are you looking for? The exit?");
for(x
= u
.ux
-1; x
< u
.ux
+2; x
++)
for(y
= u
.uy
-1; y
< u
.uy
+2; y
++) if(x
!= u
.ux
|| y
!= u
.uy
) {
if(levl
[x
][y
].typ
== SDOOR
) {
levl
[x
][y
].seen
= 0; /* force prl */
} else if(levl
[x
][y
].typ
== SCORR
) {
levl
[x
][y
].seen
= 0; /* force prl */
/* Be careful not to find anything in an SCORR or SDOOR */
if(mtmp
= m_at(x
,y
)) if(mtmp
->mimic
){
pline("You find a mimic.");
for(trap
= ftrap
; trap
; trap
= trap
->ntrap
)
if(trap
->tx
== x
&& trap
->ty
== y
&&
!trap
->tseen
&& !rn2(8)) {
pline("You find a%s.", traps
[trap
->ttyp
]);
if(trap
->ttyp
== PIERC
) {
(void) makemon(PM_PIERCER
,x
,y
);
if(!vism_at(x
,y
)) atl(x
,y
,'^');
register struct trap
*trap
;
if(!getdir(1)) return(0);
for(trap
= ftrap
; trap
; trap
= trap
->ntrap
)
if(trap
->tx
== x
&& trap
->ty
== y
&& trap
->tseen
) {
if((u
.dz
< 0) != (!xdnstair
&& trap
->ttyp
== TRAPDOOR
))
pline("That is a%s.", traps
[trap
->ttyp
]);
pline("I can't see a trap there.");
register struct monst
*mtmp
;
if(mtmp
->mimic
) seemimic(mtmp
);
/* NOTE: we must check if(mtmp->mimic) before calling this routine */
register struct monst
*mtmp
;