Simplify logic in kill(1)
This commit is contained in:
parent
e4e47a617e
commit
f06ada4592
54
kill.c
54
kill.c
|
@ -37,7 +37,6 @@ int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
char *end;
|
char *end;
|
||||||
const char *name;
|
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
int sig = SIGTERM;
|
int sig = SIGTERM;
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
|
@ -48,20 +47,8 @@ main(int argc, char *argv[])
|
||||||
usage();
|
usage();
|
||||||
|
|
||||||
argc--, argv++;
|
argc--, argv++;
|
||||||
if (strcmp(argv[0], "--") == 0) {
|
if (strcmp(argv[0], "-l") == 0) {
|
||||||
argc--, argv++;
|
argc--, argv++;
|
||||||
} else if (argv[0][0] == '-' && isdigit(argv[0][1])) {
|
|
||||||
/* handle XSI extension -signum */
|
|
||||||
errno = 0;
|
|
||||||
sig = strtol(&argv[0][1], &end, 10);
|
|
||||||
if (*end != '\0' || errno != 0)
|
|
||||||
eprintf("%s: bad signal number\n", &argv[0][1]);
|
|
||||||
sig2name(sig);
|
|
||||||
argc--, argv++;
|
|
||||||
} else if (strcmp(argv[0], "-l") == 0) {
|
|
||||||
argc--, argv++;
|
|
||||||
if (argc > 0 && strcmp(argv[0], "--") == 0)
|
|
||||||
argc--, argv++;
|
|
||||||
if (argc == 0) {
|
if (argc == 0) {
|
||||||
for (i = 0; i < LEN(sigs); i++)
|
for (i = 0; i < LEN(sigs); i++)
|
||||||
puts(sigs[i].name);
|
puts(sigs[i].name);
|
||||||
|
@ -76,22 +63,33 @@ main(int argc, char *argv[])
|
||||||
sig = WTERMSIG(sig);
|
sig = WTERMSIG(sig);
|
||||||
puts(sig2name(sig));
|
puts(sig2name(sig));
|
||||||
exit(0);
|
exit(0);
|
||||||
} else {
|
|
||||||
if (strcmp(argv[0], "-s") == 0) {
|
|
||||||
argc--, argv++;
|
|
||||||
if (argc > 0 && strcmp(argv[0], "--") == 0)
|
|
||||||
argc--, argv++;
|
|
||||||
if (argc == 0)
|
|
||||||
usage();
|
|
||||||
name = argv[0];
|
|
||||||
} else {
|
|
||||||
/* assume XSI extension -signame */
|
|
||||||
name = &argv[0][1];
|
|
||||||
}
|
|
||||||
sig = strcmp(name, "0") == 0 ? 0 : name2sig(name);
|
|
||||||
argc--, argv++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (strcmp(argv[0], "-s") == 0) {
|
||||||
|
argc--, argv++;
|
||||||
|
if (argc == 0)
|
||||||
|
usage();
|
||||||
|
sig = strcmp(argv[0], "0") == 0 ? 0 : name2sig(argv[0]);
|
||||||
|
argc--, argv++;
|
||||||
|
} else if (argv[0][0] == '-') {
|
||||||
|
if (isdigit(argv[0][1])) {
|
||||||
|
/* handle XSI extension -signum */
|
||||||
|
errno = 0;
|
||||||
|
sig = strtol(&argv[0][1], &end, 10);
|
||||||
|
if (*end != '\0' || errno != 0)
|
||||||
|
eprintf("%s: bad signal number\n", &argv[0][1]);
|
||||||
|
sig2name(sig);
|
||||||
|
argc--, argv++;
|
||||||
|
} else if (argv[0][1] != '-') {
|
||||||
|
/* handle XSI extension -signame */
|
||||||
|
sig = strcmp(&argv[0][1], "0") == 0 ? 0 : name2sig(&argv[0][1]);
|
||||||
|
argc--, argv++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argc > 0 && strcmp(argv[0], "--") == 0)
|
||||||
|
argc--, argv++;
|
||||||
|
|
||||||
if (argc == 0)
|
if (argc == 0)
|
||||||
usage();
|
usage();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user