diff options
author | Denis Vlasenko <vda.linux@googlemail.com> | 2006-09-27 14:19:16 +0000 |
---|---|---|
committer | Denis Vlasenko <vda.linux@googlemail.com> | 2006-09-27 14:19:16 +0000 |
commit | a77947f5bb9ef38b0f1fc6a2a5b500fa6ade601e (patch) | |
tree | 3ad369f8468a397c6731ccd5c1631e1bc33612d6 | |
parent | be905d550c96da8c75d697842ba4169a62d05190 (diff) | |
download | busybox-w32-a77947f5bb9ef38b0f1fc6a2a5b500fa6ade601e.tar.gz busybox-w32-a77947f5bb9ef38b0f1fc6a2a5b500fa6ade601e.tar.bz2 busybox-w32-a77947f5bb9ef38b0f1fc6a2a5b500fa6ade601e.zip |
kill: fix bugs (kill -l output was horrible), fix style, constify data
-rw-r--r-- | include/libbb.h | 4 | ||||
-rw-r--r-- | libbb/u_signal_names.c | 13 | ||||
-rw-r--r-- | procps/kill.c | 111 |
3 files changed, 64 insertions, 64 deletions
diff --git a/include/libbb.h b/include/libbb.h index 2a5b38144..05927f1de 100644 --- a/include/libbb.h +++ b/include/libbb.h | |||
@@ -357,8 +357,8 @@ char *dirname (char *path); | |||
357 | 357 | ||
358 | int bb_make_directory (char *path, long mode, int flags); | 358 | int bb_make_directory (char *path, long mode, int flags); |
359 | 359 | ||
360 | int get_signum(char *name); | 360 | int get_signum(const char *name); |
361 | char *get_signame(int number); | 361 | const char *get_signame(int number); |
362 | 362 | ||
363 | char *bb_simplify_path(const char *path); | 363 | char *bb_simplify_path(const char *path); |
364 | 364 | ||
diff --git a/libbb/u_signal_names.c b/libbb/u_signal_names.c index b9afc6ff1..3f8c04c35 100644 --- a/libbb/u_signal_names.c +++ b/libbb/u_signal_names.c | |||
@@ -9,8 +9,8 @@ | |||
9 | 9 | ||
10 | #include "libbb.h" | 10 | #include "libbb.h" |
11 | 11 | ||
12 | static struct signal_name { | 12 | static const struct signal_name { |
13 | char *name; | 13 | char name[5]; |
14 | int number; | 14 | int number; |
15 | } signals[] = { | 15 | } signals[] = { |
16 | // SUSv3 says kill must support these, and specifies the numerical values, | 16 | // SUSv3 says kill must support these, and specifies the numerical values, |
@@ -26,7 +26,7 @@ static struct signal_name { | |||
26 | 26 | ||
27 | // Convert signal name to number. | 27 | // Convert signal name to number. |
28 | 28 | ||
29 | int get_signum(char *name) | 29 | int get_signum(const char *name) |
30 | { | 30 | { |
31 | int i; | 31 | int i; |
32 | 32 | ||
@@ -42,18 +42,17 @@ int get_signum(char *name) | |||
42 | 42 | ||
43 | // Convert signal number to name | 43 | // Convert signal number to name |
44 | 44 | ||
45 | char *get_signame(int number) | 45 | const char *get_signame(int number) |
46 | { | 46 | { |
47 | int i; | 47 | int i; |
48 | static char buf[8]; | 48 | static char buf[8]; |
49 | 49 | ||
50 | itoa_to_buf(number, buf, 8); | ||
51 | for (i=0; i < sizeof(signals) / sizeof(struct signal_name); i++) { | 50 | for (i=0; i < sizeof(signals) / sizeof(struct signal_name); i++) { |
52 | if (number == signals[i].number) { | 51 | if (number == signals[i].number) { |
53 | sprintf("SIG%s", signals[i].name); | 52 | return signals[i].name; |
54 | break; | ||
55 | } | 53 | } |
56 | } | 54 | } |
57 | 55 | ||
56 | itoa_to_buf(number, buf, 8); | ||
58 | return buf; | 57 | return buf; |
59 | } | 58 | } |
diff --git a/procps/kill.c b/procps/kill.c index b7a2985c8..654467ac1 100644 --- a/procps/kill.c +++ b/procps/kill.c | |||
@@ -12,118 +12,119 @@ | |||
12 | 12 | ||
13 | int kill_main(int argc, char **argv) | 13 | int kill_main(int argc, char **argv) |
14 | { | 14 | { |
15 | int killall, signo = SIGTERM, errors = 0, quiet=0; | 15 | char *arg; |
16 | int killall, signo = SIGTERM, errors = 0, quiet = 0; | ||
16 | 17 | ||
17 | killall = (ENABLE_KILLALL && bb_applet_name[4]=='a') ? 1 : 0; | 18 | killall = (ENABLE_KILLALL && bb_applet_name[4]=='a') ? 1 : 0; |
18 | 19 | ||
19 | /* Parse any options */ | 20 | /* Parse any options */ |
20 | if (argc < 2) | 21 | argc--; |
22 | arg = *++argv; | ||
23 | if (argc<1) | ||
21 | bb_show_usage(); | 24 | bb_show_usage(); |
22 | 25 | ||
23 | if(argv[1][0] != '-'){ | 26 | if (arg[0]!='-') { |
24 | argv++; | ||
25 | argc--; | ||
26 | goto do_it_now; | 27 | goto do_it_now; |
27 | } | 28 | } |
28 | 29 | ||
29 | /* The -l option, which prints out signal names. */ | 30 | /* The -l option, which prints out signal names. */ |
30 | if(argv[1][1]=='l' && argv[1][2]=='\0'){ | 31 | if (arg[1]=='l' && arg[2]=='\0') { |
31 | if(argc==2) { | 32 | const char *name; |
33 | if (argc==1) { | ||
32 | /* Print the whole signal list */ | 34 | /* Print the whole signal list */ |
33 | int col = 0; | 35 | int col = 0; |
34 | 36 | for (signo = 1; signo<32; signo++) { | |
35 | for(signo = 0;;) { | 37 | name = get_signame(signo); |
36 | char *name = get_signame(++signo); | 38 | if (isdigit(name[0])) continue; |
37 | if (isdigit(*name)) break; | 39 | if (col > 66) { |
38 | 40 | puts(""); | |
39 | if (col > 60) { | ||
40 | printf("\n"); | ||
41 | col = 0; | 41 | col = 0; |
42 | } | 42 | } |
43 | col += printf("%2d) %-16s", signo, name); | 43 | col += printf("%2d) %-6s", signo, name); |
44 | } | 44 | } |
45 | printf("\n"); | 45 | puts(""); |
46 | } else { | 46 | } else { /* -l <sig list> */ |
47 | for(argv++; *argv; argv++) { | 47 | while ((arg = *++argv)!=NULL) { |
48 | char *name; | 48 | if (isdigit(arg[0])) { |
49 | 49 | signo = atoi(arg); | |
50 | if (isdigit(**argv)) name = get_signame(atoi(*argv)); | 50 | name = get_signame(signo); |
51 | else { | 51 | } else { |
52 | int temp = get_signum(*argv); | 52 | signo = get_signum(arg); |
53 | if (temp<0) | 53 | if (signo<0) |
54 | bb_error_msg_and_die("unknown signal %s", *argv); | 54 | bb_error_msg_and_die("unknown signal '%s'", arg); |
55 | name = get_signame(temp); | 55 | name = get_signame(signo); |
56 | } | 56 | } |
57 | puts(name); | 57 | printf("%2d) %s\n", signo, name); |
58 | } | 58 | } |
59 | } | 59 | } |
60 | /* If they specified -l, were all done */ | 60 | /* If they specified -l, we are all done */ |
61 | return EXIT_SUCCESS; | 61 | return EXIT_SUCCESS; |
62 | } | 62 | } |
63 | 63 | ||
64 | /* The -q quiet option */ | 64 | /* The -q quiet option */ |
65 | if(killall && argv[1][1]=='q' && argv[1][2]=='\0'){ | 65 | if (killall && arg[1]=='q' && arg[2]=='\0') { |
66 | quiet++; | 66 | quiet = 1; |
67 | argv++; | 67 | arg = *++argv; |
68 | argc--; | 68 | argc--; |
69 | if(argc<2 || argv[1][0] != '-'){ | 69 | if (argc<1) bb_show_usage(); |
70 | goto do_it_now; | 70 | if (arg[0]!='-') goto do_it_now; |
71 | } | ||
72 | } | 71 | } |
73 | 72 | ||
74 | if(0>(signo = get_signum(argv[1]+1))) | 73 | /* -SIG */ |
75 | bb_error_msg_and_die( "bad signal name '%s'", argv[1]+1); | 74 | signo = get_signum(&arg[1]); |
76 | argv+=2; | 75 | if (signo<0) |
77 | argc-=2; | 76 | bb_error_msg_and_die("bad signal name '%s'", &arg[1]); |
77 | arg = *++argv; | ||
78 | argc--; | ||
78 | 79 | ||
79 | do_it_now: | 80 | do_it_now: |
80 | 81 | ||
81 | /* Pid or name required */ | 82 | /* Pid or name required */ |
82 | if (argc <= 0) | 83 | if (argc<1) |
83 | bb_show_usage(); | 84 | bb_show_usage(); |
84 | 85 | ||
85 | if (!killall) { | 86 | if (!killall) { |
86 | /* Looks like they want to do a kill. Do that */ | 87 | /* Looks like they want to do a kill. Do that */ |
87 | while (--argc >= 0) { | 88 | while (arg) { |
88 | int pid; | 89 | int pid; |
89 | 90 | ||
90 | if (!isdigit(**argv) && **argv != '-') | 91 | if (!isdigit(arg[0]) && arg[0]!='-') |
91 | bb_error_msg_and_die( "Bad PID '%s'", *argv); | 92 | bb_error_msg_and_die("bad pid '%s'", arg); |
92 | pid = strtol(*argv, NULL, 0); | 93 | pid = strtol(arg, NULL, 0); |
93 | if (kill(pid, signo) != 0) { | 94 | if (kill(pid, signo)!=0) { |
94 | bb_perror_msg( "Could not kill pid '%d'", pid); | 95 | bb_perror_msg("cannot kill pid %d", pid); |
95 | errors++; | 96 | errors++; |
96 | } | 97 | } |
97 | argv++; | 98 | arg = *++argv; |
98 | } | 99 | } |
99 | 100 | ||
100 | } else { | 101 | } else { |
101 | pid_t myPid=getpid(); | 102 | pid_t myPid = getpid(); |
102 | 103 | ||
103 | /* Looks like they want to do a killall. Do that */ | 104 | /* Looks like they want to do a killall. Do that */ |
104 | while (--argc >= 0) { | 105 | while (arg) { |
105 | long* pidList; | 106 | long* pidList; |
106 | 107 | ||
107 | pidList = find_pid_by_name(*argv); | 108 | pidList = find_pid_by_name(arg); |
108 | if (!pidList || *pidList<=0) { | 109 | if (!pidList || *pidList<=0) { |
109 | errors++; | 110 | errors++; |
110 | if (quiet==0) | 111 | if (quiet==0) |
111 | bb_error_msg( "%s: no process killed", *argv); | 112 | bb_error_msg("%s: no process killed", arg); |
112 | } else { | 113 | } else { |
113 | long *pl; | 114 | long *pl; |
114 | 115 | ||
115 | for(pl = pidList; *pl !=0 ; pl++) { | 116 | for (pl = pidList; *pl!=0 ; pl++) { |
116 | if (*pl==myPid) | 117 | if (*pl==myPid) |
117 | continue; | 118 | continue; |
118 | if (kill(*pl, signo) != 0) { | 119 | if (kill(*pl, signo)!=0) { |
119 | errors++; | 120 | errors++; |
120 | if (quiet==0) | 121 | if (!quiet) |
121 | bb_perror_msg( "Could not kill pid '%ld'", *pl); | 122 | bb_perror_msg("cannot kill pid %ld", *pl); |
122 | } | 123 | } |
123 | } | 124 | } |
124 | } | 125 | } |
125 | free(pidList); | 126 | free(pidList); |
126 | argv++; | 127 | arg = *++argv; |
127 | } | 128 | } |
128 | } | 129 | } |
129 | 130 | ||