annotate uip/rcvstore.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 /* rcvstore.c - incorporate new mail asynchronously
bce86c4163a3 Initial revision
kono
parents:
diff changeset
2 originally from Julian Onions */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
3 #ifndef lint
bce86c4163a3 Initial revision
kono
parents:
diff changeset
4 static char ident[] = "@(#)$Id$";
bce86c4163a3 Initial revision
kono
parents:
diff changeset
5 #endif /* lint */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
6
bce86c4163a3 Initial revision
kono
parents:
diff changeset
7 #include "../h/mh.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
8 #include <errno.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
9 #include <signal.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
10 #include <stdio.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
11 #include <sys/types.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
12 #include <sys/stat.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
13 #ifdef LOCALE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
14 #include <locale.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
15 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
16
bce86c4163a3 Initial revision
kono
parents:
diff changeset
17 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
18
bce86c4163a3 Initial revision
kono
parents:
diff changeset
19 static struct swit switches[] = {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
20 #define CRETSW 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
21 "create", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
22 #define NCRETSW 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
23 "nocreate", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
24
bce86c4163a3 Initial revision
kono
parents:
diff changeset
25 #define PUBSW 2
bce86c4163a3 Initial revision
kono
parents:
diff changeset
26 "public", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
27 #define NPUBSW 3
bce86c4163a3 Initial revision
kono
parents:
diff changeset
28 "nopublic", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
29
bce86c4163a3 Initial revision
kono
parents:
diff changeset
30 #define SEQSW 4
bce86c4163a3 Initial revision
kono
parents:
diff changeset
31 "sequence name", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
32
bce86c4163a3 Initial revision
kono
parents:
diff changeset
33 #define ZEROSW 5
bce86c4163a3 Initial revision
kono
parents:
diff changeset
34 "zero", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
35 #define NZEROSW 6
bce86c4163a3 Initial revision
kono
parents:
diff changeset
36 "nozero", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
37
bce86c4163a3 Initial revision
kono
parents:
diff changeset
38 #define HELPSW 7
bce86c4163a3 Initial revision
kono
parents:
diff changeset
39 "help", 4,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
40
bce86c4163a3 Initial revision
kono
parents:
diff changeset
41 NULL, 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
42 };
bce86c4163a3 Initial revision
kono
parents:
diff changeset
43
bce86c4163a3 Initial revision
kono
parents:
diff changeset
44 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
45
bce86c4163a3 Initial revision
kono
parents:
diff changeset
46 extern int errno;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
47
bce86c4163a3 Initial revision
kono
parents:
diff changeset
48 static char *tmpfilenam = NULLCP;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
49 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
50
bce86c4163a3 Initial revision
kono
parents:
diff changeset
51 /* ARGSUSED */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
52
bce86c4163a3 Initial revision
kono
parents:
diff changeset
53 main (argc, argv)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
54 int argc;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
55 char *argv[];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
56 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
57 int publicsw = -1,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
58 zerosw = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
59 msgnum,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
60 create = 1,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
61 fd,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
62 seqp = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
63 char *cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
64 *maildir,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
65 *folder = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
66 buf[100],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
67 **ap,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
68 **argp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
69 *arguments[MAXARGS],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
70 *seqs[NATTRS+1];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
71 struct msgs *mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
72 struct stat st;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
73
bce86c4163a3 Initial revision
kono
parents:
diff changeset
74 #ifdef LOCALE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
75 setlocale(LC_ALL, "");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
76 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
77 #ifdef JAPAN
bce86c4163a3 Initial revision
kono
parents:
diff changeset
78 ml_init();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
79 #endif /* JAPAN */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
80 invo_name = r1bindex (argv[0], '/');
bce86c4163a3 Initial revision
kono
parents:
diff changeset
81 mts_init (invo_name);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
82 if ((cp = m_find (invo_name)) != NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
83 ap = brkstring (cp = getcpy (cp), " ", "\n");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
84 ap = copyip (ap, arguments);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
85 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
86 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
87 ap = arguments;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
88 (void) copyip (argv + 1, ap);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
89 argp = arguments;
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 while (cp = *argp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
94 if (*cp == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
95 switch (smatch (++cp, switches)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
96 case AMBIGSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
97 ambigsw (cp, switches);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
98 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
99 case UNKWNSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
100 adios (NULLCP, "-%s unknown", cp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
101 case HELPSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
102 (void) sprintf (buf, "%s [+folder] [switches]", invo_name);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
103 help (buf, switches);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
104 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
105
bce86c4163a3 Initial revision
kono
parents:
diff changeset
106 case SEQSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
107 if (!(cp = *argp++) || *cp == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
108 adios (NULLCP, "missing argument name to %s",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
109 argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
110 if (seqp < NATTRS)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
111 seqs[seqp++] = cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
112 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
113 adios (NULLCP, "only %d sequences allowed!", NATTRS);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
114 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
115 case PUBSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
116 publicsw = 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
117 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
118 case NPUBSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
119 publicsw = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
120 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
121 case ZEROSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
122 zerosw++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
123 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
124 case NZEROSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
125 zerosw = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
126 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
127
bce86c4163a3 Initial revision
kono
parents:
diff changeset
128 case CRETSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
129 create++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
130 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
131 case NCRETSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
132 create = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
133 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
134 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
135 if (*cp == '+' || *cp == '@') {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
136 if (folder)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
137 adios (NULLCP, "only one folder at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
138 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
139 folder = path (cp + 1, *cp == '+' ? TFOLDER : TSUBCWF);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
140 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
141 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
142 adios (NULLCP, "usage: %s [+folder] [switches]", invo_name);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
143 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
144
bce86c4163a3 Initial revision
kono
parents:
diff changeset
145 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
146
bce86c4163a3 Initial revision
kono
parents:
diff changeset
147 if (!m_find ("path"))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
148 free (path ("./", TFOLDER));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
149 if (!folder && !(folder = m_find (inbox)))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
150 folder = defalt;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
151 maildir = m_maildir (folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
152
bce86c4163a3 Initial revision
kono
parents:
diff changeset
153 if (stat (maildir, &st) == NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
154 if (errno != ENOENT)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
155 adios (maildir, "error on folder");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
156 if (!create)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
157 adios (NULLCP, "folder %s doesn't exist", maildir);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
158 if (!makedir (maildir))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
159 adios (NULLCP, "unable to create folder %s", maildir);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
160 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
161
bce86c4163a3 Initial revision
kono
parents:
diff changeset
162 if (chdir (maildir) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
163 adios (maildir, "unable to change directory to");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
164 if (!(mp = m_gmsg (folder)))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
165 adios (NULLCP, "unable to read folder %s", folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
166
bce86c4163a3 Initial revision
kono
parents:
diff changeset
167 (void) signal (SIGHUP, SIG_IGN);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
168 (void) signal (SIGINT, SIG_IGN);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
169 (void) signal (SIGQUIT, SIG_IGN);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
170 (void) signal (SIGTERM, SIG_IGN);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
171
bce86c4163a3 Initial revision
kono
parents:
diff changeset
172 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
173
bce86c4163a3 Initial revision
kono
parents:
diff changeset
174 if ((fd = creat (tmpfilenam = m_scratch ("", invo_name), m_gmprot ()))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
175 == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
176 adios (tmpfilenam, "unable to create");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
177 (void) chmod (tmpfilenam, m_gmprot ());
bce86c4163a3 Initial revision
kono
parents:
diff changeset
178
bce86c4163a3 Initial revision
kono
parents:
diff changeset
179 cpydata (fileno (stdin), fd, "standard input", tmpfilenam);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
180
bce86c4163a3 Initial revision
kono
parents:
diff changeset
181 if (fstat (fd, &st) == NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
182 (void) unlink (tmpfilenam);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
183 adios (tmpfilenam, "unable to fstat");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
184 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
185 if (close (fd) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
186 adios (tmpfilenam, "error closing");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
187 if (st.st_size == 0) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
188 (void) unlink (tmpfilenam);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
189 advise (NULLCP, "empty file");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
190 done (0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
191 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
192
bce86c4163a3 Initial revision
kono
parents:
diff changeset
193 msgnum = mp -> hghmsg;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
194 do {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
195 msgnum++, mp -> hghmsg++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
196 if (msgnum > mp -> hghoff)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
197 if ((mp = m_remsg (mp, 0, mp -> hghoff + MAXFOLDER)) == NULL)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
198 adios (NULLCP, "unable to allocate folder storage");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
199
bce86c4163a3 Initial revision
kono
parents:
diff changeset
200 mp -> msgstats[msgnum] |= EXISTS | UNSEEN;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
201 errno = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
202 } while (link (tmpfilenam, m_name (msgnum)) == NOTOK && errno == EEXIST);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
203
bce86c4163a3 Initial revision
kono
parents:
diff changeset
204 (void) unlink (tmpfilenam);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
205 tmpfilenam = NULLCP;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
206 if (errno != 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
207 adios (NULLCP, "can't file message %d", msgnum);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
208
bce86c4163a3 Initial revision
kono
parents:
diff changeset
209 if (mp -> lowmsg == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
210 mp -> lowmsg = msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
211 mp -> msgflags |= SEQMOD;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
212
bce86c4163a3 Initial revision
kono
parents:
diff changeset
213 seqs[seqp] = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
214 for (seqp = 0; seqs[seqp]; seqp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
215 if (zerosw && !m_seqnew (mp, seqs[seqp], publicsw))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
216 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
217 if (!m_seqadd (mp, seqs[seqp], msgnum, publicsw))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
218 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
219 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
220
bce86c4163a3 Initial revision
kono
parents:
diff changeset
221 m_setvis (mp, 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
222 m_sync (mp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
223 m_update ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
224
bce86c4163a3 Initial revision
kono
parents:
diff changeset
225 done (0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
226 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
227
bce86c4163a3 Initial revision
kono
parents:
diff changeset
228 void done (status)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
229 register int status;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
230 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
231 if (tmpfilenam && *tmpfilenam)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
232 (void) unlink (tmpfilenam);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
233 exit (status);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
234 }