X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/164be8e5e8b40ce4572281be26d423a9c9d595f3..e56972cabb200aa655374e95bbbbcf18d0ddabe0:/sbr/pidstatus.c diff --git a/sbr/pidstatus.c b/sbr/pidstatus.c index 7da78ace..82f2d119 100644 --- a/sbr/pidstatus.c +++ b/sbr/pidstatus.c @@ -9,11 +9,6 @@ #include -/* - * auto-generated header - */ -#include - #ifndef WTERMSIG # define WTERMSIG(s) ((int)((s) & 0x7F)) #endif @@ -22,10 +17,19 @@ # define WCOREDUMP(s) ((s) & 0x80) #endif +/* + * Return 0 if the command exited with an exit code of zero, a nonzero code + * otherwise. + * + * Print out an appropriate status message we didn't exit with an exit code + * of zero. + */ + int pidstatus (int status, FILE *fp, char *cp) { int signum; + char *signame; /* * I have no idea what this is for (rc) @@ -42,6 +46,7 @@ pidstatus (int status, FILE *fp, char *cp) fprintf (fp, "%s: ", cp); fprintf (fp, "exit %d\n", signum); } + return signum; } else if (WIFSIGNALED(status)) { /* If child process terminated due to receipt of a signal */ signum = WTERMSIG(status); @@ -49,8 +54,12 @@ pidstatus (int status, FILE *fp, char *cp) if (cp) fprintf (fp, "%s: ", cp); fprintf (fp, "signal %d", signum); - if (signum >= 0 && signum < sizeof(sigmsg) && sigmsg[signum] != NULL) - fprintf (fp, " (%s%s)\n", sigmsg[signum], + errno = 0; + signame = strsignal(signum); + if (errno) + signame = NULL; + if (signame) + fprintf (fp, " (%s%s)\n", signame, WCOREDUMP(status) ? ", core dumped" : ""); else fprintf (fp, "%s\n", WCOREDUMP(status) ? " (core dumped)" : "");