help-bash
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Help-bash] How to trap SIGTERM?


From: Chet Ramey
Subject: Re: [Help-bash] How to trap SIGTERM?
Date: Sun, 21 Apr 2013 18:46:50 -0400
User-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:17.0) Gecko/20130328 Thunderbird/17.0.5

On 4/20/13 4:18 AM, Pierre Gaston wrote:

> $ for i in 2  15;do ./sigtest $i;done
> Child exit normally: 0
> Child exited with status: 15 and signal: 15
> 
> I'm not quite sure why the shell doesn't indicate that it was killed with INT.

It comes back to the Cracauer article Bob referenced.  See comments at the
end.

> The same happens with the EXIT trap:
> 
> #!/usr/bin/env bash
> trap "echo Booh!" EXIT
> sleep 5 
> 
> $ for i in 2  15;do ./sigtest $i;done
> booh!
> Child exit normally: 0
> booh!
> Child exited with status: 15 and signal: 15
> 
>  so the trap is indeed not affecting TERM.
> INT is not simply ignored (like QUIT is) because if I reset the trap, running:
> 
> #!/usr/bin/env bash
> trap "echo booh!" EXIT
> trap "echo INT;trap - INT;kill -INT $$" INT
> sleep 5
> 
> I get:
> 
> $ for i in 2  15;do ./sigtest $i;done
> INT
> booh!
> Child exited with status: 2 and signal: 2
> booh!
> Child exited with status: 15 and signal: 15
> 
> So resetting the trap seems to do what I would expect, the shell exits
> indicating that it has been killed with INT.
> 
> The shell is doing some strange handling, if I change the script to:
> 
> #!/usr/bin/env bash
> trap "echo booh!" EXIT
> sleep 5  & wait $!
> 
> I get:
> 
> $ for i in 2  15;do ./sigtest $i;done
> booh!
> Child exit normally: 129
> booh!
> Child exited with status: 15 and signal: 15
> 
> As I said I'm not sure what are the rationale behind all that.

It can be found in the article.  Sending SIGINT from a program to just the
shell is somewhat artificial, since a keyboard-generated SIGINT goes to the
process group.  When the shell is not interactive, as it is in this case,
the shell assumes that the SIGINT was sent from the keyboard and received
by the foreground process group.  It uses the child's exit status as a
guide for signal disposition: if the child exits due to SIGINT, the shell
acts as if it received the SIGINT; if not, the shell effectively ignores
the signal.

The shell also assumes that if there is a trap set on SIGINT, that the
programmer must want to know about keyboard-generated signals whether or
not the foreground process responds to them, and runs the trap handler.
This is a heuristic that's worked out pretty well so far.

Running the sleep in the background and the wait in the foreground is also
documented in the section you originally quoted from the manual page.

SIGTERM, however, since it is not generated from the keyboard and not sent
by default to the terminal's foreground process group, is treated
differently.

Chet
-- 
``The lyf so short, the craft so long to lerne.'' - Chaucer
                 ``Ars longa, vita brevis'' - Hippocrates
Chet Ramey, ITS, CWRU    address@hidden    http://cnswww.cns.cwru.edu/~chet/



reply via email to

[Prev in Thread] Current Thread [Next in Thread]