X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/8cebca1119664be52f1cbccd0ee052ae0b8c1de0..63621a81d16ab743de6b57d47578a9a2c670ad22:/uip/viamail.c diff --git a/uip/viamail.c b/uip/viamail.c index 6bce740f..db93066f 100644 --- a/uip/viamail.c +++ b/uip/viamail.c @@ -1,6 +1,4 @@ - -/* - * viamail.c -- send multiple files in a MIME message +/* viamail.c -- send multiple files in a MIME message * * This code is Copyright (c) 2002, by the authors of nmh. See the * COPYRIGHT file in the root directory of the nmh distribution for @@ -9,12 +7,14 @@ #include #include -#include #include #include #include #include #include +#include +#include "sbr/m_mktemp.h" +#include "sbr/base64.h" #define VIAMAIL_SWITCHES \ X("to mailpath", 0, TOSW) \ @@ -54,11 +54,10 @@ main (int argc, char **argv) int delay = 0; char *f1 = NULL, *f2 = NULL, *f3 = NULL; char *f4 = NULL, *f5 = NULL, *f7 = NULL; - static char postpath[PATH_MAX]; char *cp, buf[BUFSIZ]; char **argp, **arguments; - if (nmh_init(argv[0], 0 /* use context_foil() */)) { return 1; } + if (nmh_init(argv[0], 2)) { return 1; } arguments = getarguments (invo_name, argc, argv, 0); argp = arguments; @@ -133,34 +132,6 @@ main (int argc, char **argv) if (!f1) adios (NULL, "missing -viamail \"mailpath\" switch"); - /* viamail doesn't read the context and postproc isn't always what - we want, such as when running make distcheck. If we have the - absolute path, set postproc to point to post in the same - directory as this executable. - This could be generalized to handle relative paths (by - converting to absolute), to find the full path from PATH given - just the basename, and to squash out ../ but it's only needed - here. viamail is typically called from sendfiles, which - provides the absolute path. - */ - if (argv[0] && argv[0][0] == '/' && - strlen(argv[0]) - 3 < sizeof postpath) { - strncpy (postpath, argv[0], sizeof postpath - 1); - postpath[sizeof postpath - 1] = '\0'; - if ((cp = strrchr (postpath, '/'))) { - struct stat st; - - *(cp + 1) = '\0'; - /* strlen ("post") <= sizeof postpath - (cp - postpath) - 2 - but use strncat just in case the code above changes. */ - strncat (postpath, "post", sizeof postpath - (cp - postpath) - 2); - - if (stat (postpath, &st) == OK) { - postproc = postpath; - } - } - } - via_mail (f1, f2, f3, f4, f5, delay, f7); return 0; /* dead code to satisfy the compiler */ } @@ -219,7 +190,7 @@ via_mail (char *mailsw, char *subjsw, char *parmsw, char *descsw, if (fflush (fp)) adios (tmpfil, "error writing to"); - writeBase64aux (stdin, fp); + writeBase64aux (stdin, fp, 0); if (fflush (fp)) adios (tmpfil, "error writing to"); @@ -243,7 +214,7 @@ via_mail (char *mailsw, char *subjsw, char *parmsw, char *descsw, vec[vecp++] = cp; } - switch (sendsbr (vec, vecp, program, tmpfil, &st, 0, (char *)0, 0)) { + switch (sendsbr (vec, vecp, program, tmpfil, &st, 0, NULL)) { case DONE: case NOTOK: status++;