summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--games/larn/signal.c82
1 files changed, 7 insertions, 75 deletions
diff --git a/games/larn/signal.c b/games/larn/signal.c
index 93773147151..3b4e2f396dd 100644
--- a/games/larn/signal.c
+++ b/games/larn/signal.c
@@ -1,5 +1,5 @@
#ifndef lint
-static char rcsid[] = "$NetBSD: signal.c,v 1.4 1995/04/24 12:24:12 cgd Exp $";
+static char rcsid[] = "$NetBSD: signal.c,v 1.5 1995/12/21 11:27:51 mycroft Exp $";
#endif /* not lint */
#include <signal.h>
@@ -55,88 +55,20 @@ tstop() /* control Y */
* subroutine to issue the needed signal traps called from main()
*/
static void sigpanic();
-static void sigill() { sigpanic(SIGILL); }
-static void sigtrap() { sigpanic(SIGTRAP); }
-static void sigiot() { sigpanic(SIGIOT); }
-static void sigemt() { sigpanic(SIGEMT); }
-static void sigfpe() { sigpanic(SIGFPE); }
-static void sigbus() { sigpanic(SIGBUS); }
-static void sigsegv() { sigpanic(SIGSEGV); }
-static void sigsys() { sigpanic(SIGSYS); }
-static void sigpipe() { sigpanic(SIGPIPE); }
-static void sigterm() { sigpanic(SIGTERM); }
sigsetup()
{
signal(SIGQUIT, cntlc); signal(SIGINT, cntlc);
signal(SIGKILL, SIG_IGN); signal(SIGHUP, sgam);
- signal(SIGILL, sigill); signal(SIGTRAP, sigtrap);
- signal(SIGIOT, sigiot); signal(SIGEMT, sigemt);
- signal(SIGFPE, sigfpe); signal(SIGBUS, sigbus);
- signal(SIGSEGV, sigsegv); signal(SIGSYS, sigsys);
- signal(SIGPIPE, sigpipe); signal(SIGTERM, sigterm);
+ signal(SIGILL, sigpanic); signal(SIGTRAP, sigpanic);
+ signal(SIGIOT, sigpanic); signal(SIGEMT, sigpanic);
+ signal(SIGFPE, sigpanic); signal(SIGBUS, sigpanic);
+ signal(SIGSEGV, sigpanic); signal(SIGSYS, sigpanic);
+ signal(SIGPIPE, sigpanic); signal(SIGTERM, sigpanic);
#ifdef SIGTSTP
signal(SIGTSTP,tstop); signal(SIGSTOP,tstop);
#endif SIGTSTP
}
-#ifdef BSD /* for BSD UNIX? */
-
-static char *signame[NSIG] = { "",
-"SIGHUP", /* 1 hangup */
-"SIGINT", /* 2 interrupt */
-"SIGQUIT", /* 3 quit */
-"SIGILL", /* 4 illegal instruction (not reset when caught) */
-"SIGTRAP", /* 5 trace trap (not reset when caught) */
-"SIGIOT", /* 6 IOT instruction */
-"SIGEMT", /* 7 EMT instruction */
-"SIGFPE", /* 8 floating point exception */
-"SIGKILL", /* 9 kill (cannot be caught or ignored) */
-"SIGBUS", /* 10 bus error */
-"SIGSEGV", /* 11 segmentation violation */
-"SIGSYS", /* 12 bad argument to system call */
-"SIGPIPE", /* 13 write on a pipe with no one to read it */
-"SIGALRM", /* 14 alarm clock */
-"SIGTERM", /* 15 software termination signal from kill */
-"SIGURG", /* 16 urgent condition on IO channel */
-"SIGSTOP", /* 17 sendable stop signal not from tty */
-"SIGTSTP", /* 18 stop signal from tty */
-"SIGCONT", /* 19 continue a stopped process */
-"SIGCHLD", /* 20 to parent on child stop or exit */
-"SIGTTIN", /* 21 to readers pgrp upon background tty read */
-"SIGTTOU", /* 22 like TTIN for output if (tp->t_local&LTOSTOP) */
-"SIGIO", /* 23 input/output possible signal */
-"SIGXCPU", /* 24 exceeded CPU time limit */
-"SIGXFSZ", /* 25 exceeded file size limit */
-"SIGVTALRM",/* 26 virtual time alarm */
-"SIGPROF", /* 27 profiling time alarm */
-"","","","" };
-
-#else BSD /* for system V? */
-
-static char *signame[NSIG] = { "",
-"SIGHUP", /* 1 hangup */
-"SIGINT", /* 2 interrupt */
-"SIGQUIT", /* 3 quit */
-"SIGILL", /* 4 illegal instruction (not reset when caught) */
-"SIGTRAP", /* 5 trace trap (not reset when caught) */
-"SIGIOT", /* 6 IOT instruction */
-"SIGEMT", /* 7 EMT instruction */
-"SIGFPE", /* 8 floating point exception */
-"SIGKILL", /* 9 kill (cannot be caught or ignored) */
-"SIGBUS", /* 10 bus error */
-"SIGSEGV", /* 11 segmentation violation */
-"SIGSYS", /* 12 bad argument to system call */
-"SIGPIPE", /* 13 write on a pipe with no one to read it */
-"SIGALRM", /* 14 alarm clock */
-"SIGTERM", /* 15 software termination signal from kill */
-"SIGUSR1", /* 16 user defines signal 1 */
-"SIGUSR2", /* 17 user defines signal 2 */
-"SIGCLD", /* 18 child death */
-"SIGPWR", /* 19 power fail */
-"","","","","","","","","","","","" };
-
-#endif BSD
-
/*
* routine to process a fatal error signal
*/
@@ -146,7 +78,7 @@ sigpanic(sig)
{
char buf[128];
signal(sig,SIG_DFL);
- sprintf(buf,"\nLarn - Panic! Signal %d received [%s]",sig,signame[sig]);
+ sprintf(buf,"\nLarn - Panic! Signal %d received [SIG%s]",sig,sys_signame[sig]);
write(2,buf,strlen(buf)); sleep(2);
sncbr();
savegame(savefilename);