]>
git.cameronkatri.com Git - bsdgames-darwin.git/blob - hack/hack.bones.c
1 /* $NetBSD: hack.bones.c,v 1.9 2011/07/20 07:04:30 dholland Exp $ */
4 * Copyright (c) 1985, Stichting Centrum voor Wiskunde en Informatica,
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions are
12 * - Redistributions of source code must retain the above copyright notice,
13 * this list of conditions and the following disclaimer.
15 * - Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
19 * - Neither the name of the Stichting Centrum voor Wiskunde en
20 * Informatica, nor the names of its contributors may be used to endorse or
21 * promote products derived from this software without specific prior
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
25 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
26 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
27 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
28 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
29 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
30 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
31 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
32 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
33 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
34 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
38 * Copyright (c) 1982 Jay Fenlason <hack@gnu.org>
39 * All rights reserved.
41 * Redistribution and use in source and binary forms, with or without
42 * modification, are permitted provided that the following conditions
44 * 1. Redistributions of source code must retain the above copyright
45 * notice, this list of conditions and the following disclaimer.
46 * 2. Redistributions in binary form must reproduce the above copyright
47 * notice, this list of conditions and the following disclaimer in the
48 * documentation and/or other materials provided with the distribution.
49 * 3. The name of the author may not be used to endorse or promote products
50 * derived from this software without specific prior written permission.
52 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
53 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
54 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
55 * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
56 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
57 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
58 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
59 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
60 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
61 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
64 #include <sys/cdefs.h>
66 __RCSID("$NetBSD: hack.bones.c,v 1.9 2011/07/20 07:04:30 dholland Exp $");
74 static char bones
[] = "bones_xx";
76 /* save bones and possessions of a deceased adventurer */
85 if (dlevel
<= 0 || dlevel
> MAXLEVEL
)
87 if (!rn2(1 + dlevel
/ 2))
88 return; /* not so many ghosts on low levels */
89 bones
[6] = '0' + (dlevel
/ 10);
90 bones
[7] = '0' + (dlevel
% 10);
91 if ((fd
= open(bones
, O_RDONLY
)) >= 0) {
95 /* drop everything; the corpse's possessions are usually cursed */
100 otmp
->age
= 0; /* very long ago */
107 invent
= 0; /* superfluous */
112 if (!(mtmp
= makemon(PM_GHOST
, u
.ux
, u
.uy
)))
117 (void) strcpy((char *) mtmp
->mextra
, plname
);
118 mkgold(somegold() + d(dlevel
, 30), u
.ux
, u
.uy
);
119 for (mtmp
= fmon
; mtmp
; mtmp
= mtmp
->nmon
) {
129 for (ttmp
= ftrap
; ttmp
; ttmp
= ttmp
->ntrap
)
131 for (otmp
= fobj
; otmp
; otmp
= otmp
->nobj
) {
133 /* otmp->o_cnt_id = 0; - superfluous */
137 if (otmp
->olet
== AMULET_SYM
&& !otmp
->spe
) {
138 otmp
->spe
= -1; /* no longer the actual amulet */
139 otmp
->cursed
= 1; /* flag as gotten from a
143 if ((fd
= creat(bones
, FMASK
)) < 0)
155 return (0); /* only once in three times do we find bones */
156 bones
[6] = '0' + dlevel
/ 10;
157 bones
[7] = '0' + dlevel
% 10;
158 if ((fd
= open(bones
, O_RDONLY
)) < 0)
160 if ((ok
= uptodate(fd
)) != 0) {
161 getlev(fd
, 0, dlevel
);
162 for (x
= 0; x
< COLNO
; x
++)
163 for (y
= 0; y
< ROWNO
; y
++)
164 levl
[x
][y
].seen
= levl
[x
][y
].new = 0;
168 if (!wizard
) /* duvel!frans: don't remove bones while
171 if (unlink(bones
) < 0) {
172 pline("Cannot unlink %s .", bones
);