summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-09-01 09:34:30 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-09-01 09:34:30 +0000
commit6f8f0a86f5964f36ea81b327c1f4538a9ccedbd2 (patch)
tree446fffdf5a750f00c72f5f44b9612e1f4eadf38b
parentb6feeb2945307a655c1a79b3ee61eafc89a7b09b (diff)
* eval.c (rb_eval): make tail recursion in ELSE clause of
RESCUE a jump. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4475 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--eval.c4
2 files changed, 7 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 54374d6d77..319fb44ad6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Mon Sep 1 18:34:25 2003 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * eval.c (rb_eval): make tail recursion in ELSE clause of
+ RESCUE a jump.
+
Mon Sep 1 18:00:02 2003 Yukihiro Matsumoto <matz@ruby-lang.org>
* parse.y (aref_args): forgot to call NEW_SPLAT(). reported by
diff --git a/eval.c b/eval.c
index fff5692080..c66f4415a7 100644
--- a/eval.c
+++ b/eval.c
@@ -2809,8 +2809,8 @@ rb_eval(self, n)
POP_TAG();
if (state) JUMP_TAG(state);
/* no exception raised */
- if (node->nd_else) { /* else clause given */
- result = rb_eval(self, node->nd_else);
+ if (node = node->nd_else) { /* else clause given */
+ goto again;
}
}
break;