]>
diplodocus.org Git - nmh/blob - uip/distsbr.c
3 * distsbr.c -- routines to do additional "dist-style" processing
5 * This code is Copyright (c) 2002, by the authors of nmh. See the
6 * COPYRIGHT file in the root directory of the nmh distribution for
7 * complete copyright information.
14 static int hdrfd
= NOTOK
;
15 static int txtfd
= NOTOK
;
17 #define BADHDR "please re-edit %s to remove the ``%s'' header!"
18 #define BADTXT "please re-edit %s to consist of headers only!"
19 #define BADMSG "please re-edit %s to include a ``Resent-To:''!"
20 #define BADRFT "please re-edit %s and fix that header!"
25 static void ready_msg(char *);
28 distout (char *drft
, char *msgnam
, char *backup
)
31 register unsigned char *dp
;
32 register char *resent
;
33 char name
[NAMESZ
], buffer
[BUFSIZ
];
34 register FILE *ifp
, *ofp
;
36 if (rename (drft
, strcpy (backup
, m_backup (drft
))) == NOTOK
)
37 adios (backup
, "unable to rename %s to",drft
);
38 if ((ifp
= fopen (backup
, "r")) == NULL
)
39 adios (backup
, "unable to read");
41 if ((ofp
= fopen (drft
, "w")) == NULL
)
42 adios (drft
, "unable to create temporary file");
43 chmod (drft
, m_gmprot ());
46 lseek (hdrfd
, (off_t
) 0, SEEK_SET
); /* msgnam not accurate */
47 cpydata (hdrfd
, fileno (ofp
), msgnam
, drft
);
49 for (state
= FLD
, resent
= NULL
;;) {
50 int buffersz
= sizeof buffer
;
51 switch (state
= m_getfld (state
, name
, buffer
, &buffersz
, ifp
)) {
55 if (uprf (name
, "distribute-"))
56 snprintf (name
, sizeof(name
), "%s%s", "Resent", &name
[10]);
57 if (uprf (name
, "distribution-"))
58 snprintf (name
, sizeof(name
), "%s%s", "Resent", &name
[12]);
59 if (!uprf (name
, "resent")) {
60 advise (NULL
, BADHDR
, "draft", name
);
64 resent
= add (":", add (name
, resent
));
65 resent
= add (buffer
, resent
);
66 fprintf (ofp
, "%s: %s", name
, buffer
);
67 while (state
== FLDPLUS
) {
68 buffersz
= sizeof buffer
;
69 state
= m_getfld (state
, name
, buffer
, &buffersz
, ifp
);
70 resent
= add (buffer
, resent
);
79 for (dp
= buffer
; *dp
; dp
++)
81 advise (NULL
, BADTXT
, "draft");
90 advise (NULL
, BADRFT
, "draft");
95 if (rename (backup
, drft
) == NOTOK
)
96 adios (drft
, "unable to rename %s to", backup
);
100 adios (NULL
, "getfld() returned %d", state
);
108 advise (NULL
, BADMSG
, "draft");
111 if (rename (backup
, drft
) == NOTOK
)
112 adios (drft
, "unable to rename %s to", backup
);
117 if (txtfd
!= NOTOK
) {
118 lseek (txtfd
, (off_t
) 0, SEEK_SET
); /* msgnam not accurate */
119 cpydata (txtfd
, fileno (ofp
), msgnam
, drft
);
129 ready_msg (char *msgnam
)
132 char name
[NAMESZ
], buffer
[BUFSIZ
], tmpfil
[BUFSIZ
];
133 register FILE *ifp
, *ofp
;
137 close (hdrfd
), hdrfd
= NOTOK
;
139 close (txtfd
), txtfd
= NOTOK
;
141 if ((ifp
= fopen (msgnam
, "r")) == NULL
)
142 adios (msgnam
, "unable to open message");
144 cp
= m_mktemp2(NULL
, "dist", &hdrfd
, NULL
);
146 adios("distsbr", "unable to create temporary file");
149 strncpy(tmpfil
, cp
, sizeof(tmpfil
));
150 if ((out
= dup (hdrfd
)) == NOTOK
151 || (ofp
= fdopen (out
, "w")) == NULL
)
152 adios (NULL
, "no file descriptors -- you lose big");
155 for (state
= FLD
;;) {
156 int buffersz
= sizeof buffer
;
157 switch (state
= m_getfld (state
, name
, buffer
, &buffersz
, ifp
)) {
161 if (uprf (name
, "resent"))
162 fprintf (ofp
, "Prev-");
163 fprintf (ofp
, "%s: %s", name
, buffer
);
164 while (state
== FLDPLUS
) {
165 buffersz
= sizeof buffer
;
166 state
= m_getfld (state
, name
, buffer
, &buffersz
, ifp
);
177 cp
= m_mktemp2(NULL
, "dist", &txtfd
, NULL
);
179 adios("distsbr", "unable to create temporary file");
182 strncpy (tmpfil
, cp
, sizeof(tmpfil
));
183 if ((out
= dup (txtfd
)) == NOTOK
184 || (ofp
= fdopen (out
, "w")) == NULL
)
185 adios (NULL
, "no file descriptors -- you lose big");
187 fprintf (ofp
, "\n%s", buffer
);
188 while (state
== BODY
) {
189 buffersz
= sizeof buffer
;
190 state
= m_getfld (state
, name
, buffer
, &buffersz
, ifp
);
198 adios (NULL
, "format error in message %s", msgnam
);
201 adios (NULL
, "getfld() returned %d", state
);