hack.bones.c 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. /* $NetBSD: hack.bones.c,v 1.6 2003/04/02 18:36:35 jsm Exp $ */
  2. /*
  3. * Copyright (c) 1985, Stichting Centrum voor Wiskunde en Informatica,
  4. * Amsterdam
  5. * All rights reserved.
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions are
  9. * met:
  10. *
  11. * - Redistributions of source code must retain the above copyright notice,
  12. * this list of conditions and the following disclaimer.
  13. *
  14. * - Redistributions in binary form must reproduce the above copyright
  15. * notice, this list of conditions and the following disclaimer in the
  16. * documentation and/or other materials provided with the distribution.
  17. *
  18. * - Neither the name of the Stichting Centrum voor Wiskunde en
  19. * Informatica, nor the names of its contributors may be used to endorse or
  20. * promote products derived from this software without specific prior
  21. * written permission.
  22. *
  23. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
  24. * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
  25. * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
  26. * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
  27. * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  28. * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  29. * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  30. * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
  31. * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  32. * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  33. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  34. */
  35. /*
  36. * Copyright (c) 1982 Jay Fenlason <hack@gnu.org>
  37. * All rights reserved.
  38. *
  39. * Redistribution and use in source and binary forms, with or without
  40. * modification, are permitted provided that the following conditions
  41. * are met:
  42. * 1. Redistributions of source code must retain the above copyright
  43. * notice, this list of conditions and the following disclaimer.
  44. * 2. Redistributions in binary form must reproduce the above copyright
  45. * notice, this list of conditions and the following disclaimer in the
  46. * documentation and/or other materials provided with the distribution.
  47. * 3. The name of the author may not be used to endorse or promote products
  48. * derived from this software without specific prior written permission.
  49. *
  50. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
  51. * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
  52. * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
  53. * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  54. * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  55. * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
  56. * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  57. * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
  58. * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  59. * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  60. */
  61. #include <sys/cdefs.h>
  62. #ifndef lint
  63. __RCSID("$NetBSD: hack.bones.c,v 1.6 2003/04/02 18:36:35 jsm Exp $");
  64. #endif /* not lint */
  65. #include "hack.h"
  66. #include "extern.h"
  67. #include <fcntl.h>
  68. #include <unistd.h>
  69. char bones[] = "bones_xx";
  70. /* save bones and possessions of a deceased adventurer */
  71. void
  72. savebones()
  73. {
  74. int fd;
  75. struct obj *otmp;
  76. struct trap *ttmp;
  77. struct monst *mtmp;
  78. if (dlevel <= 0 || dlevel > MAXLEVEL)
  79. return;
  80. if (!rn2(1 + dlevel / 2))
  81. return; /* not so many ghosts on low levels */
  82. bones[6] = '0' + (dlevel / 10);
  83. bones[7] = '0' + (dlevel % 10);
  84. if ((fd = open(bones, O_RDONLY)) >= 0) {
  85. (void) close(fd);
  86. return;
  87. }
  88. /* drop everything; the corpse's possessions are usually cursed */
  89. otmp = invent;
  90. while (otmp) {
  91. otmp->ox = u.ux;
  92. otmp->oy = u.uy;
  93. otmp->age = 0; /* very long ago */
  94. otmp->owornmask = 0;
  95. if (rn2(5))
  96. otmp->cursed = 1;
  97. if (!otmp->nobj) {
  98. otmp->nobj = fobj;
  99. fobj = invent;
  100. invent = 0; /* superfluous */
  101. break;
  102. }
  103. otmp = otmp->nobj;
  104. }
  105. if (!(mtmp = makemon(PM_GHOST, u.ux, u.uy)))
  106. return;
  107. mtmp->mx = u.ux;
  108. mtmp->my = u.uy;
  109. mtmp->msleep = 1;
  110. (void) strcpy((char *) mtmp->mextra, plname);
  111. mkgold(somegold() + d(dlevel, 30), u.ux, u.uy);
  112. for (mtmp = fmon; mtmp; mtmp = mtmp->nmon) {
  113. mtmp->m_id = 0;
  114. if (mtmp->mtame) {
  115. mtmp->mtame = 0;
  116. mtmp->mpeaceful = 0;
  117. }
  118. mtmp->mlstmv = 0;
  119. if (mtmp->mdispl)
  120. unpmon(mtmp);
  121. }
  122. for (ttmp = ftrap; ttmp; ttmp = ttmp->ntrap)
  123. ttmp->tseen = 0;
  124. for (otmp = fobj; otmp; otmp = otmp->nobj) {
  125. otmp->o_id = 0;
  126. /* otmp->o_cnt_id = 0; - superfluous */
  127. otmp->onamelth = 0;
  128. otmp->known = 0;
  129. otmp->invlet = 0;
  130. if (otmp->olet == AMULET_SYM && !otmp->spe) {
  131. otmp->spe = -1; /* no longer the actual amulet */
  132. otmp->cursed = 1; /* flag as gotten from a
  133. * ghost */
  134. }
  135. }
  136. if ((fd = creat(bones, FMASK)) < 0)
  137. return;
  138. savelev(fd, dlevel);
  139. (void) close(fd);
  140. }
  141. int
  142. getbones()
  143. {
  144. int fd, x, y, ok;
  145. if (rn2(3))
  146. return (0); /* only once in three times do we find bones */
  147. bones[6] = '0' + dlevel / 10;
  148. bones[7] = '0' + dlevel % 10;
  149. if ((fd = open(bones, O_RDONLY)) < 0)
  150. return (0);
  151. if ((ok = uptodate(fd)) != 0) {
  152. getlev(fd, 0, dlevel);
  153. for (x = 0; x < COLNO; x++)
  154. for (y = 0; y < ROWNO; y++)
  155. levl[x][y].seen = levl[x][y].new = 0;
  156. }
  157. (void) close(fd);
  158. #ifdef WIZARD
  159. if (!wizard) /* duvel!frans: don't remove bones while
  160. * debugging */
  161. #endif /* WiZARD */
  162. if (unlink(bones) < 0) {
  163. pline("Cannot unlink %s .", bones);
  164. return (0);
  165. }
  166. return (ok);
  167. }