trap man page on CentOS

Man page or keyword search:  
man Server   8420 pages
apropos Keyword Search (all sections)
Output format
CentOS logo
[printable version]

TRAP(P)			   POSIX Programmer's Manual		       TRAP(P)

PROLOG
       This  manual  page is part of the POSIX Programmer's Manual.  The Linux
       implementation of this interface may differ (consult the	 corresponding
       Linux  manual page for details of Linux behavior), or the interface may
       not be implemented on Linux.

NAME
       trap - trap signals

SYNOPSIS
       trap [action condition ...]

DESCRIPTION
       If action is '-' , the shell shall reset each condition to the  default
       value.  If action is null ( "" ), the shell shall ignore each specified
       condition if it arises. Otherwise, the argument action  shall  be  read
       and  executed  by  the  shell  when one of the corresponding conditions
       arises. The action of trap shall override  a  previous  action  (either
       default action or one explicitly set). The value of "$?" after the trap
       action completes shall be the value it had before trap was invoked.

       The condition can be EXIT, 0 (equivalent to EXIT), or a	signal	speci‐
       fied  using  a  symbolic name, without the SIG prefix, as listed in the
       tables of signal names in the <signal.h> header	defined	 in  the  Base
       Definitions  volume  of	IEEE Std 1003.1-2001, Chapter 13, Headers; for
       example, HUP, INT, QUIT, TERM. Implementations may  permit  names  with
       the  SIG prefix or ignore case in signal names as an extension. Setting
       a trap for SIGKILL or SIGSTOP produces undefined results.

       The environment in which the shell executes a trap  on  EXIT  shall  be
       identical  to  the  environment immediately after the last command exe‐
       cuted before the trap on EXIT was taken.

       Each time trap is invoked, the action argument shall be processed in  a
       manner equivalent to:

	      eval action

       Signals that were ignored on entry to a non-interactive shell cannot be
       trapped or reset, although no error need be reported when attempting to
       do  so.	An  interactive	 shell	may  reset or catch signals ignored on
       entry. Traps shall remain in place for a given shell  until  explicitly
       changed with another trap command.

       When a subshell is entered, traps that are not being ignored are set to
       the default actions. This does not imply that the trap  command	cannot
       be used within the subshell to set new traps.

       The  trap  command  with	 no arguments shall write to standard output a
       list of commands associated with each condition. The format shall be:

	      "trap -- %s %s ...\n", <action>, <condition> ...

       The shell shall format the output, including the proper use of quoting,
       so  that	 it  is	 suitable  for	reinput	 to the shell as commands that
       achieve the same trapping results. For example:

	      save_traps=$(trap)
	      ...
	      eval "$save_traps"

       XSI-conformant systems also allow numeric signal numbers for the condi‐
       tions corresponding to the following signal names:

			     Signal Number   Signal Name
			     1		     SIGHUP
			     2		     SIGINT
			     3		     SIGQUIT
			     6		     SIGABRT
			     9		     SIGKILL
			     14		     SIGALRM
			     15		     SIGTERM

       The  trap special built-in shall conform to the Base Definitions volume
       of IEEE Std 1003.1-2001, Section 12.2, Utility Syntax Guidelines.

OPTIONS
       None.

OPERANDS
       See the DESCRIPTION.

STDIN
       Not used.

INPUT FILES
       None.

ENVIRONMENT VARIABLES
       None.

ASYNCHRONOUS EVENTS
       Default.

STDOUT
       See the DESCRIPTION.

STDERR
       The standard error shall be used only for diagnostic messages.

OUTPUT FILES
       None.

EXTENDED DESCRIPTION
       None.

EXIT STATUS
       If the trap name	   or number  is invalid, a non-zero exit status shall
       be  returned;  otherwise, zero shall be returned.  For both interactive
       and non-interactive shells, invalid signal names	   or  numbers	 shall
       not be considered a syntax error and do not cause the shell to abort.

CONSEQUENCES OF ERRORS
       Default.

       The following sections are informative.

APPLICATION USAGE
       None.

EXAMPLES
       Write out a list of all traps and actions:

	      trap

       Set  a  trap  so the logout utility in the directory referred to by the
       HOME environment variable executes when the shell terminates:

	      trap '$HOME/logout' EXIT

       or:

	      trap '$HOME/logout' 0

       Unset traps on INT, QUIT, TERM, and EXIT:

	      trap - INT QUIT TERM EXIT

RATIONALE
       Implementations may permit lowercase  signal  names  as	an  extension.
       Implementations may also accept the names with the SIG prefix; no known
       historical shell does so. The trap and kill utilities in this volume of
       IEEE Std 1003.1-2001  are  now  consistent in their omission of the SIG
       prefix for signal names. Some kill implementations  do  not  allow  the
       prefix, and kill -l lists the signals without prefixes.

       Trapping	 SIGKILL or SIGSTOP is syntactically accepted by some histori‐
       cal implementations, but it has no effect. Portable POSIX  applications
       cannot attempt to trap these signals.

       The  output format is not historical practice. Since the output of his‐
       torical trap commands is not portable (because  numeric	signal	values
       are  not	 portable)  and had to change to become so, an opportunity was
       taken to format the output in a way that a shell script	could  use  to
       save and then later reuse a trap if it wanted.

       The  KornShell uses an ERR trap that is triggered whenever set -e would
       cause an exit. This is allowable as an extension, but was not mandated,
       as other shells have not used it.

       The text about the environment for the EXIT trap invalidates the behav‐
       ior of some historical versions of interactive shells which, for	 exam‐
       ple,  close  the standard input before executing a trap on 0. For exam‐
       ple, in some historical interactive shell sessions the  following  trap
       on 0 would always print "--" :

	      trap 'read foo; echo "-$foo-"' 0

FUTURE DIRECTIONS
       None.

SEE ALSO
       Special Built-In Utilities

COPYRIGHT
       Portions	 of  this text are reprinted and reproduced in electronic form
       from IEEE Std 1003.1, 2003 Edition, Standard for Information Technology
       --  Portable  Operating	System	Interface (POSIX), The Open Group Base
       Specifications Issue 6, Copyright (C) 2001-2003	by  the	 Institute  of
       Electrical  and	Electronics  Engineers, Inc and The Open Group. In the
       event of any discrepancy between this version and the original IEEE and
       The  Open Group Standard, the original IEEE and The Open Group Standard
       is the referee document. The original Standard can be  obtained	online
       at http://www.opengroup.org/unix/online.html .

IEEE/The Open Group		     2003			       TRAP(P)
[top]

List of man pages available for CentOS

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net