annotate uip/dropsbr.c @ 10:a6481689f99c

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