From: Denis Vlasenko Date: Sun, 6 May 2007 22:48:55 +0000 (-0000) Subject: kill: fix recent breakage of vda, also make code smaller by 21 bytes. X-Git-Tag: 1_6_0~86 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=02f47e9f8140e5b4e83f691df21a542f0651ab15;p=oweals%2Fbusybox.git kill: fix recent breakage of vda, also make code smaller by 21 bytes. --- diff --git a/procps/kill.c b/procps/kill.c index b3257492d..3ccbd30e4 100644 --- a/procps/kill.c +++ b/procps/kill.c @@ -1,6 +1,6 @@ /* vi: set sw=4 ts=4: */ /* - * Mini kill/killall implementation for busybox + * Mini kill/killall[5] implementation for busybox * * Copyright (C) 1995, 1996 by Bruce Perens . * Copyright (C) 1999-2004 by Erik Andersen @@ -30,10 +30,17 @@ int kill_main(int argc, char **argv) char *arg; pid_t pid; int signo = SIGTERM, errors = 0, quiet = 0; - const int killall = (ENABLE_KILLALL && argv[0][4] == 'a' - && (!ENABLE_KILLALL5 || argv[0][7] != '5')); - const int killall5 = (ENABLE_KILLALL5 && argv[0][4] == 'a' - && (!ENABLE_KILLALL || argv[0][7] == '5')); +#if !ENABLE_KILLALL && !ENABLE_KILLALL5 +#define killall 0 +#define killall5 0 +#else +/* How to determine who we are? find 3rd char from the end: + * kill, killall, killall5 + * ^i ^a ^l */ + const char char3 = argv[0][strlen(argv[0]) - 3]; +#define killall (ENABLE_KILLALL && char3 == 'a') +#define killall5 (ENABLE_KILLALL5 && char3 == 'l') +#endif /* Parse any options */ argc--;