From 601354bd6b661950663746bc41fe364b67bb8cd5 Mon Sep 17 00:00:00 2001 From: matz Date: Fri, 1 Aug 2003 02:52:21 +0000 Subject: * eval.c (BEGIN_CALLARGS): should not always reset ruby_iter, need to restore previous value. [ruby-talk:77577] * array.c (rb_ary_fill): array length may be changed during the block execution. [ruby-talk:77579] * array.c (rb_ary_zip): ditto. * array.c (rb_ary_fill): ditto. * hash.c (env_reject_bang): length may be changed during the block execution. * hash.c (env_clear): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4254 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- eval.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'eval.c') diff --git a/eval.c b/eval.c index 1c4436c7c8..7b23e74af1 100644 --- a/eval.c +++ b/eval.c @@ -1964,7 +1964,7 @@ copy_node_scope(node, rval) if (ruby_iter->iter == ITER_PRE) {\ ruby_block = ruby_block->outer;\ }\ - PUSH_ITER(ITER_NOT) + PUSH_ITER((ruby_iter->prev ? ruby_iter->prev->iter : ITER_NOT)) #define END_CALLARGS \ ruby_block = tmp_block;\ -- cgit v1.2.3