aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-06-15 03:22:51 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-06-15 03:22:51 +0000
commit70df6311af85b7f53b5c730502d4b9a94fa23cc9 (patch)
treee2e1d7a30c12579af1cc471a2705efbd37fbba57
parent31ac946975a8e20157e1f47d23546ae237484024 (diff)
downloadruby-70df6311af85b7f53b5c730502d4b9a94fa23cc9.tar.gz
* eval.c (ruby_finalize_1): rb_thread_t#errinfo should be clear with
Qnil. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@12543 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--eval.c5
2 files changed, 9 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 9f4e19d38b..b9b4360660 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Fri Jun 15 12:22:10 2007 Koichi Sasada <ko1@atdot.net>
+
+ * eval.c (ruby_finalize_1): rb_thread_t#errinfo should be clear with
+ Qnil.
+
Fri Jun 15 12:20:11 2007 Koichi Sasada <ko1@atdot.net>
* cont.c (rb_cont_call): forbid cross fiber continuation call.
diff --git a/eval.c b/eval.c
index e3f2adac99..658ff1c220 100644
--- a/eval.c
+++ b/eval.c
@@ -137,7 +137,7 @@ static void
ruby_finalize_1(void)
{
signal(SIGINT, SIG_DFL);
- GET_THREAD()->errinfo = 0;
+ GET_THREAD()->errinfo = Qnil;
rb_clear_trace_func();
rb_gc_call_finalizer_at_exit();
}
@@ -668,6 +668,7 @@ rb_longjmp(int tag, VALUE mesg)
th->errinfo = exception_error;
JUMP_TAG(TAG_FATAL);
}
+
if (NIL_P(mesg))
mesg = GET_THREAD()->errinfo;
if (NIL_P(mesg)) {
@@ -709,10 +710,12 @@ rb_longjmp(int tag, VALUE mesg)
}
rb_trap_restore_mask();
+
if (tag != TAG_FATAL) {
EXEC_EVENT_HOOK(th, RUBY_EVENT_RAISE, th->cfp->self,
0 /* TODO: id */, 0 /* TODO: klass */);
}
+
thread_reset_raised(th);
JUMP_TAG(tag);
}