1 1.9 christos /* $NetBSD: def.monst.h,v 1.9 2011/08/16 09:26:22 christos Exp $ */ 2 1.4 christos 3 1.2 mycroft /* 4 1.7 jsm * Copyright (c) 1985, Stichting Centrum voor Wiskunde en Informatica, 5 1.7 jsm * Amsterdam 6 1.7 jsm * All rights reserved. 7 1.7 jsm * 8 1.7 jsm * Redistribution and use in source and binary forms, with or without 9 1.7 jsm * modification, are permitted provided that the following conditions are 10 1.7 jsm * met: 11 1.7 jsm * 12 1.7 jsm * - Redistributions of source code must retain the above copyright notice, 13 1.7 jsm * this list of conditions and the following disclaimer. 14 1.7 jsm * 15 1.7 jsm * - Redistributions in binary form must reproduce the above copyright 16 1.7 jsm * notice, this list of conditions and the following disclaimer in the 17 1.7 jsm * documentation and/or other materials provided with the distribution. 18 1.7 jsm * 19 1.7 jsm * - Neither the name of the Stichting Centrum voor Wiskunde en 20 1.7 jsm * Informatica, nor the names of its contributors may be used to endorse or 21 1.7 jsm * promote products derived from this software without specific prior 22 1.7 jsm * written permission. 23 1.7 jsm * 24 1.7 jsm * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 25 1.7 jsm * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 26 1.7 jsm * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 27 1.7 jsm * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER 28 1.7 jsm * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 29 1.7 jsm * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 30 1.7 jsm * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 31 1.7 jsm * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 32 1.7 jsm * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 33 1.7 jsm * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 34 1.7 jsm * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 35 1.2 mycroft */ 36 1.7 jsm 37 1.7 jsm /* 38 1.7 jsm * Copyright (c) 1982 Jay Fenlason <hack (at) gnu.org> 39 1.7 jsm * All rights reserved. 40 1.7 jsm * 41 1.7 jsm * Redistribution and use in source and binary forms, with or without 42 1.7 jsm * modification, are permitted provided that the following conditions 43 1.7 jsm * are met: 44 1.7 jsm * 1. Redistributions of source code must retain the above copyright 45 1.7 jsm * notice, this list of conditions and the following disclaimer. 46 1.7 jsm * 2. Redistributions in binary form must reproduce the above copyright 47 1.7 jsm * notice, this list of conditions and the following disclaimer in the 48 1.7 jsm * documentation and/or other materials provided with the distribution. 49 1.7 jsm * 3. The name of the author may not be used to endorse or promote products 50 1.7 jsm * derived from this software without specific prior written permission. 51 1.7 jsm * 52 1.7 jsm * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, 53 1.7 jsm * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY 54 1.7 jsm * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL 55 1.7 jsm * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 56 1.7 jsm * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 57 1.7 jsm * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 58 1.7 jsm * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 59 1.7 jsm * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 60 1.7 jsm * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 61 1.7 jsm * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 62 1.7 jsm */ 63 1.7 jsm 64 1.4 christos #ifndef _DEF_MONST_H_ 65 1.4 christos #define _DEF_MONST_H_ 66 1.1 cgd struct monst { 67 1.1 cgd struct monst *nmon; 68 1.6 jsm const struct permonst *data; 69 1.1 cgd unsigned m_id; 70 1.1 cgd xchar mx,my; 71 1.1 cgd xchar mdx,mdy; /* if mdispl then pos where last displayed */ 72 1.1 cgd #define MTSZ 4 73 1.1 cgd coord mtrack[MTSZ]; /* monster track */ 74 1.1 cgd schar mhp,mhpmax; 75 1.1 cgd char mappearance; /* nonzero for undetected 'M's and for '1's */ 76 1.1 cgd Bitfield(mimic,1); /* undetected mimic */ 77 1.1 cgd Bitfield(mdispl,1); /* mdx,mdy valid */ 78 1.1 cgd Bitfield(minvis,1); /* invisible */ 79 1.1 cgd Bitfield(cham,1); /* shape-changer */ 80 1.1 cgd Bitfield(mhide,1); /* hides beneath objects */ 81 1.1 cgd Bitfield(mundetected,1); /* not seen in present hiding place */ 82 1.1 cgd Bitfield(mspeed,2); 83 1.1 cgd Bitfield(msleep,1); 84 1.1 cgd Bitfield(mfroz,1); 85 1.1 cgd Bitfield(mconf,1); 86 1.1 cgd Bitfield(mflee,1); /* fleeing */ 87 1.1 cgd Bitfield(mfleetim,7); /* timeout for mflee */ 88 1.1 cgd Bitfield(mcan,1); /* has been cancelled */ 89 1.1 cgd Bitfield(mtame,1); /* implies peaceful */ 90 1.1 cgd Bitfield(mpeaceful,1); /* does not attack unprovoked */ 91 1.1 cgd Bitfield(isshk,1); /* is shopkeeper */ 92 1.1 cgd Bitfield(isgd,1); /* is guard */ 93 1.1 cgd Bitfield(mcansee,1); /* cansee 1, temp.blinded 0, blind 0 */ 94 1.1 cgd Bitfield(mblinded,7); /* cansee 0, temp.blinded n, blind 0 */ 95 1.1 cgd Bitfield(mtrapped,1); /* trapped in a pit or bear trap */ 96 1.1 cgd Bitfield(mnamelth,6); /* length of name (following mxlth) */ 97 1.1 cgd #ifndef NOWORM 98 1.1 cgd Bitfield(wormno,5); /* at most 31 worms on any level */ 99 1.5 cgd #endif /* NOWORM */ 100 1.1 cgd unsigned mtrapseen; /* bitmap of traps we've been trapped in */ 101 1.1 cgd long mlstmv; /* prevent two moves at once */ 102 1.1 cgd struct obj *minvent; 103 1.1 cgd long mgold; 104 1.1 cgd unsigned mxlth; /* length of following data */ 105 1.1 cgd /* in order to prevent alignment problems mextra should 106 1.1 cgd be (or follow) a long int */ 107 1.1 cgd long mextra[1]; /* monster dependent info */ 108 1.1 cgd }; 109 1.1 cgd 110 1.8 dholland #define newmonst(xl) ((struct monst *) alloc((xl) + sizeof(struct monst))) 111 1.1 cgd 112 1.1 cgd extern struct monst *fmon; 113 1.1 cgd extern struct monst *fallen_down; 114 1.1 cgd 115 1.9 christos extern void *monster_private(struct monst *); 116 1.9 christos 117 1.1 cgd /* these are in mspeed */ 118 1.1 cgd #define MSLOW 1 /* slow monster */ 119 1.1 cgd #define MFAST 2 /* speeded monster */ 120 1.1 cgd 121 1.1 cgd #define NAME(mtmp) (((char *) mtmp->mextra) + mtmp->mxlth) 122 1.1 cgd #define MREGEN "TVi1" 123 1.1 cgd #define UNDEAD "ZVW " 124 1.4 christos #endif /* _DEF_MONST_H_ */ 125