summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-06-27 05:25:54 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-06-27 05:25:54 +0000
commit7a6cafc88e3b41e94d6473683580b36a39f59be1 (patch)
treee2315d2a118ee9a3a21db7529da943ee8402fd79
parentf1d4745627f5f33fc0aa91904efca7fb26614ee8 (diff)
* vm.c (vm_eval_body): if thrown exception is frozen, reraise it to
create a new instance. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@17600 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--vm.c1
2 files changed, 6 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 0a2a43a080..3098dc8926 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Fri Jun 27 14:25:52 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * vm.c (vm_eval_body): if thrown exception is frozen, reraise it to
+ create a new instance.
+
Fri Jun 27 13:29:26 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* include/ruby/intern.h (rb_str_new2, rb_tainted_str_new2,
diff --git a/vm.c b/vm.c
index 83b6ea9bd4..775dbd59ed 100644
--- a/vm.c
+++ b/vm.c
@@ -1072,6 +1072,7 @@ vm_eval_body(rb_thread_t *th)
err = th->errinfo;
if (state == TAG_RAISE) {
+ if (OBJ_FROZEN(err)) rb_exc_raise(err);
rb_ivar_set(err, idThrowState, INT2FIX(state));
}