diff options
author | Roland McGrath <roland@gnu.org> | 1995-02-18 01:27:10 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 1995-02-18 01:27:10 +0000 |
commit | 28f540f45bbacd939bfd07f213bcad2bf730b1bf (patch) | |
tree | 15f07c4c43d635959c6afee96bde71fb1b3614ee /signal/tst-signal.c | |
download | glibc-28f540f45bbacd939bfd07f213bcad2bf730b1bf.zip glibc-28f540f45bbacd939bfd07f213bcad2bf730b1bf.tar.gz glibc-28f540f45bbacd939bfd07f213bcad2bf730b1bf.tar.bz2 |
initial import
Diffstat (limited to 'signal/tst-signal.c')
-rw-r--r-- | signal/tst-signal.c | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/signal/tst-signal.c b/signal/tst-signal.c new file mode 100644 index 0000000..f622842 --- /dev/null +++ b/signal/tst-signal.c @@ -0,0 +1,44 @@ +#include <ansidecl.h> +#include <signal.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +int win = 0; + +void +DEFUN(handler, (sig), int sig) +{ + printf("Received signal %d (%s).\n", sig, strsignal(sig)); + win = 1; +} + +int +DEFUN_VOID(main) +{ + if (signal(SIGTERM, handler) == SIG_ERR) + { + perror("signal: SIGTERM"); + exit(EXIT_FAILURE); + } + + puts("Set handler."); + + printf("Sending myself signal %d.\n", SIGTERM); + fflush(stdout); + + if (raise(SIGTERM) < 0) + { + perror("raise: SIGTERM"); + exit(EXIT_FAILURE); + } + + if (!win) + { + puts("Didn't get any signal. Test FAILED!"); + exit(EXIT_FAILURE); + } + + puts("Got a signal. Test succeeded."); + exit(EXIT_SUCCESS); +} |