diff --git a/Libraries/LibC/signal.cpp b/Libraries/LibC/signal.cpp index be7d26a5a2..04d51406ba 100644 --- a/Libraries/LibC/signal.cpp +++ b/Libraries/LibC/signal.cpp @@ -30,6 +30,7 @@ #include #include #include +#include #include extern "C" { @@ -186,4 +187,53 @@ int sigsuspend(const sigset_t*) dbgprintf("FIXME: Implement sigsuspend()\n"); ASSERT_NOT_REACHED(); } + +static const char* signal_names[] = { + "INVAL", + "HUP", + "INT", + "QUIT", + "ILL", + "TRAP", + "ABRT", + "BUS", + "FPE", + "KILL", + "USR1", + "SEGV", + "USR2", + "PIPE", + "ALRM", + "TERM", + "STKFLT", + "CHLD", + "CONT", + "STOP", + "TSTP", + "TTIN", + "TTOU", + "URG", + "XCPU", + "XFSZ", + "VTALRM", + "PROF", + "WINCH", + "IO", + "INFO", + "SYS", +}; + +static_assert(sizeof(signal_names) == sizeof(const char*) * 32); + +int getsignalbyname(const char* name) +{ + ASSERT(name); + for (size_t i = 0; i < NSIG; ++i) { + auto* signal_name = signal_names[i]; + if (!strcmp(signal_name, name)) + return i; + } + errno = EINVAL; + return -1; +} } diff --git a/Libraries/LibC/signal.h b/Libraries/LibC/signal.h index 02a617920b..5131169116 100644 --- a/Libraries/LibC/signal.h +++ b/Libraries/LibC/signal.h @@ -75,6 +75,7 @@ int sigprocmask(int how, const sigset_t* set, sigset_t* old_set); int sigpending(sigset_t*); int sigsuspend(const sigset_t*); int raise(int sig); +int getsignalbyname(const char*); extern const char* sys_siglist[NSIG]; diff --git a/Userland/kill.cpp b/Userland/kill.cpp index 7858625d4f..76eeb4e891 100644 --- a/Userland/kill.cpp +++ b/Userland/kill.cpp @@ -39,55 +39,6 @@ static void print_usage_and_exit() exit(1); } -static const char* signal_names[] = { - "INVAL", - "HUP", - "INT", - "QUIT", - "ILL", - "TRAP", - "ABRT", - "BUS", - "FPE", - "KILL", - "USR1", - "SEGV", - "USR2", - "PIPE", - "ALRM", - "TERM", - "STKFLT", - "CHLD", - "CONT", - "STOP", - "TSTP", - "TTIN", - "TTOU", - "URG", - "XCPU", - "XFSZ", - "VTALRM", - "PROF", - "WINCH", - "IO", - "INFO", - "SYS" -}; - -static_assert(sizeof(signal_names) == sizeof(const char*) * 32); - -int getsignalbyname(const char* name) -{ - ASSERT(name); - for (size_t i = 0; i < NSIG; ++i) { - auto* signal_name = signal_names[i]; - if (!strcmp(signal_name, name)) - return i; - } - errno = EINVAL; - return -1; -} - int main(int argc, char** argv) { if (pledge("stdio proc", nullptr) < 0) {