summaryrefslogtreecommitdiff
path: root/eval.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-08-01 02:52:21 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-08-01 02:52:21 +0000
commit601354bd6b661950663746bc41fe364b67bb8cd5 (patch)
tree0d3a28d2d017105b74cc60301cf522134b0a4692 /eval.c
parent81f52e532b8923f2544d129f90ccb1514f1615e0 (diff)
* 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
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c2
1 files changed, 1 insertions, 1 deletions
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;\