diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-10-20 09:28:13 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-10-20 09:28:13 +0000 |
commit | 229c37a6dad61030bffc8d07f9c708f8a911601b (patch) | |
tree | 073fc6f6984c3796f80715ecef837f7d071e637a | |
parent | 6eb98c5ebe264eb0be6488c7db875137a44d8279 (diff) |
* eval.c (rb_catch): backout.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4812 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | eval.c | 14 |
2 files changed, 5 insertions, 13 deletions
@@ -1,3 +1,7 @@ +Mon Oct 20 18:28:10 2003 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * eval.c (rb_catch): backout. + Mon Oct 20 17:31:46 2003 Yukihiro Matsumoto <matz@ruby-lang.org> * eval.c (PUSH_FRAME): generate unique number to be TAG_JUMP() @@ -10217,19 +10217,7 @@ rb_catch(tag, func, data) VALUE (*func)(); VALUE data; { - int state; - VALUE val = Qnil; /* OK */ - - PUSH_TAG(PROT_NONE); - PUSH_SCOPE(); - if ((state = EXEC_TAG()) == 0) { - val = rb_iterate((VALUE(*)_((VALUE)))catch_i, ID2SYM(rb_intern(tag)), func, data); - } - POP_SCOPE(); - POP_TAG(); - if (state) JUMP_TAG(state); - - return val; + return rb_iterate((VALUE(*)_((VALUE)))catch_i, ID2SYM(rb_intern(tag)), func, data); } static VALUE |