]>
diplodocus.org Git - nmh/blob - uip/distsbr.c
1 /* distsbr.c -- routines to do additional "dist-style" processing
3 * This code is Copyright (c) 2002, by the authors of nmh. See the
4 * COPYRIGHT file in the root directory of the nmh distribution for
5 * complete copyright information.
10 #include "sbr/m_gmprot.h"
11 #include "sbr/m_getfld.h"
12 #include "sbr/cpydata.h"
14 #include "sbr/m_backup.h"
15 #include "sbr/error.h"
18 #include "sbr/m_mktemp.h"
20 static int hdrfd
= NOTOK
;
21 static int txtfd
= NOTOK
;
23 #define BADHDR "please re-edit %s to remove the ``%s'' header!"
24 #define BADTXT "please re-edit %s to consist of headers only!"
25 #define BADMSG "please re-edit %s to include a ``Resent-To:''!"
26 #define BADRFT "please re-edit %s and fix that header!"
31 static void ready_msg(char *);
34 distout (char *drft
, char *msgnam
, char *backup
)
38 char name
[NAMESZ
], buffer
[NMH_BUFSIZ
];
40 m_getfld_state_t gstate
;
42 if (rename (drft
, strcpy (backup
, m_backup (drft
))) == NOTOK
)
43 adios (backup
, "unable to rename %s to",drft
);
44 if ((ifp
= fopen (backup
, "r")) == NULL
)
45 adios (backup
, "unable to read");
47 if ((ofp
= fopen (drft
, "w")) == NULL
)
48 adios (drft
, "unable to create temporary file");
49 chmod (drft
, m_gmprot ());
52 lseek(hdrfd
, 0, SEEK_SET
); /* msgnam not accurate */
53 cpydata (hdrfd
, fileno (ofp
), msgnam
, drft
);
55 gstate
= m_getfld_state_init(ifp
);
56 for (resent
= NULL
;;) {
57 int buffersz
= sizeof buffer
;
58 switch (state
= m_getfld2(&gstate
, name
, buffer
, &buffersz
)) {
61 if (uprf (name
, "distribute-"))
62 snprintf (name
, sizeof(name
), "%s%s", "Resent", &name
[10]);
63 if (uprf (name
, "distribution-"))
64 snprintf (name
, sizeof(name
), "%s%s", "Resent", &name
[12]);
65 if (!uprf (name
, "resent")) {
66 inform(BADHDR
, "draft", name
);
70 resent
= add (":", add (name
, resent
));
71 resent
= add (buffer
, resent
);
72 fprintf (ofp
, "%s: %s", name
, buffer
);
73 while (state
== FLDPLUS
) {
74 buffersz
= sizeof buffer
;
75 state
= m_getfld2(&gstate
, name
, buffer
, &buffersz
);
76 resent
= add (buffer
, resent
);
82 for (dp
= buffer
; *dp
; dp
++)
83 if (!isspace ((unsigned char) *dp
)) {
84 inform(BADTXT
, "draft");
93 inform(BADRFT
, "draft");
97 (void) m_unlink (drft
);
98 if (rename (backup
, drft
) == NOTOK
)
99 adios (drft
, "unable to rename %s to", backup
);
103 die("getfld() returned %d", state
);
107 m_getfld_state_destroy (&gstate
);
112 inform(BADMSG
, "draft");
114 (void) m_unlink (drft
);
115 if (rename (backup
, drft
) == NOTOK
)
116 adios (drft
, "unable to rename %s to", backup
);
121 if (txtfd
!= NOTOK
) {
122 lseek(txtfd
, 0, SEEK_SET
); /* msgnam not accurate */
123 cpydata (txtfd
, fileno (ofp
), msgnam
, drft
);
133 ready_msg (char *msgnam
)
136 char name
[NAMESZ
], buffer
[NMH_BUFSIZ
], tmpfil
[BUFSIZ
];
139 m_getfld_state_t gstate
;
141 if (hdrfd
!= NOTOK
) {
145 if (txtfd
!= NOTOK
) {
150 if ((ifp
= fopen (msgnam
, "r")) == NULL
)
151 adios (msgnam
, "unable to open message");
153 cp
= m_mktemp2(NULL
, "dist", &hdrfd
, NULL
);
155 die("unable to create temporary file in %s", get_temp_dir());
157 strncpy(tmpfil
, cp
, sizeof(tmpfil
));
158 if ((out
= dup (hdrfd
)) == NOTOK
159 || (ofp
= fdopen (out
, "w")) == NULL
)
160 die("no file descriptors -- you lose big");
161 (void) m_unlink (tmpfil
);
163 gstate
= m_getfld_state_init(ifp
);
165 int buffersz
= sizeof buffer
;
166 switch (state
= m_getfld2(&gstate
, name
, buffer
, &buffersz
)) {
169 if (uprf (name
, "resent"))
170 fprintf (ofp
, "Prev-");
171 fprintf (ofp
, "%s: %s", name
, buffer
);
172 while (state
== FLDPLUS
) {
173 buffersz
= sizeof buffer
;
174 state
= m_getfld2(&gstate
, name
, buffer
, &buffersz
);
182 cp
= m_mktemp2(NULL
, "dist", &txtfd
, NULL
);
184 die("unable to create temporary file in %s",
188 strncpy (tmpfil
, cp
, sizeof(tmpfil
));
189 if ((out
= dup (txtfd
)) == NOTOK
190 || (ofp
= fdopen (out
, "w")) == NULL
)
191 die("no file descriptors -- you lose big");
192 (void) m_unlink (tmpfil
);
193 fprintf (ofp
, "\n%s", buffer
);
194 while (state
== BODY
) {
195 buffersz
= sizeof buffer
;
196 state
= m_getfld2(&gstate
, name
, buffer
, &buffersz
);
204 die("format error in message %s", msgnam
);
207 die("getfld() returned %d", state
);
211 m_getfld_state_destroy (&gstate
);