diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-06-27 05:25:54 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-06-27 05:25:54 +0000 |
commit | 7a6cafc88e3b41e94d6473683580b36a39f59be1 (patch) | |
tree | e2315d2a118ee9a3a21db7529da943ee8402fd79 | |
parent | f1d4745627f5f33fc0aa91904efca7fb26614ee8 (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-- | ChangeLog | 5 | ||||
-rw-r--r-- | vm.c | 1 |
2 files changed, 6 insertions, 0 deletions
@@ -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, @@ -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)); } |