12419Sdlw /*
2*3560Sdlw char id_signal[] = "@(#)signal_.c 1.4";
32419Sdlw *
42419Sdlw * change the action for a specified signal
52419Sdlw *
62419Sdlw * calling sequence:
72419Sdlw * integer cursig, signal, savsig
82419Sdlw * external proc
92419Sdlw * cursig = signal(signum, proc, flag)
102419Sdlw * where:
112419Sdlw * 'cursig' will receive the current value of signal(2)
122419Sdlw * 'signum' must be in the range 0 <= signum <= 16
132419Sdlw *
142419Sdlw * If 'flag' is negative, 'proc' must be an external proceedure name.
152419Sdlw *
162419Sdlw * If 'flag' is 0 or positive, it will be passed to signal(2) as the
172419Sdlw * signal action flag. 0 resets the default action; 1 sets 'ignore'.
182419Sdlw * 'flag' may be the value returned from a previous call to signal.
192544Sdlw *
202544Sdlw * This routine arranges to trap user specified signals so that it can
212544Sdlw * pass the signum fortran style - by address. (boo)
222419Sdlw */
232419Sdlw
242419Sdlw #include "../libI77/f_errno.h"
252419Sdlw
26*3560Sdlw static int (*dispatch[17])();
272419Sdlw int (*signal())();
282544Sdlw int sig_trap();
292419Sdlw
signal_(sigp,procp,flag)302419Sdlw long signal_(sigp, procp, flag)
312419Sdlw long *sigp, *flag;
322419Sdlw int (*procp)();
332419Sdlw {
342545Sdlw int (*oldsig)();
352545Sdlw int (*oldispatch)();
362545Sdlw
372545Sdlw oldispatch = dispatch[*sigp];
382545Sdlw
392419Sdlw if (*sigp < 0 || *sigp > 16)
402419Sdlw return(-((long)(errno=F_ERARG)));
412419Sdlw
422419Sdlw if (*flag < 0) /* function address passed */
432544Sdlw {
442544Sdlw dispatch[*sigp] = procp;
452545Sdlw oldsig = signal((int)*sigp, sig_trap);
462544Sdlw }
472419Sdlw
482419Sdlw else /* integer value passed */
492545Sdlw oldsig = signal((int)*sigp, (int)*flag);
502545Sdlw
512545Sdlw if (oldsig == sig_trap)
522545Sdlw return((long)oldispatch);
532545Sdlw return((long)oldsig);
542419Sdlw }
552544Sdlw
sig_trap(sn)562544Sdlw sig_trap(sn)
572544Sdlw int sn;
582544Sdlw {
592544Sdlw long lsn = (long)sn;
602544Sdlw return((*dispatch[sn])(&lsn));
612544Sdlw }
62