annotate support/bboards/mmdfII/bboards/dropsbr.c @ 0:bce86c4163a3

Initial revision
author kono
date Mon, 18 Apr 2005 23:46:02 +0900
parents
children a6481689f99c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
1 /* dropsbr.c - write to a mailbox */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
2 #ifndef lint
bce86c4163a3 Initial revision
kono
parents:
diff changeset
3 static char Id[] = "@(#)$Id$";
bce86c4163a3 Initial revision
kono
parents:
diff changeset
4 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
5
bce86c4163a3 Initial revision
kono
parents:
diff changeset
6 #include <stdio.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
7 #ifndef MMDFONLY
bce86c4163a3 Initial revision
kono
parents:
diff changeset
8 #include "../h/mh.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
9 #include "../h/dropsbr.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
10 #include "../zotnet/mts.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
11 #else MMDFONLY
bce86c4163a3 Initial revision
kono
parents:
diff changeset
12 #include "dropsbr.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
13 #include "strings.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
14 #include "mmdfonly.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
15 #endif MMDFONLY
bce86c4163a3 Initial revision
kono
parents:
diff changeset
16 #include <errno.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
17 #include <sys/types.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
18 #include <sys/stat.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
19
bce86c4163a3 Initial revision
kono
parents:
diff changeset
20
bce86c4163a3 Initial revision
kono
parents:
diff changeset
21 #define MMDF 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
22 #define UUCP 2
bce86c4163a3 Initial revision
kono
parents:
diff changeset
23
bce86c4163a3 Initial revision
kono
parents:
diff changeset
24 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
25
bce86c4163a3 Initial revision
kono
parents:
diff changeset
26 static int mbx_style = MMDF;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
27
bce86c4163a3 Initial revision
kono
parents:
diff changeset
28
bce86c4163a3 Initial revision
kono
parents:
diff changeset
29 extern int errno;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
30
bce86c4163a3 Initial revision
kono
parents:
diff changeset
31 off_t lseek ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
32
bce86c4163a3 Initial revision
kono
parents:
diff changeset
33 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
34
bce86c4163a3 Initial revision
kono
parents:
diff changeset
35 int mbx_mmdf () {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
36 int style = mbx_style;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
37
bce86c4163a3 Initial revision
kono
parents:
diff changeset
38 mbx_style = MMDF;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
39 return style;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
40 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
41
bce86c4163a3 Initial revision
kono
parents:
diff changeset
42
bce86c4163a3 Initial revision
kono
parents:
diff changeset
43 int mbx_uucp () {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
44 int style = mbx_style;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
45
bce86c4163a3 Initial revision
kono
parents:
diff changeset
46 mbx_style = UUCP;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
47 return style;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
48 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
49
bce86c4163a3 Initial revision
kono
parents:
diff changeset
50 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
51
bce86c4163a3 Initial revision
kono
parents:
diff changeset
52 int mbx_open (file, uid, gid, mode)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
53 char *file;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
54 int uid,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
55 gid,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
56 mode;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
57 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
58 int clear,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
59 fd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
60
bce86c4163a3 Initial revision
kono
parents:
diff changeset
61 if ((fd = mbx_Xopen (file, uid, gid, mode, &clear)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
62 return fd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
63
bce86c4163a3 Initial revision
kono
parents:
diff changeset
64 if (!clear)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
65 switch (mbx_style) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
66 case MMDF:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
67 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
68 if (mbx_chk (fd) == NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
69 (void) close (fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
70 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
71 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
72 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
73
bce86c4163a3 Initial revision
kono
parents:
diff changeset
74 case UUCP:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
75 if (lseek (fd, (off_t)0, 2) == (off_t) NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
76 (void) close (fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
77 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
78 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
79 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
80 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
81
bce86c4163a3 Initial revision
kono
parents:
diff changeset
82 return fd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
83 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
84
bce86c4163a3 Initial revision
kono
parents:
diff changeset
85 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
86
bce86c4163a3 Initial revision
kono
parents:
diff changeset
87 int mbx_Xopen (file, uid, gid, mode, clear)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
88 char *file;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
89 int uid,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
90 gid,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
91 mode,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
92 *clear;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
93 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
94 register int j;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
95 int count,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
96 fd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
97 struct stat st;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
98
bce86c4163a3 Initial revision
kono
parents:
diff changeset
99 for (*clear = 0, count = 4, j = 0; count > 0; count--)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
100 if ((fd = lkopen (file, 6)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
101 switch (errno) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
102 case ENOENT:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
103 if (mbx_create (file, uid, gid, mode) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
104 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
105 (*clear)++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
106 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
107
bce86c4163a3 Initial revision
kono
parents:
diff changeset
108 #ifdef BSD42
bce86c4163a3 Initial revision
kono
parents:
diff changeset
109 case EWOULDBLOCK:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
110 #endif BSD42
bce86c4163a3 Initial revision
kono
parents:
diff changeset
111 case ETXTBSY:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
112 j = errno;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
113 sleep (5);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
114 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
115
bce86c4163a3 Initial revision
kono
parents:
diff changeset
116 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
117 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
118 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
119 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
120 *clear = fstat (fd, &st) != NOTOK && st.st_size == 0L;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
121 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
122 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
123
bce86c4163a3 Initial revision
kono
parents:
diff changeset
124 errno = j;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
125 return fd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
126 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
127
bce86c4163a3 Initial revision
kono
parents:
diff changeset
128 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
129
bce86c4163a3 Initial revision
kono
parents:
diff changeset
130 static int mbx_create (file, uid, gid, mode)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
131 char *file;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
132 int uid,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
133 gid,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
134 mode;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
135 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
136 int fd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
137
bce86c4163a3 Initial revision
kono
parents:
diff changeset
138 if ((fd = creat (file, 0600)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
139 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
140
bce86c4163a3 Initial revision
kono
parents:
diff changeset
141 (void) close (fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
142 (void) chown (file, uid, gid);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
143 (void) chmod (file, mode);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
144
bce86c4163a3 Initial revision
kono
parents:
diff changeset
145 return OK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
146 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
147
bce86c4163a3 Initial revision
kono
parents:
diff changeset
148
bce86c4163a3 Initial revision
kono
parents:
diff changeset
149 static int mbx_chk (fd)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
150 int fd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
151 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
152 int count;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
153 char ldelim[BUFSIZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
154
bce86c4163a3 Initial revision
kono
parents:
diff changeset
155 count = strlen (mmdlm2);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
156
bce86c4163a3 Initial revision
kono
parents:
diff changeset
157 if (lseek (fd, (off_t) (-count), 2) == (off_t) NOTOK
bce86c4163a3 Initial revision
kono
parents:
diff changeset
158 || read (fd, ldelim, count) != count)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
159 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
160 ldelim[count] = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
161
bce86c4163a3 Initial revision
kono
parents:
diff changeset
162 if (strcmp (ldelim, mmdlm2)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
163 && write (fd, "\n", 1) != 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
164 && write (fd, mmdlm2, count) != count)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
165 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
166
bce86c4163a3 Initial revision
kono
parents:
diff changeset
167 return OK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
168 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
169
bce86c4163a3 Initial revision
kono
parents:
diff changeset
170 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
171
bce86c4163a3 Initial revision
kono
parents:
diff changeset
172 int mbx_read (fp, pos, drops, noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
173 register FILE *fp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
174 register long pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
175 struct drop **drops;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
176 int noisy;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
177 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
178 register int len,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
179 size;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
180 long ld1,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
181 ld2;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
182 register char *bp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
183 char buffer[BUFSIZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
184 register struct drop *cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
185 *dp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
186 *ep,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
187 *pp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
188
bce86c4163a3 Initial revision
kono
parents:
diff changeset
189 pp = (struct drop *) calloc ((unsigned) (len = MAXFOLDER), sizeof *dp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
190 if (pp == NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
191 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
192 admonish (NULLCP, "unable to allocate drop storage");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
193 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
194 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
195
bce86c4163a3 Initial revision
kono
parents:
diff changeset
196 ld1 = (long) strlen (mmdlm1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
197 ld2 = (long) strlen (mmdlm2);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
198
bce86c4163a3 Initial revision
kono
parents:
diff changeset
199 (void) fseek (fp, pos, 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
200 for (ep = (dp = pp) + len - 1; fgets (buffer, sizeof buffer, fp);) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
201 size = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
202 if (strcmp (buffer, mmdlm1) == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
203 pos += ld1, dp -> d_start = pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
204 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
205 dp -> d_start = pos, pos += (long) strlen (buffer);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
206 for (bp = buffer; *bp; bp++, size++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
207 if (*bp == '\n')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
208 size++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
209 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
210
bce86c4163a3 Initial revision
kono
parents:
diff changeset
211 while (fgets (buffer, sizeof buffer, fp) != NULL)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
212 if (strcmp (buffer, mmdlm2) == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
213 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
214 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
215 pos += (long) strlen (buffer);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
216 for (bp = buffer; *bp; bp++, size++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
217 if (*bp == '\n')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
218 size++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
219 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
220
bce86c4163a3 Initial revision
kono
parents:
diff changeset
221 if (dp -> d_start != pos) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
222 dp -> d_id = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
223 dp -> d_size = size;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
224 dp -> d_stop = pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
225 dp++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
226 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
227 pos += ld2;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
228
bce86c4163a3 Initial revision
kono
parents:
diff changeset
229 if (dp >= ep) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
230 register int curlen = dp - pp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
231
bce86c4163a3 Initial revision
kono
parents:
diff changeset
232 cp = (struct drop *) realloc ((char *) pp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
233 (unsigned) (len += MAXFOLDER) * sizeof *pp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
234 if (cp == NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
235 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
236 admonish (NULLCP, "unable to allocate drop storage");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
237 free ((char *) pp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
238 return 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
239 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
240 dp = cp + curlen, ep = (pp = cp) + len - 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
241 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
242 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
243
bce86c4163a3 Initial revision
kono
parents:
diff changeset
244 if (dp == pp)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
245 free ((char *) pp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
246 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
247 *drops = pp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
248 return (dp - pp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
249 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
250
bce86c4163a3 Initial revision
kono
parents:
diff changeset
251 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
252
bce86c4163a3 Initial revision
kono
parents:
diff changeset
253 int mbx_write (mailbox, md, fp, id, last, pos, stop, mapping, noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
254 char *mailbox;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
255 register FILE *fp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
256 int md,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
257 id,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
258 mapping,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
259 noisy;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
260 long last;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
261 register long pos,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
262 stop;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
263 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
264 register int i,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
265 j,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
266 size;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
267 register long start,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
268 off;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
269 register char *cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
270 char buffer[BUFSIZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
271
bce86c4163a3 Initial revision
kono
parents:
diff changeset
272 off = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
273 j = strlen (mmdlm1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
274 if (write (md, mmdlm1, j) != j)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
275 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
276 start = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
277 size = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
278
bce86c4163a3 Initial revision
kono
parents:
diff changeset
279 (void) fseek (fp, pos, 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
280 while (fgets (buffer, sizeof buffer, fp) != NULL && pos < stop) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
281 i = strlen (buffer);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
282 for (j = 0; (j = stringdex (mmdlm1, buffer)) >= 0; buffer[j]++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
283 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
284 for (j = 0; (j = stringdex (mmdlm2, buffer)) >= 0; buffer[j]++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
285 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
286 if (write (md, buffer, i) != i)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
287 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
288 pos += (long) i;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
289 if (mapping)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
290 for (cp = buffer; i-- > 0; size++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
291 if (*cp++ == '\n')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
292 size++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
293 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
294
bce86c4163a3 Initial revision
kono
parents:
diff changeset
295 stop = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
296 j = strlen (mmdlm2);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
297 if (write (md, mmdlm2, j) != j)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
298 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
299 if (mapping)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
300 (void) map_write (mailbox, md, id, last, start, stop, off, size, noisy);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
301
bce86c4163a3 Initial revision
kono
parents:
diff changeset
302 return OK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
303 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
304
bce86c4163a3 Initial revision
kono
parents:
diff changeset
305 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
306
bce86c4163a3 Initial revision
kono
parents:
diff changeset
307 int mbx_copy (mailbox, md, fd, mapping, text, noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
308 char *mailbox;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
309 int md,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
310 fd,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
311 mapping,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
312 noisy;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
313 char *text;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
314 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
315 register int i,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
316 j,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
317 size;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
318 register long start,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
319 stop,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
320 pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
321 register char *cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
322 char buffer[BUFSIZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
323 register FILE *fp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
324
bce86c4163a3 Initial revision
kono
parents:
diff changeset
325 pos = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
326 size = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
327
bce86c4163a3 Initial revision
kono
parents:
diff changeset
328 switch (mbx_style) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
329 case MMDF:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
330 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
331 j = strlen (mmdlm1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
332 if (write (md, mmdlm1, j) != j)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
333 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
334 start = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
335
bce86c4163a3 Initial revision
kono
parents:
diff changeset
336 if (text) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
337 i = strlen (text);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
338 if (write (md, text, i) != i)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
339 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
340 for (cp = text; *cp++; size++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
341 if (*cp == '\n')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
342 size++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
343 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
344
bce86c4163a3 Initial revision
kono
parents:
diff changeset
345 while ((i = read (fd, buffer, sizeof buffer)) > 0) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
346 for (j = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
347 (j = stringdex (mmdlm1, buffer)) >= 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
348 buffer[j]++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
349 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
350 for (j = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
351 (j = stringdex (mmdlm2, buffer)) >= 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
352 buffer[j]++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
353 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
354 if (write (md, buffer, i) != i)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
355 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
356 if (mapping)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
357 for (cp = buffer; i-- > 0; size++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
358 if (*cp++ == '\n')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
359 size++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
360 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
361
bce86c4163a3 Initial revision
kono
parents:
diff changeset
362 stop = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
363 j = strlen (mmdlm2);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
364 if (write (md, mmdlm2, j) != j)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
365 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
366 if (mapping)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
367 (void) map_write (mailbox, md, 0, 0L, start, stop, pos, size,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
368 noisy);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
369
bce86c4163a3 Initial revision
kono
parents:
diff changeset
370 return (i != NOTOK ? OK : NOTOK);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
371
bce86c4163a3 Initial revision
kono
parents:
diff changeset
372 case UUCP: /* I hate this... */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
373 if ((j = dup (fd)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
374 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
375 if ((fp = fdopen (j, "r")) == NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
376 (void) close (j);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
377 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
378 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
379 start = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
380
bce86c4163a3 Initial revision
kono
parents:
diff changeset
381 if (text) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
382 i = strlen (text);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
383 if (write (md, text, i) != i)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
384 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
385 for (cp = text; *cp++; size++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
386 if (*cp == '\n')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
387 size++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
388 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
389
bce86c4163a3 Initial revision
kono
parents:
diff changeset
390 for (j = 0; fgets (buffer, sizeof buffer, fp) != NULL; j++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
391 if (j != 0 && strncmp (buffer, "From ", 5) == 0) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
392 (void) write (fd, ">", 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
393 size++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
394 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
395 i = strlen (buffer);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
396 if (write (md, buffer, i) != i) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
397 (void) fclose (fp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
398 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
399 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
400 if (mapping)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
401 for (cp = buffer; i-- > 0; size++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
402 if (*cp++ == '\n')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
403 size++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
404 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
405
bce86c4163a3 Initial revision
kono
parents:
diff changeset
406 (void) fclose (fp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
407 (void) lseek (fd, (off_t)0, 2);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
408 stop = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
409 if (mapping)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
410 (void) map_write (mailbox, md, 0, 0L, start, stop, pos, size,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
411 noisy);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
412
bce86c4163a3 Initial revision
kono
parents:
diff changeset
413 return OK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
414 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
415 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
416
bce86c4163a3 Initial revision
kono
parents:
diff changeset
417 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
418
bce86c4163a3 Initial revision
kono
parents:
diff changeset
419 int mbx_size (md, start, stop)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
420 int md;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
421 long start,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
422 stop;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
423 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
424 register int i,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
425 fd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
426 register long pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
427 register FILE *fp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
428
bce86c4163a3 Initial revision
kono
parents:
diff changeset
429 if ((fd = dup (md)) == NOTOK || (fp = fdopen (fd, "r")) == NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
430 if (fd != NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
431 (void) close (fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
432 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
433 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
434
bce86c4163a3 Initial revision
kono
parents:
diff changeset
435 (void) fseek (fp, start, 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
436 for (i = 0, pos = stop - start; pos-- > 0; i++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
437 if (fgetc (fp) == '\n')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
438 i++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
439
bce86c4163a3 Initial revision
kono
parents:
diff changeset
440 (void) fclose (fp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
441
bce86c4163a3 Initial revision
kono
parents:
diff changeset
442 return i;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
443 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
444
bce86c4163a3 Initial revision
kono
parents:
diff changeset
445 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
446
bce86c4163a3 Initial revision
kono
parents:
diff changeset
447 int mbx_close (mailbox, md)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
448 char *mailbox;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
449 int md;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
450 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
451 (void) lkclose (md, mailbox);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
452
bce86c4163a3 Initial revision
kono
parents:
diff changeset
453 return OK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
454 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
455
bce86c4163a3 Initial revision
kono
parents:
diff changeset
456 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
457
bce86c4163a3 Initial revision
kono
parents:
diff changeset
458 /* This function is performed implicitly by getbbent.c:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
459
bce86c4163a3 Initial revision
kono
parents:
diff changeset
460 bb -> bb_map = map_name (bb -> bb_file);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
461 */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
462
bce86c4163a3 Initial revision
kono
parents:
diff changeset
463 char *map_name (file)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
464 register char *file;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
465 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
466 register char *cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
467 *dp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
468 static char buffer[BUFSIZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
469
bce86c4163a3 Initial revision
kono
parents:
diff changeset
470 if ((dp = index (cp = r1bindex (file, '/'), '.')) == NULL)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
471 dp = cp + strlen (cp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
472 if (cp == file)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
473 (void) sprintf (buffer, ".%.*s%s", dp - cp, cp, ".map");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
474 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
475 (void) sprintf (buffer, "%.*s.%.*s%s", cp - file, file, dp - cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
476 cp, ".map");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
477
bce86c4163a3 Initial revision
kono
parents:
diff changeset
478 return buffer;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
479 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
480
bce86c4163a3 Initial revision
kono
parents:
diff changeset
481 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
482
bce86c4163a3 Initial revision
kono
parents:
diff changeset
483 int map_read (file, pos, drops, noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
484 char *file;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
485 long pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
486 struct drop **drops;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
487 int noisy;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
488 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
489 register int i,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
490 md,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
491 msgp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
492 register char *cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
493 struct drop d;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
494 register struct drop *mp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
495 *dp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
496
bce86c4163a3 Initial revision
kono
parents:
diff changeset
497 if ((md = open (cp = map_name (file), 0)) == NOTOK
bce86c4163a3 Initial revision
kono
parents:
diff changeset
498 || map_chk (cp, md, mp = &d, pos, noisy)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
499 if (md != NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
500 (void) close (md);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
501 return 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
502 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
503
bce86c4163a3 Initial revision
kono
parents:
diff changeset
504 msgp = mp -> d_id;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
505 dp = (struct drop *) calloc ((unsigned) (msgp + 1), sizeof *dp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
506 if (dp == NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
507 (void) close (md);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
508 return 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
509 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
510
bce86c4163a3 Initial revision
kono
parents:
diff changeset
511 bcopy ((char *) mp, (char *) dp, sizeof *dp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
512
bce86c4163a3 Initial revision
kono
parents:
diff changeset
513 (void) lseek (md, (off_t) sizeof *mp, 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
514 if ((i = read (md, (char *) (dp + 1), msgp * sizeof *dp)) < sizeof *dp) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
515 i = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
516 free ((char *) dp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
517 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
518 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
519 *drops = dp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
520
bce86c4163a3 Initial revision
kono
parents:
diff changeset
521 (void) close (md);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
522
bce86c4163a3 Initial revision
kono
parents:
diff changeset
523 return (i / sizeof *dp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
524 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
525
bce86c4163a3 Initial revision
kono
parents:
diff changeset
526 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
527
bce86c4163a3 Initial revision
kono
parents:
diff changeset
528 int map_write (mailbox, md, id, last, start, stop, pos, size, noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
529 register char *mailbox;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
530 int md,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
531 id,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
532 size,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
533 noisy;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
534 long last,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
535 start,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
536 stop,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
537 pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
538 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
539 register int i;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
540 int clear,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
541 fd,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
542 td;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
543 char *file;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
544 register struct drop *dp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
545 struct drop d1,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
546 d2,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
547 *rp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
548 register FILE *fp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
549
bce86c4163a3 Initial revision
kono
parents:
diff changeset
550 if ((fd = map_open (file = map_name (mailbox), &clear, md)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
551 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
552
bce86c4163a3 Initial revision
kono
parents:
diff changeset
553 if (!clear && map_chk (file, fd, &d1, pos, noisy)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
554 (void) unlink (file);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
555 (void) mbx_close (file, fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
556 if ((fd = map_open (file, &clear, md)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
557 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
558 clear++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
559 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
560
bce86c4163a3 Initial revision
kono
parents:
diff changeset
561 if (clear) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
562 if ((td = dup (md)) == NOTOK || (fp = fdopen (td, "r")) == NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
563 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
564 admonish (file, "unable to %s", td != NOTOK ? "fdopen" : "dup");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
565 if (td != NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
566 (void) close (td);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
567 (void) mbx_close (file, fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
568 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
569 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
570
bce86c4163a3 Initial revision
kono
parents:
diff changeset
571 switch (i = mbx_read (fp, 0L, &rp, noisy)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
572 case NOTOK:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
573 (void) fclose (fp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
574 (void) mbx_close (file, fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
575 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
576
bce86c4163a3 Initial revision
kono
parents:
diff changeset
577 case OK:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
578 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
579
bce86c4163a3 Initial revision
kono
parents:
diff changeset
580 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
581 d1.d_id = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
582 for (dp = rp; i-- >0; dp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
583 if (dp -> d_start == start)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
584 dp -> d_id = id;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
585 (void) lseek (fd, (off_t) (++d1.d_id * sizeof *dp), 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
586 if (write (fd, (char *) dp, sizeof *dp) != sizeof *dp) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
587 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
588 admonish (file, "write error");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
589 (void) mbx_close (file, fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
590 (void) fclose (fp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
591 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
592 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
593 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
594 free ((char *) rp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
595 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
596 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
597 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
598 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
599 if (last == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
600 last = d1.d_start;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
601 dp = &d2;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
602 dp -> d_id = id;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
603 dp -> d_size = size ? size : mbx_size (fd, start, stop);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
604 dp -> d_start = start;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
605 dp -> d_stop = stop;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
606 (void) lseek (fd, (off_t) (++d1.d_id * sizeof *dp), 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
607 if (write (fd, (char *) dp, sizeof *dp) != sizeof *dp) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
608 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
609 admonish (file, "write error");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
610 (void) mbx_close (file, fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
611 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
612 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
613 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
614
bce86c4163a3 Initial revision
kono
parents:
diff changeset
615 dp = &d1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
616 dp -> d_size = DRVRSN;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
617 dp -> d_start = last;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
618 dp -> d_stop = (long) lseek (md, (off_t)0, 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
619
bce86c4163a3 Initial revision
kono
parents:
diff changeset
620 (void) lseek (fd, (off_t)0, 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
621 if (write (fd, (char *) dp, sizeof *dp) != sizeof *dp) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
622 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
623 admonish (file, "write error");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
624 (void) mbx_close (file, fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
625 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
626 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
627
bce86c4163a3 Initial revision
kono
parents:
diff changeset
628 (void) mbx_close (file, fd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
629
bce86c4163a3 Initial revision
kono
parents:
diff changeset
630 return OK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
631 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
632
bce86c4163a3 Initial revision
kono
parents:
diff changeset
633 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
634
bce86c4163a3 Initial revision
kono
parents:
diff changeset
635 static int map_open (file, clear, md)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
636 char *file;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
637 int *clear,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
638 md;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
639 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
640 int mode;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
641 struct stat st;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
642
bce86c4163a3 Initial revision
kono
parents:
diff changeset
643 mode = fstat (md, &st) != NOTOK ? (int) (st.st_mode & 0777) : m_gmprot ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
644 return mbx_Xopen (file, st.st_uid, st.st_gid, mode, clear);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
645 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
646
bce86c4163a3 Initial revision
kono
parents:
diff changeset
647 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
648
bce86c4163a3 Initial revision
kono
parents:
diff changeset
649 int map_chk (file, fd, dp, pos, noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
650 char *file;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
651 int fd,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
652 noisy;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
653 register struct drop *dp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
654 long pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
655 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
656 long count;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
657 struct drop d;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
658 register struct drop *dl;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
659
bce86c4163a3 Initial revision
kono
parents:
diff changeset
660 if (read (fd, (char *) dp, sizeof *dp) != sizeof *dp) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
661 #ifdef notdef
bce86c4163a3 Initial revision
kono
parents:
diff changeset
662 admonish (NULLCP, "%s: missing or partial index", file);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
663 #endif notdef
bce86c4163a3 Initial revision
kono
parents:
diff changeset
664 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
665 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
666
bce86c4163a3 Initial revision
kono
parents:
diff changeset
667 if (dp -> d_size != DRVRSN) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
668 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
669 admonish (NULLCP, "%s: version mismatch", file);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
670 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
671 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
672
bce86c4163a3 Initial revision
kono
parents:
diff changeset
673 if (dp -> d_stop != pos) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
674 if (noisy && pos != 0L)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
675 admonish (NULLCP,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
676 "%s: pointer mismatch or incomplete index (%ld!=%ld)",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
677 file, dp -> d_stop, pos);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
678 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
679 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
680
bce86c4163a3 Initial revision
kono
parents:
diff changeset
681 if ((long) ((dp -> d_id + 1) * sizeof *dp) != (long) lseek (fd, (off_t)0, 2)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
682 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
683 admonish (NULLCP, "%s: corrupt index(1)", file);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
684 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
685 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
686
bce86c4163a3 Initial revision
kono
parents:
diff changeset
687 dl = &d;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
688 count = (long) strlen (mmdlm2);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
689 (void) lseek (fd, (off_t) (dp -> d_id * sizeof *dp), 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
690 if (read (fd, (char *) dl, sizeof *dl) != sizeof *dl
bce86c4163a3 Initial revision
kono
parents:
diff changeset
691 || (dl -> d_stop != dp -> d_stop
bce86c4163a3 Initial revision
kono
parents:
diff changeset
692 && dl -> d_stop + count != dp -> d_stop)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
693 if (noisy)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
694 admonish (NULLCP, "%s: corrupt index(2)", file);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
695 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
696 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
697
bce86c4163a3 Initial revision
kono
parents:
diff changeset
698 return OK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
699 }