X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=uip%2Fsend.c;h=07f25457480898b665de0f990afac7637b4f6147;hb=8ab7ca4f2b4caa1f1ed2859d7d911513a7b2b2a2;hp=3c2db0ea222c00d9b75ee0725ec23bdea61bdd0c;hpb=04e93dabf152cc30d0aeb043d65f911ef765a176;p=mmh diff --git a/uip/send.c b/uip/send.c index 3c2db0e..07f2545 100644 --- a/uip/send.c +++ b/uip/send.c @@ -11,7 +11,6 @@ #include #include #include -#include #include #include #include @@ -28,8 +27,6 @@ char *altmsg = NULL; char *annotext = NULL; char *distfile = NULL; -static jmp_buf env; - /* name of temp file for body content */ static char body_file_name[MAXPATHLEN + 1]; /* name of mhbuild composition temporary file */ @@ -44,7 +41,6 @@ static FILE *composition_file; /* composition file pointer */ ** static prototypes */ static int sendsbr(char **, int, char *, struct stat *); -static void armed_done(int) NORETURN; static void anno(struct stat *); static int sendaux(char **, int, char *, struct stat *); static int attach(char *); @@ -99,7 +95,7 @@ main(int argc, char **argv) switch (smatch(++cp, switches)) { case AMBIGSW: ambigsw(cp, switches); - done(1); + exit(1); case UNKWNSW: adios(NULL, "-%s unknown\n", cp); @@ -108,10 +104,10 @@ main(int argc, char **argv) "%s [file] [switches]", invo_name); print_help(buf, switches, 1); - done(1); + exit(0); case VERSIONSW: print_version(invo_name); - done(1); + exit(0); case DEBUGSW: debugsw++; @@ -150,7 +146,7 @@ main(int argc, char **argv) /* parse all the msgranges/sequences and set SELECTED */ for (msgnum = 0; msgnum < nmsgs; msgnum++) { if (!m_convert(mp, msgs[msgnum])) { - done(1); + exit(1); } } seq_setprev(mp); @@ -217,7 +213,7 @@ main(int argc, char **argv) for (n = 0; n < nfiles; n++) { switch (sendsbr(vec, vecp, files[n], &st)) { case DONE: - done(++status); + exit(++status); case NOTOK: status++; /* fall */ case OK: @@ -226,8 +222,7 @@ main(int argc, char **argv) } context_save(); - done(status); - return 1; + return status; } @@ -237,8 +232,7 @@ main(int argc, char **argv) static int sendsbr(char **vec, int vecp, char *drft, struct stat *st) { - int status; - char buffer[BUFSIZ]; + int status, dupfd; char *original_draft; /* @@ -289,19 +283,19 @@ sendsbr(char **vec, int vecp, char *drft, struct stat *st) break; } - done=armed_done; - switch (setjmp(env)) { + switch (sendaux(vec, vecp, drft, st)) { case OK: - status = sendaux(vec, vecp, drft, st) ? NOTOK : OK; - if (status == OK) { - /* move original draft to +trash folder */ - snprintf(buffer, sizeof buffer, - "