From ff46ec3a43fc9cb2e128348308d2aea429fb2041 Mon Sep 17 00:00:00 2001 From: matz Date: Wed, 31 Jan 2007 05:59:23 +0000 Subject: * eval.c (rb_iterate): need to PUSH_ITER in proper order. [ruby-core:10125] * test/ruby/test_iterator.rb (TestIterator::test_block_given_within_iterator): add new test. [ruby-core:10125] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@11606 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- eval.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'eval.c') diff --git a/eval.c b/eval.c index a1ca159588..19d3b0489a 100644 --- a/eval.c +++ b/eval.c @@ -5284,9 +5284,9 @@ rb_iterate(it_proc, data1, bl_proc, data2) NODE *node = NEW_IFUNC(bl_proc, data2); VALUE self = ruby_top_self; - PUSH_ITER(ITER_PRE); PUSH_TAG(PROT_LOOP); PUSH_BLOCK(0, node); + PUSH_ITER(ITER_PRE); state = EXEC_TAG(); if (state == 0) { iter_retry: @@ -5300,9 +5300,9 @@ rb_iterate(it_proc, data1, bl_proc, data2) state = 0; goto iter_retry; } + POP_ITER(); POP_BLOCK(); POP_TAG(); - POP_ITER(); switch (state) { case 0: -- cgit v1.2.3