mirror of
https://git.savannah.gnu.org/git/gnulib.git
synced 2025-08-16 01:22:18 +03:00
* lib/sigprocmask.c: Include msvc-inval.h. (signal_nothrow): New function. (signal): Redefine it. * m4/signalblocking.m4 (gl_PREREQ_SIGPROCMASK): Require AC_C_INLINE. * modules/sigprocmask (Depends-on): Add msvc-inval. * doc/posix-functions/signal.texi: Mention the problem on MSVC.
29 lines
1005 B
Plaintext
29 lines
1005 B
Plaintext
@node signal
|
|
@section @code{signal}
|
|
@findex signal
|
|
|
|
POSIX specification:@* @url{http://www.opengroup.org/onlinepubs/9699919799/functions/signal.html}
|
|
|
|
Gnulib module: ---
|
|
|
|
Portability problems fixed by Gnulib:
|
|
@itemize
|
|
@end itemize
|
|
|
|
Portability problems not fixed by Gnulib:
|
|
@itemize
|
|
@item
|
|
This function crashes when invoked with invalid arguments on some platforms:
|
|
MSVC 9.
|
|
@item
|
|
On System V platforms, when the signal is triggered, the kernel uninstalls the
|
|
handler (i.e.@: resets the signal's action to SIG_DFL) before invoking the
|
|
handler. This opens the door to race conditions: undesired things happen
|
|
if the signal is triggered twice and the signal handler was not quick enough
|
|
reinstalling itself as a handler. On BSD platforms and glibc platforms, on the
|
|
other hand, when the signal is triggered, the kernel blocks the signal
|
|
before invoking the handler. This is saner, but POSIX still allows either
|
|
behavior. To avoid this problem, use @code{sigaction} instead of
|
|
@code{signal}.
|
|
@end itemize
|