X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=uip%2Fviamail.c;h=e9b26b76e3eb63c3cfae266cb75aa82de1181504;hb=7946a8c713bd43a52229345ad0289aaa461acfb3;hp=859dfafa645fd8296093a556be7f4cfc1749e659;hpb=5ff96d61ee5af34956ae958a0bc72ee78734a4d7;p=mmh diff --git a/uip/viamail.c b/uip/viamail.c index 859dfaf..e9b26b7 100644 --- a/uip/viamail.c +++ b/uip/viamail.c @@ -2,8 +2,6 @@ /* * viamail.c -- send multiple files in a MIME message * - * $Id$ - * * This code is Copyright (c) 2002, by the authors of nmh. See the * COPYRIGHT file in the root directory of the nmh distribution for * complete copyright information. @@ -20,10 +18,6 @@ #include #include -#ifdef HAVE_SYS_WAIT_H -# include -#endif - static struct swit switches[] = { #define TOSW 0 { "to mailpath", 0 }, @@ -58,12 +52,6 @@ extern int verbsw; int ebcdicsw = 0; /* hack for linking purposes */ -/* mhmisc.c */ -void set_endian (void); - -/* mhoutsbr.c */ -int writeBase64aux (FILE *, FILE *); - /* * static prototypes */ @@ -103,10 +91,10 @@ main (int argc, char **argv) case HELPSW: snprintf (buf, sizeof(buf), "%s [switches]", invo_name); print_help (buf, switches, 1); - done (1); + done (0); case VERSIONSW: print_version(invo_name); - done (1); + done (0); case TOSW: if (!(f1 = *argp++)) @@ -158,8 +146,6 @@ main (int argc, char **argv) } } - set_endian (); - if (!f1) adios (NULL, "missing -viamail \"mailpath\" switch"); @@ -181,16 +167,17 @@ via_mail (char *mailsw, char *subjsw, char *parmsw, char *descsw, char *vec[MAXARGS]; struct stat st; FILE *fp; + char *tfile = NULL; umask (~m_gmprot ()); - strncpy (tmpfil, m_tmpfil (invo_name), sizeof(tmpfil)); - if ((fp = fopen (tmpfil, "w+")) == NULL) - adios (tmpfil, "unable to open for writing"); - chmod (tmpfil, 0600); + tfile = m_mktemp2(NULL, invo_name, NULL, &fp); + if (tfile == NULL) adios("viamail", "unable to create temporary file"); + chmod(tfile, 0600); + strncpy (tmpfil, tfile, sizeof(tmpfil)); if (!strchr(mailsw, '@')) - mailsw = concat (mailsw, "@", LocalName (), NULL); + mailsw = concat (mailsw, "@", LocalName (0), NULL); fprintf (fp, "To: %s\n", mailsw); if (subjsw) @@ -198,7 +185,7 @@ via_mail (char *mailsw, char *subjsw, char *parmsw, char *descsw, if (fromsw) { if (!strchr(fromsw, '@')) - fromsw = concat (fromsw, "@", LocalName (), NULL); + fromsw = concat (fromsw, "@", LocalName (0), NULL); fprintf (fp, "From: %s\n", fromsw); } @@ -248,5 +235,6 @@ via_mail (char *mailsw, char *subjsw, char *parmsw, char *descsw, fclose (fp); if (unlink (tmpfil) == -1) advise (NULL, "unable to remove temp file %s", tmpfil); - return done (status); + done (status); + return 1; }