]>
git.cameronkatri.com Git - bsdgames-darwin.git/blob - adventure/save.c
1 /* $NetBSD: save.c,v 1.3 1997/08/11 14:06:17 christos Exp $ */
4 * Copyright (c) 1991, 1993
5 * The Regents of the University of California. All rights reserved.
7 * The game adventure was originally written in Fortran by Will Crowther
8 * and Don Woods. It was later translated to C and enhanced by Jim
9 * Gillogly. This code is derived from software contributed to Berkeley
10 * by Jim Gillogly at The Rand Corporation.
12 * Redistribution and use in source and binary forms, with or without
13 * modification, are permitted provided that the following conditions
15 * 1. Redistributions of source code must retain the above copyright
16 * notice, this list of conditions and the following disclaimer.
17 * 2. Redistributions in binary form must reproduce the above copyright
18 * notice, this list of conditions and the following disclaimer in the
19 * documentation and/or other materials provided with the distribution.
20 * 3. All advertising materials mentioning features or use of this software
21 * must display the following acknowledgement:
22 * This product includes software developed by the University of
23 * California, Berkeley and its contributors.
24 * 4. Neither the name of the University nor the names of its contributors
25 * may be used to endorse or promote products derived from this software
26 * without specific prior written permission.
28 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
41 #include <sys/cdefs.h>
44 static char sccsid
[] = "@(#)save.c 8.1 (Berkeley) 5/31/93";
46 __RCSID("$NetBSD: save.c,v 1.3 1997/08/11 14:06:17 christos Exp $");
61 struct savestruct save_array
[] =
63 { &abbnum
, sizeof(abbnum
) },
64 { &attack
, sizeof(attack
) },
65 { &blklin
, sizeof(blklin
) },
66 { &bonus
, sizeof(bonus
) },
67 { &chloc
, sizeof(chloc
) },
68 { &chloc2
, sizeof(chloc2
) },
69 { &clock1
, sizeof(clock1
) },
70 { &clock2
, sizeof(clock2
) },
71 { &closed
, sizeof(closed
) },
72 { &closng
, sizeof(closng
) },
73 { &daltlc
, sizeof(daltlc
) },
74 { &demo
, sizeof(demo
) },
75 { &detail
, sizeof(detail
) },
76 { &dflag
, sizeof(dflag
) },
77 { &dkill
, sizeof(dkill
) },
78 { &dtotal
, sizeof(dtotal
) },
79 { &foobar
, sizeof(foobar
) },
80 { &gaveup
, sizeof(gaveup
) },
81 { &holdng
, sizeof(holdng
) },
82 { &iwest
, sizeof(iwest
) },
85 { &knfloc
, sizeof(knfloc
) },
87 { &latncy
, sizeof(latncy
) },
88 { &limit
, sizeof(limit
) },
89 { &lmwarn
, sizeof(lmwarn
) },
90 { &loc
, sizeof(loc
) },
91 { &maxdie
, sizeof(maxdie
) },
92 { &mxscor
, sizeof(mxscor
) },
93 { &newloc
, sizeof(newloc
) },
94 { &numdie
, sizeof(numdie
) },
95 { &obj
, sizeof(obj
) },
96 { &oldlc2
, sizeof(oldlc2
) },
97 { &oldloc
, sizeof(oldloc
) },
98 { &panic
, sizeof(panic
) },
99 { &saved
, sizeof(saved
) },
100 { &savet
, sizeof(savet
) },
101 { &scorng
, sizeof(scorng
) },
102 { &spk
, sizeof(spk
) },
103 { &stick
, sizeof(stick
) },
104 { &tally
, sizeof(tally
) },
105 { &tally2
, sizeof(tally2
) },
106 { &tkk
, sizeof(tkk
) },
107 { &turns
, sizeof(turns
) },
108 { &verb
, sizeof(verb
) },
109 { &wd1
, sizeof(wd1
) },
110 { &wd2
, sizeof(wd2
) },
111 { &wzdark
, sizeof(wzdark
) },
112 { &yea
, sizeof(yea
) },
113 { atloc
, sizeof(atloc
) },
114 { dloc
, sizeof(dloc
) },
115 { dseen
, sizeof(dseen
) },
116 { fixed
, sizeof(fixed
) },
117 { hinted
, sizeof(hinted
) },
118 { links
, sizeof(links
) },
119 { odloc
, sizeof(odloc
) },
120 { place
, sizeof(place
) },
121 { prop
, sizeof(prop
) },
128 save(outfile
) /* Two passes on data: first to get checksum, second */
129 char *outfile
; /* to output the data using checksum to start random #s */
132 struct savestruct
*p
;
138 for (p
= save_array
; p
->address
!= NULL
; p
++)
139 sum
= crc(p
->address
, p
->width
);
142 if ((out
= fopen(outfile
, "wb")) == NULL
)
145 "Hmm. The name \"%s\" appears to be magically blocked.\n",
149 fwrite(&sum
, sizeof(sum
), 1, out
); /* Here's the random() key */
150 for (p
= save_array
; p
->address
!= NULL
; p
++)
152 for (s
= p
->address
, i
= 0; i
< p
->width
; i
++, s
++)
153 *s
= (*s
^ random()) & 0xFF; /* Lightly encrypt */
154 fwrite(p
->address
, p
->width
, 1, out
);
165 struct savestruct
*p
;
170 if ((in
= fopen(infile
, "rb")) == NULL
)
173 "Hmm. The file \"%s\" appears to be magically blocked.\n",
177 fread(&sum
, sizeof(sum
), 1, in
); /* Get the seed */
179 for (p
= save_array
; p
->address
!= NULL
; p
++)
181 fread(p
->address
, p
->width
, 1, in
);
182 for (s
= p
->address
, i
= 0; i
< p
->width
; i
++, s
++)
183 *s
= (*s
^ random()) & 0xFF; /* Lightly decrypt */
187 crc_start(); /* See if she cheated */
188 for (p
= save_array
; p
->address
!= NULL
; p
++)
189 cksum
= crc(p
->address
, p
->width
);
190 if (sum
!= cksum
) /* Tsk tsk */
191 return 2; /* Altered the file */
192 /* We successfully restored, so this really was a save file */
193 /* Get rid of the file, but don't bother checking that we did */