annotate uip/refile.c @ 12:441a2190cfae

Lion fix
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 21 Apr 2012 13:10:49 +0900
parents a6481689f99c
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
1 /* refile.c - file messages away */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
2 #ifndef lint
12
441a2190cfae Lion fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
3 static char ident[] = "@(#)$Id: refile.c,v 1.2 2006/12/05 18:18:13 kono Exp $";
0
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 "../h/mh.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
7 #include <errno.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
8 #include <stdio.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
9 #include <sys/types.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
10 #include <sys/stat.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
11 #ifdef LOCALE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
12 #include <locale.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
13 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
14
bce86c4163a3 Initial revision
kono
parents:
diff changeset
15 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
16
bce86c4163a3 Initial revision
kono
parents:
diff changeset
17 static struct swit switches[] = {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
18 #define DRAFTSW 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
19 "draft", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
20
bce86c4163a3 Initial revision
kono
parents:
diff changeset
21 #define LINKSW 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
22 "link", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
23 #define NLINKSW 2
bce86c4163a3 Initial revision
kono
parents:
diff changeset
24 "nolink", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
25
bce86c4163a3 Initial revision
kono
parents:
diff changeset
26 #define PRESSW 3
bce86c4163a3 Initial revision
kono
parents:
diff changeset
27 "preserve", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
28 #define NPRESSW 4
bce86c4163a3 Initial revision
kono
parents:
diff changeset
29 "nopreserve", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
30
bce86c4163a3 Initial revision
kono
parents:
diff changeset
31 #define SRCSW 5
bce86c4163a3 Initial revision
kono
parents:
diff changeset
32 "src +folder", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
33
bce86c4163a3 Initial revision
kono
parents:
diff changeset
34 #define FILESW 6
bce86c4163a3 Initial revision
kono
parents:
diff changeset
35 "file file", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
36
bce86c4163a3 Initial revision
kono
parents:
diff changeset
37 #define RPROCSW 7
bce86c4163a3 Initial revision
kono
parents:
diff changeset
38 "rmmproc program", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
39 #define NRPRCSW 8
bce86c4163a3 Initial revision
kono
parents:
diff changeset
40 "normmproc", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
41
bce86c4163a3 Initial revision
kono
parents:
diff changeset
42 #define HELPSW 9
bce86c4163a3 Initial revision
kono
parents:
diff changeset
43 "help", 4,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
44
bce86c4163a3 Initial revision
kono
parents:
diff changeset
45 NULL, 0
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
bce86c4163a3 Initial revision
kono
parents:
diff changeset
50
bce86c4163a3 Initial revision
kono
parents:
diff changeset
51
bce86c4163a3 Initial revision
kono
parents:
diff changeset
52 static char maildir[BUFSIZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
53
bce86c4163a3 Initial revision
kono
parents:
diff changeset
54
bce86c4163a3 Initial revision
kono
parents:
diff changeset
55 struct st_fold {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
56 char *f_name;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
57 struct msgs *f_mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
58 };
bce86c4163a3 Initial revision
kono
parents:
diff changeset
59
bce86c4163a3 Initial revision
kono
parents:
diff changeset
60 static opnfolds(), clsfolds(), removeit();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
61 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
62
bce86c4163a3 Initial revision
kono
parents:
diff changeset
63 /* ARGSUSED */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
64
bce86c4163a3 Initial revision
kono
parents:
diff changeset
65 main (argc, argv)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
66 int argc;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
67 char **argv;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
68 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
69 int linkf = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
70 prsrvf = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
71 filep = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
72 foldp = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
73 msgp = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
74 isdf = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
75 i,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
76 msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
77 char *cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
78 *folder = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
79 buf[100],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
80 **ap,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
81 **argp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
82 *arguments[MAXARGS],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
83 *filevec[NFOLDERS + 2],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
84 **files = &filevec[1], /* leave room for removeit:vec[0] */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
85 *msgs[MAXARGS];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
86 struct st_fold folders[NFOLDERS + 1];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
87 struct msgs *mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
88
bce86c4163a3 Initial revision
kono
parents:
diff changeset
89 #ifdef LOCALE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
90 setlocale(LC_ALL, "");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
91 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
92 #ifdef JAPAN
bce86c4163a3 Initial revision
kono
parents:
diff changeset
93 ml_init();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
94 #endif /* JAPAN */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
95 invo_name = r1bindex (argv[0], '/');
bce86c4163a3 Initial revision
kono
parents:
diff changeset
96 if ((cp = m_find (invo_name)) != NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
97 ap = brkstring (cp = getcpy (cp), " ", "\n");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
98 ap = copyip (ap, arguments);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
99 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
100 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
101 ap = arguments;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
102 (void) copyip (argv + 1, ap);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
103 argp = arguments;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
104
bce86c4163a3 Initial revision
kono
parents:
diff changeset
105 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
106
bce86c4163a3 Initial revision
kono
parents:
diff changeset
107 while (cp = *argp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
108 if (*cp == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
109 switch (smatch (++cp, switches)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
110 case AMBIGSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
111 ambigsw (cp, switches);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
112 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
113 case UNKWNSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
114 adios (NULLCP, "-%s unknown\n", cp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
115 case HELPSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
116 (void) sprintf (buf, "%s [msgs] [switches] +folder ...",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
117 invo_name);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
118 help (buf, switches);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
119 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
120
bce86c4163a3 Initial revision
kono
parents:
diff changeset
121 case LINKSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
122 linkf++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
123 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
124 case NLINKSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
125 linkf = 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 PRESSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
129 prsrvf++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
130 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
131 case NPRESSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
132 prsrvf = 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 case SRCSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
136 if (folder)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
137 adios (NULLCP, "only one source folder at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
138 if (!(cp = *argp++) || *cp == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
139 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
140 folder = path (*cp == '+' || *cp == '@' ? cp + 1 : cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
141 *cp != '@' ? TFOLDER : TSUBCWF);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
142 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
143 case DRAFTSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
144 if (filep > NFOLDERS)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
145 adios (NULLCP, "only %d files allowed!", NFOLDERS);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
146 isdf = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
147 files[filep++] = getcpy (m_draft (NULLCP, NULLCP, 1, &isdf));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
148 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
149 case FILESW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
150 if (filep > NFOLDERS)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
151 adios (NULLCP, "only %d files allowed!", NFOLDERS);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
152 if (!(cp = *argp++) || *cp == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
153 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
154 files[filep++] = path (cp, TFILE);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
155 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
156
bce86c4163a3 Initial revision
kono
parents:
diff changeset
157 case RPROCSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
158 if (!(rmmproc = *argp++) || *rmmproc == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
159 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
160 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
161 case NRPRCSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
162 rmmproc = (char *)0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
163 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
164 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
165 if (*cp == '+' || *cp == '@') {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
166 if (foldp > NFOLDERS)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
167 adios (NULLCP, "only %d folders allowed!", NFOLDERS);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
168 folders[foldp++].f_name =
bce86c4163a3 Initial revision
kono
parents:
diff changeset
169 path (cp + 1, *cp == '+' ? TFOLDER : TSUBCWF);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
170 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
171 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
172 msgs[msgp++] = cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
173 }
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 if (!m_find ("path"))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
178 free (path ("./", TFOLDER));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
179 if (foldp == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
180 adios (NULLCP, "no folder specified");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
181
bce86c4163a3 Initial revision
kono
parents:
diff changeset
182 #ifdef WHATNOW
bce86c4163a3 Initial revision
kono
parents:
diff changeset
183 if (!msgp && !foldp && !filep && (cp = getenv ("mhdraft")) && *cp)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
184 files[filep++] = cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
185 #endif /* WHATNOW */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
186
bce86c4163a3 Initial revision
kono
parents:
diff changeset
187 if (filep > 0) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
188 if (folder || msgp)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
189 adios (NULLCP, "use -file or some messages, not both");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
190 opnfolds (folders, foldp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
191 for (i = 0; i < filep; i++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
192 if (m_file (files[i], folders, foldp, prsrvf))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
193 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
194 if (!linkf)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
195 removeit (NULLMP, filep, filevec);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
196 done (0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
197 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
198
bce86c4163a3 Initial revision
kono
parents:
diff changeset
199 if (!msgp)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
200 msgs[msgp++] = "cur";
bce86c4163a3 Initial revision
kono
parents:
diff changeset
201 if (!folder)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
202 folder = m_getfolder ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
203 (void) strcpy (maildir, m_maildir (folder));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
204
bce86c4163a3 Initial revision
kono
parents:
diff changeset
205 if (chdir (maildir) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
206 adios (maildir, "unable to change directory to");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
207 if (!(mp = m_gmsg (folder)))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
208 adios (NULLCP, "unable to read folder %s", folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
209 if (mp -> hghmsg == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
210 adios (NULLCP, "no messages in %s", folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
211
bce86c4163a3 Initial revision
kono
parents:
diff changeset
212 for (msgnum = 0; msgnum < msgp; msgnum++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
213 if (!m_convert (mp, msgs[msgnum]))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
214 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
215 m_setseq (mp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
216
bce86c4163a3 Initial revision
kono
parents:
diff changeset
217 opnfolds (folders, foldp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
218 for (msgnum = mp -> lowsel; msgnum <= mp -> hghsel; msgnum++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
219 if (mp -> msgstats[msgnum] & SELECTED) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
220 cp = getcpy (m_name (msgnum));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
221 if (m_file (cp, folders, foldp, prsrvf))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
222 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
223 free (cp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
224 if (!linkf) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
225 #ifdef notdef
bce86c4163a3 Initial revision
kono
parents:
diff changeset
226 mp -> msgstats[msgnum] |= DELETED;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
227 #endif /* notdef */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
228 mp -> msgstats[msgnum] &= ~EXISTS;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
229 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
230 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
231 if (!linkf)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
232 mp -> msgflags |= SEQMOD;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
233 clsfolds (folders, foldp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
234
bce86c4163a3 Initial revision
kono
parents:
diff changeset
235 m_replace (pfolder, folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
236 if (mp -> hghsel != mp -> curmsg
bce86c4163a3 Initial revision
kono
parents:
diff changeset
237 && (mp -> numsel != mp -> nummsg || linkf))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
238 m_setcur (mp, mp -> hghsel);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
239 m_sync (mp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
240 m_update ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
241
bce86c4163a3 Initial revision
kono
parents:
diff changeset
242 if (!linkf)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
243 removeit (mp, filep, filevec);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
244
bce86c4163a3 Initial revision
kono
parents:
diff changeset
245 done (0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
246 }
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 static opnfolds (folders, nfolders)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
251 register struct st_fold *folders;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
252 int nfolders;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
253 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
254 register char *cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
255 char nmaildir[BUFSIZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
256 register struct st_fold *fp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
257 *ep;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
258 register struct msgs *mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
259 struct stat st;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
260
bce86c4163a3 Initial revision
kono
parents:
diff changeset
261 for (ep = (fp = folders) + nfolders; fp < ep; fp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
262 (void) chdir (m_maildir (""));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
263 (void) strcpy (nmaildir, m_maildir (fp -> f_name));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
264
bce86c4163a3 Initial revision
kono
parents:
diff changeset
265 if (stat (nmaildir, &st) == NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
266 if (errno != ENOENT)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
267 adios (nmaildir, "error on folder");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
268 cp = concat ("Create folder \"", nmaildir, "\"? ", NULLCP);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
269 if (!getanswer (cp))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
270 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
271 free (cp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
272 if (!makedir (nmaildir))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
273 adios (NULLCP, "unable to create folder %s", nmaildir);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
274 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
275
bce86c4163a3 Initial revision
kono
parents:
diff changeset
276 if (chdir (nmaildir) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
277 adios (nmaildir, "unable to change directory to");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
278 if (!(mp = m_gmsg (fp -> f_name)))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
279 adios (NULLCP, "unable to read folder %s", fp -> f_name);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
280 mp -> curmsg = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
281
bce86c4163a3 Initial revision
kono
parents:
diff changeset
282 fp -> f_mp = mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
283
bce86c4163a3 Initial revision
kono
parents:
diff changeset
284 (void) chdir (maildir);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
285 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
286 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
287
bce86c4163a3 Initial revision
kono
parents:
diff changeset
288 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
289
bce86c4163a3 Initial revision
kono
parents:
diff changeset
290 static clsfolds (folders, nfolders)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
291 register struct st_fold *folders;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
292 int nfolders;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
293 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
294 register struct st_fold *fp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
295 *ep;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
296 register struct msgs *mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
297
bce86c4163a3 Initial revision
kono
parents:
diff changeset
298 for (ep = (fp = folders) + nfolders; fp < ep; fp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
299 mp = fp -> f_mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
300 m_setseq (mp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
301 m_sync (mp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
302 }
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 static removeit (mp, filep, files)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
308 register struct msgs *mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
309 register int filep;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
310 register char **files;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
311 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
312 register int i,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
313 vecp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
314 register char *cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
315 **vec;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
316
bce86c4163a3 Initial revision
kono
parents:
diff changeset
317 if (rmmproc) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
318 if (filep > 0) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
319 vec = files++; /* filevec[1] */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
320 files[filep] = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
321 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
322 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
323 if (mp -> numsel > MAXARGS - 2)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
324 adios (NULLCP, "more than %d messages for %s exec",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
325 MAXARGS - 2, rmmproc);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
326 vec = (char **) calloc ((unsigned) (mp -> numsel + 2), sizeof *vec);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
327 if (vec == NULL)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
328 adios (NULLCP, "unable to allocate exec vector");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
329 vecp = 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
330 for (i = mp -> lowsel; i <= mp -> hghsel; i++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
331 if (mp -> msgstats[i] & SELECTED)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
332 vec[vecp++] = getcpy (m_name (i));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
333 vec[vecp] = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
334 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
335
bce86c4163a3 Initial revision
kono
parents:
diff changeset
336 (void) fflush (stdout);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
337 vec[0] = r1bindex (rmmproc, '/');
bce86c4163a3 Initial revision
kono
parents:
diff changeset
338 execvp (rmmproc, vec);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
339 adios (rmmproc, "unable to exec");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
340 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
341
bce86c4163a3 Initial revision
kono
parents:
diff changeset
342 if (filep > 0) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
343 files++; /* filevec[1] */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
344 for (i = 0; i < filep; i++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
345 if (unlink (files[i]) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
346 admonish (files[i], "unable to unlink");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
347 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
348 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
349 for (i = mp -> lowsel; i <= mp -> hghsel; i++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
350 if (mp -> msgstats[i] & SELECTED)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
351 if (unlink (cp = m_name (i)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
352 admonish (cp, "unable to unlink");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
353 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
354
bce86c4163a3 Initial revision
kono
parents:
diff changeset
355 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
356
bce86c4163a3 Initial revision
kono
parents:
diff changeset
357 m_file (msg, folders, nfolders, prsrvf)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
358 register char *msg;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
359 struct st_fold *folders;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
360 int nfolders,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
361 prsrvf;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
362 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
363 int in,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
364 out,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
365 linkerr,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
366 msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
367 register char *nmsg;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
368 char newmsg[BUFSIZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
369 register struct st_fold *fp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
370 *ep;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
371 register struct msgs *mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
372 struct stat st,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
373 s1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
374
bce86c4163a3 Initial revision
kono
parents:
diff changeset
375 for (ep = (fp = folders) + nfolders; fp < ep; fp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
376 mp = fp -> f_mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
377 if (prsrvf && (msgnum = m_atoi (nmsg = msg)) > 0) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
378 if (msgnum >= mp -> hghoff)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
379 if (mp = m_remsg (mp, 0, msgnum + MAXFOLDER))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
380 fp -> f_mp = mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
381 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
382 adios (NULLCP, "unable to allocate folder storage");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
383 if (!(mp -> msgstats[msgnum] & EXISTS)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
384 mp -> msgstats[msgnum] |= EXISTS;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
385 #ifdef notdef
bce86c4163a3 Initial revision
kono
parents:
diff changeset
386 mp -> msgstats[msgnum] &= ~DELETED;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
387 #endif /* notdef */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
388 mp -> nummsg++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
389 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
390 mp -> msgstats[msgnum] |= SELECTED;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
391 if (msgnum > mp -> hghmsg)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
392 mp -> hghmsg = msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
393 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
394 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
395 if (mp -> hghmsg >= mp -> hghoff)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
396 if (mp = m_remsg (mp, 0, mp -> hghoff + MAXFOLDER))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
397 fp -> f_mp = mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
398 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
399 adios (NULLCP, "unable to allocate folder storage");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
400
bce86c4163a3 Initial revision
kono
parents:
diff changeset
401 nmsg = m_name (msgnum = ++mp -> hghmsg);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
402 mp -> nummsg++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
403 mp -> msgstats[msgnum] |= EXISTS | SELECTED;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
404 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
405 if (mp -> lowmsg == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
406 mp -> lowmsg = msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
407 if (mp -> lowsel == 0 || msgnum < mp -> lowsel)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
408 mp -> lowsel = msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
409 if (msgnum > mp -> hghsel)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
410 mp -> hghsel = msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
411
bce86c4163a3 Initial revision
kono
parents:
diff changeset
412 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
413
bce86c4163a3 Initial revision
kono
parents:
diff changeset
414 (void) sprintf (newmsg, "%s/%s", mp -> foldpath, nmsg);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
415 if (link (msg, newmsg) == NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
416 #ifndef EISREMOTE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
417 linkerr = errno;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
418 #else /* EISREMOTE */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
419 if ((linkerr = errno) == EISREMOTE)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
420 linkerr = EXDEV;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
421 #endif /* EISREMOTE */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
422 if (linkerr == EEXIST
bce86c4163a3 Initial revision
kono
parents:
diff changeset
423 || (linkerr == EXDEV && stat (newmsg, &st) != NOTOK)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
424 if (linkerr != EEXIST
bce86c4163a3 Initial revision
kono
parents:
diff changeset
425 || stat (msg, &s1) == NOTOK
bce86c4163a3 Initial revision
kono
parents:
diff changeset
426 || stat (newmsg, &st) == NOTOK
bce86c4163a3 Initial revision
kono
parents:
diff changeset
427 || s1.st_ino != st.st_ino) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
428 advise (NULLCP, "message %s:%s already exists",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
429 fp -> f_name, newmsg);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
430 return 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
431 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
432 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
433 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
434 if (linkerr == EXDEV) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
435 if ((in = open (msg, 0)) == NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
436 advise (msg, "unable to open message %s");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
437 return 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
438 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
439 (void) fstat (in, &st);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
440 if ((out = creat (newmsg, (int) st.st_mode & 0777))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
441 == NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
442 advise (newmsg, "unable to create");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
443 (void) close (in);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
444 return 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
445 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
446 cpydata (in, out, msg, newmsg);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
447 (void) close (in);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
448 (void) close (out);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
449 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
450 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
451 advise (newmsg, "error linking %s to", msg);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
452 return 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
453 }
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 return 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
458 }