Below is the full text to savelev.h from the source code of Hack 1.0. To link to a particular line, write [[Hack 1.0/savelev.h#line123]], for example.
Warning! This is the source code from an old release. For the latest release, see Source code.
The Usenet post in which this file was originally distributed is not archived at Google Groups. No copy is known to be publicly available. This file is reconstructed from later versions and may not match the original distribution exactly.
Screenshots and source code from Hack are used under the CWI license. |
1. /* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1984. */ 2. 3. #include "hack.h" 4. #include <stdio.h> 5. extern struct monst *restmonchn(); 6. extern struct obj *restobjchn(); 7. extern struct obj *billobjs; 8. extern char *itoa(); 9. 10. extern char nul[]; 11. #ifndef NOWORM 12. #include "def.wseg.h" 13. 14. extern struct wseg *wsegs[32], *wheads[32]; 15. extern long wgrowtime[32]; 16. #endif NOWORM 17. 18. savelev(fd){ 19. #ifndef NOWORM 20. register struct wseg *wtmp, *wtmp2; 21. register int tmp; 22. #endif NOWORM 23. 24. if(fd < 0) 25. panic("Save on bad file!"); 26. 27. bwrite(fd,(char *) levl,sizeof(levl)); 28. bwrite(fd,(char *) &moves,sizeof(long)); 29. bwrite(fd,(char *) &xupstair,sizeof(xupstair)); 30. bwrite(fd,(char *) &yupstair,sizeof(yupstair)); 31. bwrite(fd,(char *) &xdnstair,sizeof(xdnstair)); 32. bwrite(fd,(char *) &ydnstair,sizeof(ydnstair)); 33. savemonchn(fd, fmon); 34. savegenchn(fd, fgold); 35. savegenchn(fd, ftrap); 36. saveobjchn(fd, fobj); 37. saveobjchn(fd, billobjs); 38. /* if (!ismklev) */ 39. billobjs = 0; 40. bwrite(fd,(char *) nul, sizeof(unsigned)); 41. #ifndef QUEST 42. bwrite(fd,(char *) rooms,sizeof(rooms)); 43. bwrite(fd,(char *) doors,sizeof(doors)); 44. save_engravings(fd); 45. #endif QUEST 46. /* if (!ismklev) */ 47. { 48. fgold = ftrap = 0; 49. fmon = 0; 50. fobj = 0; 51. } 52. /*--------------------------------------------------------------------*/ 53. #ifndef NOWORM 54. bwrite(fd,(char *) wsegs,sizeof(wsegs)); 55. for(tmp=1; tmp<32; tmp++){ 56. for(wtmp = wsegs[tmp]; wtmp; wtmp = wtmp2){ 57. wtmp2 = wtmp->nseg; 58. bwrite(fd,(char *) wtmp,sizeof(struct wseg)); 59. } 60. /* if (!ismklev) */ 61. wsegs[tmp] = 0; 62. } 63. bwrite(fd,(char *) wgrowtime,sizeof(wgrowtime)); 64. #endif NOWORM 65. /*--------------------------------------------------------------------*/ 66. } 67. 68. bwrite(fd,loc,num) 69. register int fd; 70. register char *loc; 71. register unsigned num; 72. { 73. /* lint wants the 3rd arg of write to be an int; lint -p an unsigned */ 74. if(write(fd, loc, (int) num) != num) 75. panic("cannot write %d bytes to file #%d",num,fd); 76. } 77. 78. saveobjchn(fd,otmp) 79. register int fd; 80. register struct obj *otmp; 81. { 82. register struct obj *otmp2; 83. unsigned xl; 84. int minusone = -1; 85. 86. while(otmp) { 87. otmp2 = otmp->nobj; 88. xl = otmp->onamelth; 89. bwrite(fd, (char *) &xl, sizeof(int)); 90. bwrite(fd, (char *) otmp, xl + sizeof(struct obj)); 91. /* if (!ismklev) */ 92. free((char *) otmp); 93. otmp = otmp2; 94. } 95. bwrite(fd, (char *) &minusone, sizeof(int)); 96. } 97. 98. savemonchn(fd,mtmp) 99. register int fd; 100. register struct monst *mtmp; 101. { 102. register struct monst *mtmp2; 103. unsigned xl; 104. int minusone = -1; 105. int monnum; 106. #ifdef FUNNYRELOC 107. struct permonst *monbegin = &mons[0]; 108. 109. bwrite(fd, (char *) &monbegin, sizeof(monbegin)); 110. #endif 111. 112. while(mtmp) { 113. mtmp2 = mtmp->nmon; 114. xl = mtmp->mxlth + mtmp->mnamelth; 115. bwrite(fd, (char *) &xl, sizeof(int)); 116. 117. /* JAT - just save the offset into the monster table, */ 118. /* it will be relocated when read in */ 119. monnum = mtmp->data - &mons[0]; 120. mtmp->data = (struct permonst *)monnum; 121. #ifdef DEBUGMON 122. myprintf("Wrote monster #%d", monnum); 123. #endif 124. bwrite(fd, (char *) mtmp, xl + sizeof(struct monst)); 125. if(mtmp->minvent) saveobjchn(fd,mtmp->minvent); 126. /* if (!ismklev) */ 127. free((char *) mtmp); 128. mtmp = mtmp2; 129. } 130. bwrite(fd, (char *) &minusone, sizeof(int)); 131. } 132. 133. savegenchn(fd,gtmp) 134. register int fd; 135. register struct gen *gtmp; 136. { 137. register struct gen *gtmp2; 138. while(gtmp) { 139. gtmp2 = gtmp->ngen; 140. bwrite(fd, (char *) gtmp, sizeof(struct gen)); 141. /* if (!ismklev) */ 142. free((char *) gtmp); 143. gtmp = gtmp2; 144. } 145. bwrite(fd, nul, sizeof(struct gen)); 146. } 147. 148.