From 545031a076d4b5712442a8fc2d983f1e9d9f4f79 Mon Sep 17 00:00:00 2001 From: Hiltjo Posthuma Date: Sun, 27 Oct 2024 20:08:46 +0100 Subject: [PATCH] util.c: output function might override errno and thus affect perror() Original patch by Raymond Cole with some modifications, thanks! --- util.c | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/util.c b/util.c index 96b82c9..8e26a51 100644 --- a/util.c +++ b/util.c @@ -1,4 +1,5 @@ /* See LICENSE file for copyright and license details. */ +#include #include #include #include @@ -10,17 +11,17 @@ void die(const char *fmt, ...) { va_list ap; + int saved_errno; + + saved_errno = errno; va_start(ap, fmt); vfprintf(stderr, fmt, ap); va_end(ap); - if (fmt[0] && fmt[strlen(fmt)-1] == ':') { - fputc(' ', stderr); - perror(NULL); - } else { - fputc('\n', stderr); - } + if (fmt[0] && fmt[strlen(fmt)-1] == ':') + fprintf(stderr, " %s", strerror(saved_errno)); + fputc('\n', stderr); exit(1); }