annotate uip/pick.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 /* pick.c - select messages by content */
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 "../h/mh.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
7 #include "../zotnet/tws.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
8 #include <stdio.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
9 #ifdef LOCALE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
10 #include <locale.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
11 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
12
bce86c4163a3 Initial revision
kono
parents:
diff changeset
13 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
14
bce86c4163a3 Initial revision
kono
parents:
diff changeset
15 static struct swit switches[] = {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
16 #define ANDSW 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
17 "and", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
18 #define ORSW 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
19 "or", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
20 #define NOTSW 2
bce86c4163a3 Initial revision
kono
parents:
diff changeset
21 "not", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
22 #define LBRSW 3
bce86c4163a3 Initial revision
kono
parents:
diff changeset
23 "lbrace", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
24 #define RBRSW 4
bce86c4163a3 Initial revision
kono
parents:
diff changeset
25 "rbrace", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
26
bce86c4163a3 Initial revision
kono
parents:
diff changeset
27 #define CCSW 5
bce86c4163a3 Initial revision
kono
parents:
diff changeset
28 "cc pattern", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
29 #define DATESW 6
bce86c4163a3 Initial revision
kono
parents:
diff changeset
30 "date pattern", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
31 #define FROMSW 7
bce86c4163a3 Initial revision
kono
parents:
diff changeset
32 "from pattern", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
33 #define SRCHSW 8
bce86c4163a3 Initial revision
kono
parents:
diff changeset
34 "search pattern", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
35 #define SUBJSW 9
bce86c4163a3 Initial revision
kono
parents:
diff changeset
36 "subject pattern", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
37 #define TOSW 10
bce86c4163a3 Initial revision
kono
parents:
diff changeset
38 "to pattern", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
39 #define OTHRSW 11
bce86c4163a3 Initial revision
kono
parents:
diff changeset
40 "-othercomponent pattern", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
41 #define AFTRSW 12
bce86c4163a3 Initial revision
kono
parents:
diff changeset
42 "after date", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
43 #define BEFRSW 13
bce86c4163a3 Initial revision
kono
parents:
diff changeset
44 "before date", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
45 #define DATFDSW 14
bce86c4163a3 Initial revision
kono
parents:
diff changeset
46 "datefield field", 5,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
47
bce86c4163a3 Initial revision
kono
parents:
diff changeset
48 #define SEQSW 15
bce86c4163a3 Initial revision
kono
parents:
diff changeset
49 "sequence name", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
50 #define PUBLSW 16
bce86c4163a3 Initial revision
kono
parents:
diff changeset
51 "public", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
52 #define NPUBLSW 17
bce86c4163a3 Initial revision
kono
parents:
diff changeset
53 "nopublic", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
54 #define ZEROSW 18
bce86c4163a3 Initial revision
kono
parents:
diff changeset
55 "zero", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
56 #define NZEROSW 19
bce86c4163a3 Initial revision
kono
parents:
diff changeset
57 "nozero", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
58
bce86c4163a3 Initial revision
kono
parents:
diff changeset
59 #define LISTSW 20
bce86c4163a3 Initial revision
kono
parents:
diff changeset
60 "list", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
61 #define NLISTSW 21
bce86c4163a3 Initial revision
kono
parents:
diff changeset
62 "nolist", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
63
bce86c4163a3 Initial revision
kono
parents:
diff changeset
64 #define HELPSW 22
bce86c4163a3 Initial revision
kono
parents:
diff changeset
65 "help", 4,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
66
bce86c4163a3 Initial revision
kono
parents:
diff changeset
67 NULL, 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
68 };
bce86c4163a3 Initial revision
kono
parents:
diff changeset
69
bce86c4163a3 Initial revision
kono
parents:
diff changeset
70 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
71
bce86c4163a3 Initial revision
kono
parents:
diff changeset
72 static int listsw = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
73
bce86c4163a3 Initial revision
kono
parents:
diff changeset
74 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
75
bce86c4163a3 Initial revision
kono
parents:
diff changeset
76 /* ARGSUSED */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
77
bce86c4163a3 Initial revision
kono
parents:
diff changeset
78 main (argc, argv)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
79 char *argv[];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
80 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
81 int publicsw = -1,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
82 zerosw = 1,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
83 msgp = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
84 seqp = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
85 vecp = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
86 lo,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
87 hi,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
88 msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
89 char *maildir,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
90 *folder = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
91 buf[100],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
92 *cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
93 **ap,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
94 **argp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
95 *arguments[MAXARGS],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
96 *msgs[MAXARGS],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
97 *seqs[NATTRS + 1],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
98 *vec[MAXARGS];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
99 struct msgs *mp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
100 register FILE *fp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
101
bce86c4163a3 Initial revision
kono
parents:
diff changeset
102 #ifdef LOCALE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
103 setlocale(LC_ALL, "");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
104 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
105 #ifdef JAPAN
bce86c4163a3 Initial revision
kono
parents:
diff changeset
106 ml_init();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
107 #endif /* JAPAN */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
108 invo_name = r1bindex (argv[0], '/');
bce86c4163a3 Initial revision
kono
parents:
diff changeset
109 if ((cp = m_find (invo_name)) != NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
110 ap = brkstring (cp = getcpy (cp), " ", "\n");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
111 ap = copyip (ap, arguments);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
112 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
113 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
114 ap = arguments;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
115 (void) copyip (argv + 1, ap);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
116 argp = arguments;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
117
bce86c4163a3 Initial revision
kono
parents:
diff changeset
118 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
119
bce86c4163a3 Initial revision
kono
parents:
diff changeset
120 while (cp = *argp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
121 if (*cp == '-') {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
122 if (*++cp == '-') {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
123 vec[vecp++] = --cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
124 goto pattern;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
125 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
126 switch (smatch (cp, switches)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
127 case AMBIGSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
128 ambigsw (cp, switches);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
129 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
130 case UNKWNSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
131 adios (NULLCP, "-%s unknown", cp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
132 case HELPSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
133 (void) sprintf (buf, "%s [+folder] [msgs] [switches]",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
134 invo_name);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
135 help (buf, switches);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
136 listsw = 0; /* HACK */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
137 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
138
bce86c4163a3 Initial revision
kono
parents:
diff changeset
139 case CCSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
140 case DATESW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
141 case FROMSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
142 case SUBJSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
143 case TOSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
144 case DATFDSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
145 case AFTRSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
146 case BEFRSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
147 case SRCHSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
148 vec[vecp++] = --cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
149 pattern: ;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
150 if (!(cp = *argp++))/* allow -xyz arguments */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
151 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
152 vec[vecp++] = cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
153 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
154 case OTHRSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
155 adios (NULLCP, "internal error!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
156
bce86c4163a3 Initial revision
kono
parents:
diff changeset
157 case ANDSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
158 case ORSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
159 case NOTSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
160 case LBRSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
161 case RBRSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
162 vec[vecp++] = --cp;
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 case SEQSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
166 if (!(cp = *argp++) || *cp == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
167 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
168 if (seqp < NATTRS)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
169 seqs[seqp++] = cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
170 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
171 adios (NULLCP, "only %d sequences allowed!", NATTRS);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
172 listsw = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
173 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
174 case PUBLSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
175 publicsw = 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
176 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
177 case NPUBLSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
178 publicsw = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
179 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
180 case ZEROSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
181 zerosw++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
182 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
183 case NZEROSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
184 zerosw = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
185 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
186
bce86c4163a3 Initial revision
kono
parents:
diff changeset
187 case LISTSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
188 listsw++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
189 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
190 case NLISTSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
191 listsw = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
192 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
193 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
194 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
195 if (*cp == '+' || *cp == '@')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
196 if (folder)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
197 adios (NULLCP, "only one folder at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
198 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
199 folder = path (cp + 1, *cp == '+' ? TFOLDER : TSUBCWF);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
200 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
201 msgs[msgp++] = cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
202 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
203 vec[vecp] = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
204
bce86c4163a3 Initial revision
kono
parents:
diff changeset
205 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
206
bce86c4163a3 Initial revision
kono
parents:
diff changeset
207 if (!m_find ("path"))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
208 free (path ("./", TFOLDER));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
209 if (!msgp)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
210 msgs[msgp++] = "all";
bce86c4163a3 Initial revision
kono
parents:
diff changeset
211 if (!folder)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
212 folder = m_getfolder ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
213 maildir = m_maildir (folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
214
bce86c4163a3 Initial revision
kono
parents:
diff changeset
215 if (chdir (maildir) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
216 adios (maildir, "unable to change directory to");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
217 if (!(mp = m_gmsg (folder)))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
218 adios (NULLCP, "unable to read folder %s", folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
219 if (mp -> hghmsg == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
220 adios (NULLCP, "no messages in %s", folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
221
bce86c4163a3 Initial revision
kono
parents:
diff changeset
222 for (msgnum = 0; msgnum < msgp; msgnum++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
223 if (!m_convert (mp, msgs[msgnum]))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
224 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
225 m_setseq (mp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
226
bce86c4163a3 Initial revision
kono
parents:
diff changeset
227 if (seqp == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
228 listsw++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
229 if (publicsw == -1)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
230 publicsw = mp -> msgflags & READONLY ? 0 : 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
231 if (publicsw && (mp -> msgflags & READONLY))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
232 adios (NULLCP, "folder %s is read-only, so -public not allowed",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
233 folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
234
bce86c4163a3 Initial revision
kono
parents:
diff changeset
235 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
236
bce86c4163a3 Initial revision
kono
parents:
diff changeset
237 if (!pcompile (vec, NULLCP))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
238 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
239
bce86c4163a3 Initial revision
kono
parents:
diff changeset
240 lo = mp -> lowsel;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
241 hi = mp -> hghsel;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
242
bce86c4163a3 Initial revision
kono
parents:
diff changeset
243 for (msgnum = mp -> lowsel; msgnum <= mp -> hghsel; msgnum++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
244 if (mp -> msgstats[msgnum] & SELECTED) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
245 if ((fp = fopen (cp = m_name (msgnum), "r")) == NULL)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
246 admonish (cp, "unable to read message");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
247 if (fp && pmatches (fp, msgnum, 0L, 0L)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
248 if (msgnum < lo)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
249 lo = msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
250 if (msgnum > hi)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
251 hi = msgnum;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
252 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
253 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
254 mp -> msgstats[msgnum] &= ~SELECTED;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
255 mp -> numsel--;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
256 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
257 if (fp)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
258 (void) fclose (fp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
259 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
260
bce86c4163a3 Initial revision
kono
parents:
diff changeset
261 mp -> lowsel = lo;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
262 mp -> hghsel = hi;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
263
bce86c4163a3 Initial revision
kono
parents:
diff changeset
264 if (mp -> numsel <= 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
265 adios (NULLCP, "no messages match specification");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
266
bce86c4163a3 Initial revision
kono
parents:
diff changeset
267 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
268
bce86c4163a3 Initial revision
kono
parents:
diff changeset
269 seqs[seqp] = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
270 for (seqp = 0; seqs[seqp]; seqp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
271 if (zerosw && !m_seqnew (mp, seqs[seqp], publicsw))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
272 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
273 for (msgnum = mp -> lowsel; msgnum <= mp -> hghsel; msgnum++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
274 if (mp -> msgstats[msgnum] & SELECTED)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
275 if (!m_seqadd (mp, seqs[seqp], msgnum, publicsw))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
276 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
277 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
278
bce86c4163a3 Initial revision
kono
parents:
diff changeset
279 if (listsw) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
280 for (msgnum = mp -> lowsel; msgnum <= mp -> hghsel; msgnum++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
281 if (mp -> msgstats[msgnum] & SELECTED)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
282 printf ("%s\n", m_name (msgnum));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
283 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
284 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
285 printf ("%d hit%s\n", mp -> numsel,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
286 mp -> numsel == 1 ? "" : "s");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
287
bce86c4163a3 Initial revision
kono
parents:
diff changeset
288 m_replace (pfolder, folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
289 m_sync (mp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
290 m_update ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
291
bce86c4163a3 Initial revision
kono
parents:
diff changeset
292 done (0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
293 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
294
bce86c4163a3 Initial revision
kono
parents:
diff changeset
295 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
296
bce86c4163a3 Initial revision
kono
parents:
diff changeset
297 void done (status)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
298 int status;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
299 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
300 if (listsw && status && !isatty (fileno (stdout)))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
301 printf ("0\n");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
302 exit (status);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
303 }