BSD 4_3_Reno release
[unix-history] / usr / src / lib / libc / gen / signal.c
index 7c0710a..52c31b4 100644 (file)
@@ -1,36 +1,46 @@
 /*
 /*
- * Copyright (c) 1985 Regents of the University of California.
- * All rights reserved.  The Berkeley software License Agreement
- * specifies the terms and conditions for redistribution.
+ * Copyright (c) 1985, 1989 Regents of the University of California.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms are permitted
+ * provided that: (1) source distributions retain this entire copyright
+ * notice and comment, and (2) distributions including binaries display
+ * the following acknowledgement:  ``This product includes software
+ * developed by the University of California, Berkeley and its contributors''
+ * in the documentation or other materials provided with the distribution
+ * and in all advertising materials mentioning features or use of this
+ * software. Neither the name of the University nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  */
 
 #if defined(LIBC_SCCS) && !defined(lint)
  */
 
 #if defined(LIBC_SCCS) && !defined(lint)
-static char sccsid[] = "@(#)signal.c   5.2 (Berkeley) 3/9/86";
-#endif LIBC_SCCS and not lint
+static char sccsid[] = "@(#)signal.c   5.5 (Berkeley) 6/1/90";
+#endif /* LIBC_SCCS and not lint */
 
 /*
  * Almost backwards compatible signal.
  */
 #include <signal.h>
 
 
 /*
  * Almost backwards compatible signal.
  */
 #include <signal.h>
 
-int (*
-signal(s, a))()
-       int s, (*a)();
+sigset_t _sigintr;             /* shared with siginterrupt */
+
+sig_t
+signal(s, a)
+       int s;
+       sig_t a;
 {
 {
-       struct sigvec osv, sv;
-       static int mask[NSIG];
-       static int flags[NSIG];
+       struct sigaction sa, osa;
 
 
-       sv.sv_handler = a;
-       sv.sv_mask = mask[s];
-       sv.sv_flags = flags[s];
-       if (sigvec(s, &sv, &osv) < 0)
+       sa.sa_handler = a;
+       sigemptyset(&sa.sa_mask);
+       sa.sa_flags = 0;
+       if (!sigismember(&_sigintr, s))
+               sa.sa_flags |= SA_RESTART;
+       if (sigaction(s, &sa, &osa) < 0)
                return (BADSIG);
                return (BADSIG);
-       if (sv.sv_mask != osv.sv_mask || sv.sv_flags != osv.sv_flags) {
-               mask[s] = sv.sv_mask = osv.sv_mask;
-               flags[s] = sv.sv_flags = osv.sv_flags;
-               if (sigvec(s, &sv, 0) < 0)
-                       return (BADSIG);
-       }
-       return (osv.sv_handler);
+       return (osa.sa_handler);
 }
 }