diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-06-15 09:58:10 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-06-15 09:58:10 +0000 |
commit | cebc9bb19d219aaf5d035ff2d0e5fb69636bd2c1 (patch) | |
tree | d59baa6723297e06b43b8ee61390098d2da4fcb2 /signal.c | |
parent | e3dd9a78db1f918bd4e621492975b741269b5cb4 (diff) | |
download | ruby-cebc9bb19d219aaf5d035ff2d0e5fb69636bd2c1.tar.gz |
* signal.c (trap_handler): trap("SIGSEGV", "DEFAULT") may cause wrong
trap error because SIG_DFL may be zero.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@12550 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'signal.c')
-rw-r--r-- | signal.c | 13 |
1 files changed, 7 insertions, 6 deletions
@@ -634,10 +634,15 @@ struct trap_arg { VALUE cmd; }; +static RETSIGTYPE +wrong_trap(int sig) +{ +} + static sighandler_t trap_handler(VALUE *cmd) { - sighandler_t func = 0; + sighandler_t func = wrong_trap; VALUE command; if (NIL_P(*cmd)) { @@ -674,7 +679,7 @@ trap_handler(VALUE *cmd) } break; } - if (!func) { + if (func == wrong_trap) { rb_raise(rb_eArgError, "wrong trap - %s", RSTRING_PTR(command)); } } @@ -1047,14 +1052,10 @@ Init_signal(void) #endif #ifdef SIGBUS -# ifndef RUBY_GC_STRESS install_sighandler(SIGBUS, sigbus); -# endif #endif #ifdef SIGSEGV -# ifndef RUBY_GC_STRESS install_sighandler(SIGSEGV, sigsegv); -# endif #endif #ifdef SIGPIPE install_sighandler(SIGPIPE, sigpipe); |