Implement XSI extensions -signal_name and -signal_number for kill(1)

This commit is contained in:
sin 2014-11-11 15:35:27 +00:00
parent 237673302d
commit a0e9050925

48
kill.c
View File

@ -1,5 +1,6 @@
/* See LICENSE file for copyright and license details. */ /* See LICENSE file for copyright and license details. */
#include <sys/wait.h> #include <sys/wait.h>
#include <ctype.h>
#include <errno.h> #include <errno.h>
#include <signal.h> #include <signal.h>
#include <stdbool.h> #include <stdbool.h>
@ -47,7 +48,25 @@ main(int argc, char *argv[])
argc--; argc--;
argv++; argv++;
if (strcmp(argv[0], "-l") == 0) { if (strcmp(argv[0], "--") == 0) {
argc--;
argv++;
if (argc == 0)
usage();
} else if (argv[0][0] == '-' && isdigit(argv[0][1])) {
/* handle XSI extension -signal_number */
errno = 0;
sig = strtol(&argv[0][1], &end, 0);
if (*end != '\0' || errno != 0)
eprintf("%d: bad signal number\n", sig);
for (i = 0; i < LEN(sigs); i++)
if (sigs[i].sig == sig || sig == 0)
break;
if (i == LEN(sigs))
eprintf("%d: bad signal number\n", sig);
argc--;
argv++;
} else if (strcmp(argv[0], "-l") == 0) {
argc--; argc--;
argv++; argv++;
if (argc == 0) { if (argc == 0) {
@ -70,30 +89,31 @@ main(int argc, char *argv[])
} }
} }
exit(0); exit(0);
} else if (strcmp(argv[0], "-s") == 0) { } else {
argc--; if (strcmp(argv[0], "-s") == 0) {
argv++; argc--;
if (argc == 0) argv++;
usage(); if (argc == 0)
if (strcmp(argv[0], "0") == 0) { usage();
name = argv[0];
} else {
/* assume XSI extension -signal_name */
name = &argv[0][1];
}
if (strcmp(name, "0") == 0) {
sig = 0; sig = 0;
} else { } else {
for (i = 0; i < LEN(sigs); i++) { for (i = 0; i < LEN(sigs); i++) {
if (strcasecmp(sigs[i].name, argv[0]) == 0) { if (strcasecmp(sigs[i].name, name) == 0) {
sig = sigs[i].sig; sig = sigs[i].sig;
break; break;
} }
} }
if (i == LEN(sigs)) if (i == LEN(sigs))
eprintf("%s: bad signal number\n", argv[0]); eprintf("%s: bad signal number\n", name);
} }
argc--; argc--;
argv++; argv++;
} else if (strcmp(argv[0], "--") == 0) {
argc--;
argv++;
if (argc == 0)
usage();
} }
if (argc == 0) if (argc == 0)