X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/a109ec7024b3c857ab1b628788ec6c15c19ca513..bb8a255634719c63cfae1ee4d0fb12f056efa71b:/uip/post.c diff --git a/uip/post.c b/uip/post.c index 02e3283a..5f70e62f 100644 --- a/uip/post.c +++ b/uip/post.c @@ -323,7 +323,7 @@ main (int argc, char **argv) char *cp, *msg = NULL, **argp, **arguments, *envelope; char buf[NMH_BUFSIZ], name[NAMESZ], *auth_svc = NULL; FILE *in, *out; - m_getfld_state_t gstate = 0; + m_getfld_state_t gstate; if (nmh_init(argv[0], 0 /* use context_foil() */)) { return 1; } @@ -619,16 +619,17 @@ main (int argc, char **argv) hdrtab = msgstate == NORMAL ? NHeaders : RHeaders; + gstate = m_getfld_state_init(in); for (compnum = 1;;) { int bufsz = sizeof buf; - switch (state = m_getfld (&gstate, name, buf, &bufsz, in)) { + switch (state = m_getfld2(&gstate, name, buf, &bufsz)) { case FLD: case FLDPLUS: compnum++; cp = mh_xstrdup(buf); while (state == FLDPLUS) { bufsz = sizeof buf; - state = m_getfld (&gstate, name, buf, &bufsz, in); + state = m_getfld2(&gstate, name, buf, &bufsz); cp = add (buf, cp); } putfmt (name, cp, &eai, out); @@ -642,7 +643,7 @@ main (int argc, char **argv) fprintf (out, "\n%s", buf); while (state == BODY) { bufsz = sizeof buf; - state = m_getfld (&gstate, name, buf, &bufsz, in); + state = m_getfld2(&gstate, name, buf, &bufsz); fputs (buf, out); } break; @@ -886,7 +887,7 @@ putfmt (char *name, char *str, int *eai, FILE *out) if ((msgstate == RESENT) ? (hdr->set & MRFM) : (hdr->set & MFRM)) { savehdr = fullfrom; savehdr[0] = '\0'; - savehdlen = sizeof(fullfrom); + savehdrlen = sizeof(fullfrom); } tmpaddrs.m_next = NULL; @@ -1068,13 +1069,12 @@ putfmt (char *name, char *str, int *eai, FILE *out) mnfree (mp); } -#error - strncpy(fullfrom, str, sizeof(fullfrom)); - fullfrom[sizeof(fullfrom) - 1] = 0; - /* - * Strip off any trailing newlines - */ + /* + * If it was a From header, strip off any trailing newlines from + * the alias-expanded From line. + */ + if ((msgstate == RESENT) ? (hdr->set & MRFM) : (hdr->set & MFRM)) { while (*fullfrom && fullfrom[strlen(fullfrom) - 1] == '\n') { fullfrom[strlen(fullfrom) - 1] = '\0'; } @@ -1298,7 +1298,7 @@ putadr (char *name, char *aka, struct mailname *mp, FILE *out, fputs (cp, out); if (saveappend && shlen + len < savehdrsize) - strncat(savehdr, out); + strncat(savehdr, cp, savehdrsize - shlen + len); linepos += len;