[PATCH 1/2] tests: add signal2name function to libtests
Fei Jie
feij.fnst at cn.fujitsu.com
Tue May 31 06:13:57 UTC 2016
* tests/tests.h (signal2name): New prototype.
* tests/signal2name.c: New file.
* tests/Makefile.am (libtests_a_SOURCES): Add it.
---
tests/Makefile.am | 1 +
tests/signal2name.c | 125 ++++++++++++++++++++++++++++++++++++++++++++++++++++
tests/tests.h | 3 ++
3 files changed, 129 insertions(+)
create mode 100644 tests/signal2name.c
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 9eba306..ac527ec 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -51,6 +51,7 @@ libtests_a_SOURCES = \
print_quoted_string.c \
printflags.c \
printxval.c \
+ signal2name.c \
tail_alloc.c \
tests.h \
tprintf.c \
diff --git a/tests/signal2name.c b/tests/signal2name.c
new file mode 100644
index 0000000..906e821
--- /dev/null
+++ b/tests/signal2name.c
@@ -0,0 +1,125 @@
+#include "tests.h"
+#include <signal.h>
+
+#define CASE(x) case x: return #x
+
+const char *
+signal2name(int sig)
+{
+ switch (sig) {
+#ifdef SIGALRM
+ CASE(SIGALRM);
+#endif
+#ifdef SIGBUS
+ CASE(SIGBUS);
+#endif
+#ifdef SIGCHLD
+ CASE(SIGCHLD);
+#endif
+#ifdef SIGCONT
+ CASE(SIGCONT);
+#endif
+#ifdef SIGFPE
+ CASE(SIGFPE);
+#endif
+#ifdef SIGHUP
+ CASE(SIGHUP);
+#endif
+#ifdef SIGILL
+ CASE(SIGILL);
+#endif
+#ifdef SIGINT
+ CASE(SIGINT);
+#endif
+#ifdef SIGIO
+ CASE(SIGIO);
+#endif
+#ifdef SIGPIPE
+ CASE(SIGPIPE);
+#endif
+#ifdef SIGPROF
+ CASE(SIGPROF);
+#endif
+#ifdef SIGQUIT
+ CASE(SIGQUIT);
+#endif
+#ifdef SIGSEGV
+ CASE(SIGSEGV);
+#endif
+#ifdef SIGSYS
+ CASE(SIGSYS);
+#endif
+#ifdef SIGTERM
+ CASE(SIGTERM);
+#endif
+#ifdef SIGTRAP
+ CASE(SIGTRAP);
+#endif
+#ifdef SIGTSTP
+ CASE(SIGTSTP);
+#endif
+#ifdef SIGTTIN
+ CASE(SIGTTIN);
+#endif
+#ifdef SIGTTOU
+ CASE(SIGTTOU);
+#endif
+#ifdef SIGURG
+ CASE(SIGURG);
+#endif
+#ifdef SIGUSR1
+ CASE(SIGUSR1);
+#endif
+#ifdef SIGUSR2
+ CASE(SIGUSR2);
+#endif
+#ifdef SIGVTALRM
+ CASE(SIGVTALRM);
+#endif
+#ifdef SIGWINCH
+ CASE(SIGWINCH);
+#endif
+#ifdef SIGXCPU
+ CASE(SIGXCPU);
+#endif
+#ifdef SIGXFSZ
+ CASE(SIGXFSZ);
+#endif
+#if !defined MIPS
+# ifdef SIGABRT
+ CASE(SIGABRT);
+# endif
+#endif
+#if defined ALPHA || defined MIPS || defined SPARC
+# ifdef SIGEMT
+ CASE(SIGEMT);
+# endif
+#endif
+#ifdef ALPHA
+# ifdef SIGINFO
+ CASE(SIGINFO);
+# endif
+#endif
+#ifdef MIPS
+# ifdef SIGIOT
+ CASE(SIGIOT);
+# endif
+#endif
+#ifdef SPARC
+# ifdef SIGLOST
+ CASE(SIGLOST);
+# endif
+#endif
+#if !defined ALPHA && !defined SPARC
+# ifdef SIGPWR
+ CASE(SIGPWR);
+# endif
+#endif
+#if !defined ALPHA && !defined SPARC && !defined MIPS
+# ifdef SIGSTKFLT
+ CASE(SIGSTKFLT);
+# endif
+#endif
+ default: perror_msg_and_fail("unknown signal number %d", sig);
+ }
+}
diff --git a/tests/tests.h b/tests/tests.h
index 0205ea0..c140830 100644
--- a/tests/tests.h
+++ b/tests/tests.h
@@ -93,6 +93,9 @@ void check_overflowgid(const int);
/* Translate errno to its name. */
const char *errno2name(void);
+/* Translate signal number to its name. */
+const char *signal2name(int);
+
struct xlat;
/* Print flags in symbolic form according to xlat table. */
--
1.8.3.1
More information about the Strace-devel
mailing list