diff options
| author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-03-25 15:25:18 +0000 |
|---|---|---|
| committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-03-25 15:25:18 +0000 |
| commit | 7c2dc8a6ff013cebfc867e630b7bcf26f6184c06 (patch) | |
| tree | e5c75ec3d25a02e65af59a480ac9bc181eb612ff | |
| parent | 44fdfd5e1067d886ab10b8271d2dceab04c9129a (diff) | |
| download | ruby-7c2dc8a6ff013cebfc867e630b7bcf26f6184c06.tar.gz ruby-7c2dc8a6ff013cebfc867e630b7bcf26f6184c06.tar.xz ruby-7c2dc8a6ff013cebfc867e630b7bcf26f6184c06.zip | |
* signal.c (trap): return "DEFAULT" and "IGNORE" respectively for
previous sighandler SIG_DFL and SIG_IGN. [ruby-talk:67860]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@3614 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 5 | ||||
| -rw-r--r-- | sample/test.rb | 5 | ||||
| -rw-r--r-- | signal.c | 16 |
3 files changed, 20 insertions, 6 deletions
@@ -1,3 +1,8 @@ +Tue Mar 25 23:26:02 2003 Yukihiro Matsumoto <matz@ruby-lang.org> + + * signal.c (trap): return "DEFAULT" and "IGNORE" respectively for + previous sighandler SIG_DFL and SIG_IGN. [ruby-talk:67860] + Tue Mar 25 12:24:15 2003 Yukihiro Matsumoto <matz@ruby-lang.org> * eval.c (rb_yield_0): call avalue_to_mrhs() to assign block diff --git a/sample/test.rb b/sample/test.rb index 247518c75..fb7c0f675 100644 --- a/sample/test.rb +++ b/sample/test.rb @@ -248,6 +248,11 @@ f = lambda {|r,*l| test_ok([] == r); test_ok([1] == l)} f.call([], *[1]) f.yield([], *[1]) +a = [42,55] +lambda{|x| test_ok([42,55] == x)}.call(a) +lambda{|x,| test_ok([42,55] == x)}.call(a) +lambda{|*x| test_ok([[42,55]] == x)}.call(a) + a,=*[1] test_ok(a == 1) @@ -481,8 +481,8 @@ static VALUE trap(arg) struct trap_arg *arg; { - sighandler_t func; - VALUE command, old; + sighandler_t func, oldfunc; + VALUE command, oldcmd; int sig = -1; char *s; @@ -588,9 +588,13 @@ trap(arg) #endif } } - ruby_signal(sig, func); - old = trap_list[sig]; - if (!old) old = Qnil; + oldfunc = ruby_signal(sig, func); + oldcmd = trap_list[sig]; + if (!oldcmd) { + if (oldfunc == SIG_IGN) oldcmd = rb_str_new2("IGNORE"); + else if (oldfunc == sighandler) oldcmd = rb_str_new2("DEFAULT"); + else oldcmd = Qnil; + } trap_list[sig] = command; /* enable at least specified signal. */ @@ -601,7 +605,7 @@ trap(arg) arg->mask &= ~sigmask(sig); #endif #endif - return old; + return oldcmd; } #ifndef _WIN32 |
