annotate uip/comp.c @ 0:bce86c4163a3

Initial revision
author kono
date Mon, 18 Apr 2005 23:46:02 +0900
parents
children 441a2190cfae
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
1 /* comp.c - compose a message */
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 <stdio.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
8 #include <sys/types.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
9 #include <sys/stat.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
10 #ifdef LOCALE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
11 #include <locale.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
12 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
13
bce86c4163a3 Initial revision
kono
parents:
diff changeset
14 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
15
bce86c4163a3 Initial revision
kono
parents:
diff changeset
16 static struct swit switches[] = {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
17 #define DFOLDSW 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
18 "draftfolder +folder", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
19 #define DMSGSW 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
20 "draftmessage msg", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
21 #define NDFLDSW 2
bce86c4163a3 Initial revision
kono
parents:
diff changeset
22 "nodraftfolder", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
23
bce86c4163a3 Initial revision
kono
parents:
diff changeset
24 #define EDITRSW 3
bce86c4163a3 Initial revision
kono
parents:
diff changeset
25 "editor editor", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
26 #define NEDITSW 4
bce86c4163a3 Initial revision
kono
parents:
diff changeset
27 "noedit", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
28
bce86c4163a3 Initial revision
kono
parents:
diff changeset
29 #define FILESW 5
bce86c4163a3 Initial revision
kono
parents:
diff changeset
30 "file file", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
31 #define FORMSW 6
bce86c4163a3 Initial revision
kono
parents:
diff changeset
32 "form formfile", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
33
bce86c4163a3 Initial revision
kono
parents:
diff changeset
34 #define USESW 7
bce86c4163a3 Initial revision
kono
parents:
diff changeset
35 "use", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
36 #define NUSESW 8
bce86c4163a3 Initial revision
kono
parents:
diff changeset
37 "nouse", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
38
bce86c4163a3 Initial revision
kono
parents:
diff changeset
39 #define WHATSW 9
bce86c4163a3 Initial revision
kono
parents:
diff changeset
40 "whatnowproc program", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
41 #define NWHATSW 10
bce86c4163a3 Initial revision
kono
parents:
diff changeset
42 "nowhatnowproc", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
43
bce86c4163a3 Initial revision
kono
parents:
diff changeset
44 #define HELPSW 11
bce86c4163a3 Initial revision
kono
parents:
diff changeset
45 "help", 4,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
46
bce86c4163a3 Initial revision
kono
parents:
diff changeset
47
bce86c4163a3 Initial revision
kono
parents:
diff changeset
48 NULL, 0
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
bce86c4163a3 Initial revision
kono
parents:
diff changeset
53 static struct swit aqrunl[] = {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
54 #define NOSW 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
55 "quit", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
56 #define YESW 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
57 "replace", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
58 #define USELSW 2
bce86c4163a3 Initial revision
kono
parents:
diff changeset
59 "use", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
60 #define LISTDSW 3
bce86c4163a3 Initial revision
kono
parents:
diff changeset
61 "list", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
62 #define REFILSW 4
bce86c4163a3 Initial revision
kono
parents:
diff changeset
63 "refile +folder", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
64 #define NEWSW 5
bce86c4163a3 Initial revision
kono
parents:
diff changeset
65 "new", 0,
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 static struct swit aqrul[] = {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
72 "quit", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
73 "replace", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
74 "use", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
75 "list", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
76 "refile", 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
77
bce86c4163a3 Initial revision
kono
parents:
diff changeset
78 NULL, 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
79 };
bce86c4163a3 Initial revision
kono
parents:
diff changeset
80
bce86c4163a3 Initial revision
kono
parents:
diff changeset
81 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
82
bce86c4163a3 Initial revision
kono
parents:
diff changeset
83 /* ARGSUSED */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
84
bce86c4163a3 Initial revision
kono
parents:
diff changeset
85 main (argc, argv)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
86 int argc;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
87 char *argv[];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
88 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
89 int use = NOUSE,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
90 nedit = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
91 nwhat = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
92 i,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
93 in,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
94 isdf = 0,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
95 out;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
96 char *cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
97 *cwd,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
98 *maildir,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
99 *dfolder = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
100 *ed = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
101 *file = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
102 *form = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
103 *folder = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
104 *msg = NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
105 buf[BUFSIZ],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
106 drft[BUFSIZ],
bce86c4163a3 Initial revision
kono
parents:
diff changeset
107 **ap,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
108 **argp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
109 *arguments[MAXARGS];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
110 struct msgs *mp = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
111 struct stat st;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
112
bce86c4163a3 Initial revision
kono
parents:
diff changeset
113 #ifdef LOCALE
bce86c4163a3 Initial revision
kono
parents:
diff changeset
114 setlocale(LC_ALL, "");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
115 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
116 #ifdef JAPAN
bce86c4163a3 Initial revision
kono
parents:
diff changeset
117 ml_init();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
118 #endif /* JAPAN */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
119 invo_name = r1bindex (argv[0], '/');
bce86c4163a3 Initial revision
kono
parents:
diff changeset
120 if ((cp = m_find (invo_name)) != NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
121 ap = brkstring (cp = getcpy (cp), " ", "\n");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
122 ap = copyip (ap, arguments);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
123 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
124 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
125 ap = arguments;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
126 (void) copyip (argv + 1, ap);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
127 argp = arguments;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
128
bce86c4163a3 Initial revision
kono
parents:
diff changeset
129 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
130
bce86c4163a3 Initial revision
kono
parents:
diff changeset
131 while (cp = *argp++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
132 if (*cp == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
133 switch (smatch (++cp, switches)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
134 case AMBIGSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
135 ambigsw (cp, switches);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
136 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
137 case UNKWNSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
138 adios (NULLCP, "-%s unknown", cp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
139 case HELPSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
140 (void) sprintf (buf, "%s [+folder] [msg] [switches]",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
141 invo_name);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
142 help (buf, switches);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
143 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
144
bce86c4163a3 Initial revision
kono
parents:
diff changeset
145 case EDITRSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
146 if (!(ed = *argp++) || *ed == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
147 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
148 nedit = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
149 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
150 case NEDITSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
151 nedit++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
152 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
153
bce86c4163a3 Initial revision
kono
parents:
diff changeset
154 case WHATSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
155 if (!(whatnowproc = *argp++) || *whatnowproc == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
156 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
157 nwhat = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
158 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
159 case NWHATSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
160 nwhat++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
161 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
162
bce86c4163a3 Initial revision
kono
parents:
diff changeset
163 case FORMSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
164 if (!(form = *argp++) || *form == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
165 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
166 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
167
bce86c4163a3 Initial revision
kono
parents:
diff changeset
168 case USESW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
169 use++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
170 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
171 case NUSESW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
172 use = NOUSE;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
173 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
174
bce86c4163a3 Initial revision
kono
parents:
diff changeset
175 case FILESW: /* compatibility */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
176 if (file)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
177 adios (NULLCP, "only one file at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
178 if (!(file = *argp++) || *file == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
179 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
180 isdf = NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
181 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
182
bce86c4163a3 Initial revision
kono
parents:
diff changeset
183 case DFOLDSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
184 if (dfolder)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
185 adios (NULLCP, "only one draft folder at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
186 if (!(cp = *argp++) || *cp == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
187 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
188 dfolder = path (*cp == '+' || *cp == '@' ? cp + 1 : cp,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
189 *cp != '@' ? TFOLDER : TSUBCWF);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
190 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
191 case DMSGSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
192 if (file)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
193 adios (NULLCP, "only one draft message at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
194 if (!(file = *argp++) || *file == '-')
bce86c4163a3 Initial revision
kono
parents:
diff changeset
195 adios (NULLCP, "missing argument to %s", argp[-2]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
196 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
197 case NDFLDSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
198 dfolder = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
199 isdf = NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
200 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
201 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
202 if (*cp == '+' || *cp == '@') {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
203 if (folder)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
204 adios (NULLCP, "only one folder at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
205 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
206 folder = path (cp + 1, *cp == '+' ? TFOLDER : TSUBCWF);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
207 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
208 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
209 if (msg)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
210 adios (NULLCP, "only one message at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
211 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
212 msg = cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
213 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
214
bce86c4163a3 Initial revision
kono
parents:
diff changeset
215 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
216
bce86c4163a3 Initial revision
kono
parents:
diff changeset
217 cwd = getcpy (pwd ());
bce86c4163a3 Initial revision
kono
parents:
diff changeset
218
bce86c4163a3 Initial revision
kono
parents:
diff changeset
219 if (!m_find ("path"))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
220 free (path ("./", TFOLDER));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
221
bce86c4163a3 Initial revision
kono
parents:
diff changeset
222 if ((dfolder || m_find ("Draft-Folder")) && !folder && msg && !file)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
223 file = msg, msg = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
224 if (form && (folder || msg))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
225 adios (NULLCP, "can't mix forms and folders/msgs");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
226
bce86c4163a3 Initial revision
kono
parents:
diff changeset
227 if (folder || msg) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
228 if (!msg)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
229 msg = "cur";
bce86c4163a3 Initial revision
kono
parents:
diff changeset
230 if (!folder)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
231 folder = m_getfolder ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
232 maildir = m_maildir (folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
233
bce86c4163a3 Initial revision
kono
parents:
diff changeset
234 if (chdir (maildir) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
235 adios (maildir, "unable to change directory to");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
236 if (!(mp = m_gmsg (folder)))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
237 adios (NULLCP, "unable to read folder %s", folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
238 if (mp -> hghmsg == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
239 adios (NULLCP, "no messages in %s", folder);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
240
bce86c4163a3 Initial revision
kono
parents:
diff changeset
241 if (!m_convert (mp, msg))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
242 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
243 m_setseq (mp);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
244
bce86c4163a3 Initial revision
kono
parents:
diff changeset
245 if (mp -> numsel > 1)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
246 adios (NULLCP, "only one message at a time!");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
247
bce86c4163a3 Initial revision
kono
parents:
diff changeset
248 if ((in = open (form = getcpy (m_name (mp -> lowsel)), 0)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
249 adios (form, "unable to open message");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
250 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
251 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
252 if (form) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
253 if ((in = open (libpath (form), 0)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
254 adios (form, "unable to open form file");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
255 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
256 else {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
257 if ((in = open (libpath (components), 0)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
258 adios (components, "unable to open default components file");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
259 form = components;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
260 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
261
bce86c4163a3 Initial revision
kono
parents:
diff changeset
262 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
263
bce86c4163a3 Initial revision
kono
parents:
diff changeset
264 try_it_again: ;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
265 (void) strcpy (drft, m_draft (dfolder, file, use, &isdf));
bce86c4163a3 Initial revision
kono
parents:
diff changeset
266 if ((out = open (drft, 0)) != NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
267 i = fdcompare (in, out);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
268 (void) close (out);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
269 if (use || i)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
270 goto edit_it;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
271
bce86c4163a3 Initial revision
kono
parents:
diff changeset
272 if (stat (drft, &st) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
273 adios (drft, "unable to stat");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
274 printf ("Draft \"%s\" exists (%ld bytes).", drft, (long) st.st_size);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
275 for (i = LISTDSW; i != YESW;) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
276 if (!(argp = getans ("\nDisposition? ", isdf ? aqrunl : aqrul)))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
277 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
278 switch (i = smatch (*argp, isdf ? aqrunl : aqrul)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
279 case NOSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
280 done (0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
281 case NEWSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
282 file = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
283 use = NOUSE;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
284 goto try_it_again;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
285 case YESW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
286 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
287 case USELSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
288 use++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
289 goto edit_it;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
290 case LISTDSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
291 (void) showfile (++argp, drft);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
292 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
293 case REFILSW:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
294 if (refile (++argp, drft) == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
295 i = YESW;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
296 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
297 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
298 advise (NULLCP, "say what?");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
299 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
300 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
301 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
302 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
303 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
304 if (use)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
305 adios (drft, "unable to open");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
306
bce86c4163a3 Initial revision
kono
parents:
diff changeset
307 if ((out = creat (drft, m_gmprot ())) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
308 adios (drft, "unable to create");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
309 cpydata (in, out, form, drft);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
310 (void) close (in);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
311 (void) close (out);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
312
bce86c4163a3 Initial revision
kono
parents:
diff changeset
313 edit_it: ;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
314 m_update ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
315
bce86c4163a3 Initial revision
kono
parents:
diff changeset
316 if (nwhat)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
317 done (0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
318 (void) what_now (ed, nedit, use, drft, NULLCP, 0, NULLMP, NULLCP, 0, cwd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
319 done (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
320 }