X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/1e424a2249aa6b911fd3be973de00cee413342eb..cf57870921b26703aad420c6741c524b33736ff1:/sbr/error.c diff --git a/sbr/error.c b/sbr/error.c index 5dc84e87..b33eae54 100644 --- a/sbr/error.c +++ b/sbr/error.c @@ -29,9 +29,9 @@ advise (const char *what, const char *fmt, ...) /* adios calls advertise() with no tail to print fmt, and perhaps what, * to stderr, and "ends" the program with an error exit status. The * route to exit is via the done function pointer and may not be - * straightforward. - * FIXME: Document if this function can ever return. If not, perhaps an - * abort(3) at the end of the routine would make that more clear. */ + * straightforward, e.g. longjmp(3), but it must not return to adios(). + * If it does then it's a bug and adios() will abort(3) as callers do + * not expect execution to continue. */ void adios (const char *what, const char *fmt, ...) { @@ -41,6 +41,7 @@ adios (const char *what, const char *fmt, ...) advertise (what, NULL, fmt, ap); va_end(ap); done (1); + abort(); } @@ -69,8 +70,9 @@ void advertise (const char *what, char *tail, const char *fmt, va_list ap) { int eindex = errno; - char buffer[BUFSIZ], errbuf[BUFSIZ], *err; - struct iovec iob[20], *iov; + char buffer[NMH_BUFSIZ], errbuf[NMH_BUFSIZ], *err; + struct iovec iob[10], *iov; + size_t niov; iov = iob; @@ -112,9 +114,12 @@ advertise (const char *what, char *tail, const char *fmt, va_list ap) #undef ADD_LITERAL #undef ADD_VAR + niov = iov - iob; + assert(niov <= DIM(iob)); + fflush (stdout); fflush (stderr); - if (writev (fileno (stderr), iob, iov - iob) < 0) { + if (writev(fileno(stderr), iob, niov) == -1) { snprintf(buffer, sizeof buffer, "%s: write stderr failed: %d\n", invo_name && *invo_name ? invo_name : "nmh", errno); if (write(2, buffer, strlen(buffer)) == -1) {