save.c revision 1.11 1 /* $NetBSD: save.c,v 1.11 2005/07/01 01:12:39 jmc Exp $ */
2
3 /*
4 * Copyright (c) 1980, 1993
5 * The Regents of the University of California. 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
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. Neither the name of the University nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * SUCH DAMAGE.
30 */
31
32 #include <sys/cdefs.h>
33 #ifndef lint
34 #if 0
35 static char sccsid[] = "@(#)save.c 8.1 (Berkeley) 5/31/93";
36 #else
37 __RCSID("$NetBSD: save.c,v 1.11 2005/07/01 01:12:39 jmc Exp $");
38 #endif
39 #endif /* not lint */
40
41 #include <errno.h>
42
43 #include "back.h"
44
45 static const char confirm[] = "Are you sure you want to leave now?";
46 static const char prompt[] = "Enter a file name: ";
47 static const char exist1[] = "The file '";
48 static const char exist2[] =
49 "' already exists.\nAre you sure you want to use this file?";
50 static const char cantuse[] = "\nCan't use ";
51 static const char saved[] = "This game has been saved on the file '";
52 static const char type[] = "'.\nType \"backgammon ";
53 static const char rec[] = "\" to recover your game.\n\n";
54 static const char cantrec[] = "Can't recover file: ";
55
56 void
57 save(int n)
58 {
59 int fdesc;
60 char *fs;
61 char fname[50];
62
63 if (n) {
64 if (tflag) {
65 curmove(20, 0);
66 clend();
67 } else
68 writec('\n');
69 writel(confirm);
70 if (!yorn(0))
71 return;
72 }
73 cflag = 1;
74 for (;;) {
75 writel(prompt);
76 fs = fname;
77 while ((*fs = readc()) != '\n') {
78 if (*fs == old.c_cc[VERASE]) {
79 if (fs > fname) {
80 fs--;
81 if (tflag)
82 curmove(curr, curc - 1);
83 else
84 writec(*fs);
85 } else
86 writec('\007');
87 continue;
88 }
89 writec(*fs++);
90 }
91 *fs = '\0';
92 if ((fdesc = open(fname, O_RDWR)) == -1 && errno == ENOENT) {
93 if ((fdesc = creat(fname, 0600)) != -1)
94 break;
95 }
96 if (fdesc != -1) {
97 if (tflag) {
98 curmove(18, 0);
99 clend();
100 } else
101 writec('\n');
102 writel(exist1);
103 writel(fname);
104 writel(exist2);
105 cflag = 0;
106 close(fdesc);
107 if (yorn(0)) {
108 unlink(fname);
109 fdesc = creat(fname, 0600);
110 break;
111 } else {
112 cflag = 1;
113 continue;
114 }
115 }
116 writel(cantuse);
117 writel(fname);
118 writel(".\n");
119 close(fdesc);
120 cflag = 1;
121 }
122 write(fdesc, board, sizeof board);
123 write(fdesc, off, sizeof off);
124 write(fdesc, in, sizeof in);
125 write(fdesc, dice, sizeof dice);
126 write(fdesc, &cturn, sizeof cturn);
127 write(fdesc, &dlast, sizeof dlast);
128 write(fdesc, &pnum, sizeof pnum);
129 write(fdesc, &rscore, sizeof rscore);
130 write(fdesc, &wscore, sizeof wscore);
131 write(fdesc, &gvalue, sizeof gvalue);
132 write(fdesc, &raflag, sizeof raflag);
133 close(fdesc);
134 if (tflag)
135 curmove(18, 0);
136 writel(saved);
137 writel(fname);
138 writel(type);
139 writel(fname);
140 writel(rec);
141 if (tflag)
142 clend();
143 getout(0);
144 }
145
146 void
147 recover(const char *s)
148 {
149 int fdesc;
150
151 if ((fdesc = open(s, O_RDONLY)) == -1)
152 norec(s);
153 read(fdesc, board, sizeof board);
154 read(fdesc, off, sizeof off);
155 read(fdesc, in, sizeof in);
156 read(fdesc, dice, sizeof dice);
157 read(fdesc, &cturn, sizeof cturn);
158 read(fdesc, &dlast, sizeof dlast);
159 read(fdesc, &pnum, sizeof pnum);
160 read(fdesc, &rscore, sizeof rscore);
161 read(fdesc, &wscore, sizeof wscore);
162 read(fdesc, &gvalue, sizeof gvalue);
163 read(fdesc, &raflag, sizeof raflag);
164 close(fdesc);
165 rflag = 1;
166 }
167
168 void
169 norec(const char *s)
170 {
171 const char *c;
172
173 tflag = 0;
174 writel(cantrec);
175 c = s;
176 while (*c != '\0')
177 writec(*c++);
178 getout(0);
179 }
180