diff options
author | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-07-19 14:19:40 +0000 |
---|---|---|
committer | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-07-19 14:19:40 +0000 |
commit | f4a8db647ae66621f5d37402f5a11a3d57c69bb0 (patch) | |
tree | 2325b2b809b9d94ef2ccc367f5f84d9672e9f00d /insns.def | |
parent | 422e8d5adc3cf2d67b53cf9050c750eba7db3673 (diff) | |
download | ruby-f4a8db647ae66621f5d37402f5a11a3d57c69bb0.tar.gz |
* thread.c (rb_thread_s_control_interrupt,
rb_thread_s_check_interrupt): added for
Thread.control_intgerrupt and Thread.check_interrupt.
See details on rdoc.
I'll make an ticket for this feature.
* test/ruby/test_thread.rb: add a test for Thread.control_intgerrupt.
* thread.c (rb_threadptr_raise): make a new exception object
even if argc is 0.
* thread.c (rb_thread_kill): kill thread immediately if target thread
is current thread.
* vm_core.h (RUBY_VM_CHECK_INTS_BLOCKING): added.
CHECK_INTS while/after blocking operation.
* vm_core.h (RUBY_VM_CHECK_INTS): require rb_thread_t ptr.
* cont.c (fiber_switch): use replaced RUBY_VM_CHECK_INTS().
* eval.c (ruby_cleanup): ditto.
* insns.def: ditto.
* process.c (rb_waitpid): ditto.
* vm_eval.c (vm_call0): ditto.
* vm_insnhelper.c (vm_call_method): ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@36470 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'insns.def')
-rw-r--r-- | insns.def | 12 |
1 files changed, 6 insertions, 6 deletions
@@ -1086,7 +1086,7 @@ leave } } - RUBY_VM_CHECK_INTS(); + RUBY_VM_CHECK_INTS(th); if (UNLIKELY(VM_FRAME_TYPE_FINISH_P(GET_CFP()))) { #if OPT_CALL_THREADED_CODE @@ -1117,7 +1117,7 @@ throw (VALUE throwobj) (VALUE val) { - RUBY_VM_CHECK_INTS(); + RUBY_VM_CHECK_INTS(th); val = vm_throw(th, GET_CFP(), throw_state, throwobj); THROW_EXCEPTION(val); /* unreachable */ @@ -1138,7 +1138,7 @@ jump () () { - RUBY_VM_CHECK_INTS(); + RUBY_VM_CHECK_INTS(th); JUMP(dst); } @@ -1154,7 +1154,7 @@ branchif () { if (RTEST(val)) { - RUBY_VM_CHECK_INTS(); + RUBY_VM_CHECK_INTS(th); JUMP(dst); } } @@ -1171,7 +1171,7 @@ branchunless () { if (!RTEST(val)) { - RUBY_VM_CHECK_INTS(); + RUBY_VM_CHECK_INTS(th); JUMP(dst); } } @@ -1220,7 +1220,7 @@ onceinlinecache } else if (ic->ic_value.value == Qundef) { - RUBY_VM_CHECK_INTS(); + RUBY_VM_CHECK_INTS(th); rb_thread_schedule(); goto retry; } |