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 | 07dc1fbb18e23f0a9d1d37e66cc96948014d2c41 (patch) | |
| tree | d59baa6723297e06b43b8ee61390098d2da4fcb2 | |
| parent | 57d47da6fc9d11487ad28f524f803304afdd346a (diff) | |
| download | ruby-07dc1fbb18e23f0a9d1d37e66cc96948014d2c41.tar.gz ruby-07dc1fbb18e23f0a9d1d37e66cc96948014d2c41.tar.xz ruby-07dc1fbb18e23f0a9d1d37e66cc96948014d2c41.zip | |
* signal.c (trap_handler): trap("SIGSEGV", "DEFAULT") may cause wrong
trap error because SIG_DFL may be zero.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@12550 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 7 | ||||
| -rw-r--r-- | signal.c | 13 |
2 files changed, 13 insertions, 7 deletions
@@ -1,6 +1,11 @@ +Fri Jun 15 18:56:52 2007 Tanaka Akira <akr@fsij.org> + + * signal.c (trap_handler): trap("SIGSEGV", "DEFAULT") may cause wrong + trap error because SIG_DFL may be zero. + Fri Jun 15 15:55:55 2007 Koichi Sasada <ko1@atdot.net> - * insns.def(setconstant, toregexp): fix to mark object correctly. + * insns.def (setconstant, toregexp): fix to mark object correctly. Fri Jun 15 13:24:18 2007 Koichi Sasada <ko1@atdot.net> @@ -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); |
