mirror of
https://github.com/sheumann/hush.git
synced 2024-12-22 14:30:31 +00:00
Make signal table a bit smaller
get_signum 136 151 +15 signals 224 192 -32
This commit is contained in:
parent
5f934b0785
commit
c689fcfdb0
@ -11,10 +11,9 @@
|
||||
|
||||
#define KILL_MAX_SIG 32
|
||||
|
||||
static const char signals[KILL_MAX_SIG][7] = {
|
||||
static const char signals[KILL_MAX_SIG][6] = {
|
||||
// SUSv3 says kill must support these, and specifies the numerical values,
|
||||
// http://www.opengroup.org/onlinepubs/009695399/utilities/kill.html
|
||||
// TODO: "[SIG]EXIT" shouldn't work for kill, right?
|
||||
// {0, "EXIT"}, {1, "HUP"}, {2, "INT"}, {3, "QUIT"},
|
||||
// {6, "ABRT"}, {9, "KILL"}, {14, "ALRM"}, {15, "TERM"}
|
||||
// And Posix adds the following:
|
||||
@ -25,6 +24,8 @@ static const char signals[KILL_MAX_SIG][7] = {
|
||||
|
||||
/* Believe it or not, but some arches have more than 32 SIGs!
|
||||
* HPPA: SIGSTKFLT == 36. We don't include those. */
|
||||
|
||||
/* NB: longest (6-char) names are NOT nul-terminated */
|
||||
[0] = "EXIT",
|
||||
#if defined SIGHUP && SIGHUP < KILL_MAX_SIG
|
||||
[SIGHUP ] = "HUP",
|
||||
@ -132,8 +133,10 @@ int get_signum(const char *name)
|
||||
return i;
|
||||
if (strncasecmp(name, "SIG", 3) == 0)
|
||||
name += 3;
|
||||
if (strlen(name) > 6)
|
||||
return -1;
|
||||
for (i = 0; i < ARRAY_SIZE(signals); i++)
|
||||
if (strcasecmp(name, signals[i]) == 0)
|
||||
if (strncasecmp(name, signals[i], 6) == 0)
|
||||
return i;
|
||||
|
||||
#if ENABLE_DESKTOP && (defined(SIGIOT) || defined(SIGIO))
|
||||
|
Loading…
Reference in New Issue
Block a user