setjmp, sigsetjmp — save stack context for nonlocal goto
#include <setjmp.h>
| int
            setjmp( | jmp_buf env ); | 
| int
            sigsetjmp( | sigjmp_buf env, | 
| int savesigs ); | 
| ![[Note]](../stylesheet/note.png) | Note | ||||
|---|---|---|---|---|---|
| 
 | 
setjmp() and longjmp(3) are useful for
      dealing with errors and interrupts encountered in a low-level
      subroutine of a program. setjmp() saves the stack
      context/environment in env for later use by longjmp(3). The stack
      context will be invalidated if the function which called
      setjmp() returns.
sigsetjmp() is similar to
      setjmp(). If, and only if,
      savesigs is nonzero,
      the process's current signal mask is saved in env and will be restored if a
      siglongjmp(3) is later
      performed with this env.
setjmp() and sigsetjmp() return 0 if returning directly,
      and nonzero when returning from longjmp(3) or siglongjmp(3) using the
      saved context.
POSIX does not specify whether setjmp() will save the signal mask (to be
      later restored during longjmp(3)). In System V it
      will not. In 4.3BSD it will, and there is a function
      _setjmp that will not. On Linux
      with glibc versions before 2.19, setjmp() follows the System V behavior by
      default, but the BSD behavior is provided if the _BSD_SOURCE feature test macro is defined
      and none of _POSIX_SOURCE,
      _POSIX_C_SOURCE, _XOPEN_SOURCE, _XOPEN_SOURCE_EXTENDED, _GNU_SOURCE, or _SVID_SOURCE is defined. Since glibc 2.19,
      <setjmp.h>
      exposes only the System V version of setjmp(). Programs that need the BSD
      semantics should replace calls to setjmp() with calls to sigsetjmp() with a nonzero savesigs argument.
If you want to portably save and restore signal masks, use
      sigsetjmp() and siglongjmp(3).
setjmp() and sigsetjmp() make programs hard to
      understand and maintain. If possible, an alternative should
      be used.
This page is part of release 3.72 of the Linux man-pages project. A
      description of the project, information about reporting bugs,
      and the latest version of this page, can be found at
      http://www.kernel.org/doc/man−pages/.
| Written by Michael Haardt, Fri Nov 25 14:51:42 MET 1994 %%%LICENSE_START(GPLv2+_DOC_FULL) This is free documentation; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. The GNU General Public License's references to "object code" and "executables" are to be interpreted as the output of any document formatting or typesetting system, including intermediate and printed output. This manual is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this manual; if not, see <http://www.gnu.org/licenses/>. %%%LICENSE_END Added sigsetjmp, Sun Mar 2 22:03:05 EST 1997, jrvvanzandt.mv.com Modifications, Sun Feb 26 14:39:45 1995, faithcs.unc.edu " |