summaryrefslogtreecommitdiff
path: root/eval.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-08-11 08:35:54 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-08-11 08:35:54 +0000
commit5256bca931a809d8518c55b2d98e8169a128b37e (patch)
treeb7930bcad3235cfafae4547fb6d94b2468eb05a8 /eval.c
parentb2385db8963cebbdebff7333e33f740594ea9dc6 (diff)
* eval.c (rb_call_super): do not use rb_block_given_p() for
check. [ruby-talk:78656] * eval.c (BEGIN_CALLARGS): push ITER_NOT only when ITER_PRE. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4365 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/eval.c b/eval.c
index 46a1b7ad8a..6ed377fe6d 100644
--- a/eval.c
+++ b/eval.c
@@ -1961,10 +1961,12 @@ copy_node_scope(node, rval)
#define BEGIN_CALLARGS do {\
struct BLOCK *tmp_block = ruby_block;\
- if (ruby_iter->iter == ITER_PRE) {\
+ int tmp_iter = ruby_iter->iter;\
+ if (tmp_iter == ITER_PRE) {\
ruby_block = ruby_block->outer;\
+ tmp_iter = ITER_NOT;\
}\
- PUSH_ITER(ITER_NOT)
+ PUSH_ITER(tmp_iter)
#define END_CALLARGS \
ruby_block = tmp_block;\
@@ -5239,7 +5241,7 @@ rb_call_super(argc, argv)
klass = k;
}
- PUSH_ITER(ruby_iter->iter || rb_block_given_p() ? ITER_PRE : ITER_NOT);
+ PUSH_ITER(ruby_iter->iter ? ITER_PRE : ITER_NOT);
result = rb_call(RCLASS(klass)->super, self, ruby_frame->orig_func, argc, argv, 3);
POP_ITER();