summaryrefslogtreecommitdiff
path: root/thread.c
diff options
context:
space:
mode:
authorkosaki <kosaki@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-11-28 04:09:38 +0000
committerkosaki <kosaki@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-11-28 04:09:38 +0000
commit694c77633c80a106a1e526870ad5076bfac30640 (patch)
treee7b83a4ee3845c914b205e65e6165fac5d849f97 /thread.c
parent4ed6a88b74be65894b580dba81e7b8e3e8b0c3ce (diff)
* thread.c (thread_join): A trap handler check was moved from
thread_join_m because Thread#value should be raised an exception too. * thread.c (thread_join_m): remove trap handler check. * test/ruby/test_thread.rb (test_thread_join_in_trap): add test for thread#value. * NEWS: documentation fix for the above. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@37918 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'thread.c')
-rw-r--r--thread.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/thread.c b/thread.c
index a0a3472b26..473713f862 100644
--- a/thread.c
+++ b/thread.c
@@ -740,6 +740,10 @@ thread_join(rb_thread_t *target_th, double delay)
if (GET_VM()->main_thread == target_th) {
rb_raise(rb_eThreadError, "Target thread must not be main thread");
}
+ /* When running trap handler */
+ if (th->interrupt_mask & TRAP_INTERRUPT_MASK) {
+ rb_raise(rb_eThreadError, "can't be called from trap context");
+ }
arg.target = target_th;
arg.waiting = th;
@@ -822,15 +826,9 @@ static VALUE
thread_join_m(int argc, VALUE *argv, VALUE self)
{
rb_thread_t *target_th;
- rb_thread_t *cur_th = GET_THREAD();
double delay = DELAY_INFTY;
VALUE limit;
- /* When running trap handler */
- if (cur_th->interrupt_mask & TRAP_INTERRUPT_MASK) {
- rb_raise(rb_eThreadError, "can't be called from trap context");
- }
-
GetThreadPtr(self, target_th);
rb_scan_args(argc, argv, "01", &limit);