1 /* $NetBSD: sig.c,v 1.14 2009/02/18 15:04:40 christos Exp $ */
4 * Copyright (c) 1992, 1993
5 * The Regents of the University of California. All rights reserved.
7 * This code is derived from software contributed to Berkeley by
8 * Christos Zoulas of Cornell University.
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
18 * 3. Neither the name of the University nor the names of its contributors
19 * may be used to endorse or promote products derived from this software
20 * without specific prior written permission.
22 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
36 #if !defined(lint) && !defined(SCCSID)
38 static char sccsid
[] = "@(#)sig.c 8.1 (Berkeley) 6/4/93";
40 __RCSID("$NetBSD: sig.c,v 1.14 2009/02/18 15:04:40 christos Exp $");
42 #endif /* not lint && not SCCSID */
45 * sig.c: Signal handling stuff.
46 * our policy is to trap all signals, set a good state
47 * and pass the ball to our caller.
52 private EditLine
*sel
= NULL
;
54 private const int sighdl
[] = {
61 private void sig_handler(int);
64 * This is the handler called for all signals
65 * XXX: we cannot pass any data so we just store the old editline
66 * state in a private variable
69 sig_handler(int signo
)
74 (void) sigemptyset(&nset
);
75 (void) sigaddset(&nset
, signo
);
76 (void) sigprocmask(SIG_BLOCK
, &nset
, &oset
);
78 sel
->el_signal
->sig_no
= signo
;
83 if (ed_redisplay(sel
, 0) == CC_REFRESH
)
97 for (i
= 0; sighdl
[i
] != -1; i
++)
98 if (signo
== sighdl
[i
])
101 (void) sigaction(signo
, &sel
->el_signal
->sig_action
[i
], NULL
);
102 sel
->el_signal
->sig_action
[i
].sa_handler
= SIG_ERR
;
103 sel
->el_signal
->sig_action
[i
].sa_flags
= 0;
104 sigemptyset(&sel
->el_signal
->sig_action
[i
].sa_mask
);
105 (void) sigprocmask(SIG_SETMASK
, &oset
, NULL
);
106 (void) kill(0, signo
);
111 * Initialize all signal stuff
114 sig_init(EditLine
*el
)
117 sigset_t
*nset
, oset
;
119 el
->el_signal
= el_malloc(sizeof(*el
->el_signal
));
120 if (el
->el_signal
== NULL
)
123 nset
= &el
->el_signal
->sig_set
;
124 (void) sigemptyset(nset
);
125 #define _DO(a) (void) sigaddset(nset, a);
128 (void) sigprocmask(SIG_BLOCK
, nset
, &oset
);
130 for (i
= 0; sighdl
[i
] != -1; i
++) {
131 el
->el_signal
->sig_action
[i
].sa_handler
= SIG_ERR
;
132 el
->el_signal
->sig_action
[i
].sa_flags
= 0;
133 sigemptyset(&el
->el_signal
->sig_action
[i
].sa_mask
);
136 (void) sigprocmask(SIG_SETMASK
, &oset
, NULL
);
143 * Clear all signal stuff
146 sig_end(EditLine
*el
)
149 el_free((ptr_t
) el
->el_signal
);
150 el
->el_signal
= NULL
;
155 * set all the signal handlers
158 sig_set(EditLine
*el
)
162 struct sigaction osa
, nsa
;
164 nsa
.sa_handler
= sig_handler
;
166 sigemptyset(&nsa
.sa_mask
);
168 (void) sigprocmask(SIG_BLOCK
, &el
->el_signal
->sig_set
, &oset
);
170 for (i
= 0; sighdl
[i
] != -1; i
++) {
171 /* This could happen if we get interrupted */
172 if (sigaction(sighdl
[i
], &nsa
, &osa
) != -1 &&
173 osa
.sa_handler
!= sig_handler
)
174 el
->el_signal
->sig_action
[i
] = osa
;
177 (void) sigprocmask(SIG_SETMASK
, &oset
, NULL
);
182 * clear all the signal handlers
185 sig_clr(EditLine
*el
)
190 (void) sigprocmask(SIG_BLOCK
, &el
->el_signal
->sig_set
, &oset
);
192 for (i
= 0; sighdl
[i
] != -1; i
++)
193 if (el
->el_signal
->sig_action
[i
].sa_handler
!= SIG_ERR
)
194 (void)sigaction(sighdl
[i
],
195 &el
->el_signal
->sig_action
[i
], NULL
);
197 sel
= NULL
; /* we are going to die if the handler is
199 (void)sigprocmask(SIG_SETMASK
, &oset
, NULL
);