summaryrefslogtreecommitdiff
path: root/parse.y
diff options
context:
space:
mode:
authornagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-05-13 16:00:26 +0000
committernagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-05-13 16:00:26 +0000
commit3dd4b241bfe4fad201ed50932a5dde08e1e83524 (patch)
treeff256d1e855a59b4dce84abc5a48861d277d772a /parse.y
parentaca1574676e39bec9106223a41f1f2497dcbab1c (diff)
merge revision(s) 50402: [Backport #11107]
* parse.y (lambda): push and reset cmdarg_stack in lambda body. [ruby-core:69017] [Bug #11107] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_2@50487 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'parse.y')
-rw-r--r--parse.y9
1 files changed, 7 insertions, 2 deletions
diff --git a/parse.y b/parse.y
index 0f9a5670b6..1e29197bfe 100644
--- a/parse.y
+++ b/parse.y
@@ -3534,14 +3534,19 @@ lambda : {
{
$<num>$ = ruby_sourceline;
}
+ {
+ $<val>$ = cmdarg_stack;
+ cmdarg_stack = 0;
+ }
lambda_body
{
lpar_beg = $<num>2;
+ cmdarg_stack = $<val>5;
/*%%%*/
- $$ = NEW_LAMBDA($3, $5);
+ $$ = NEW_LAMBDA($3, $6);
nd_set_line($$, $<num>4);
/*%
- $$ = dispatch2(lambda, $3, $5);
+ $$ = dispatch2(lambda, $3, $6);
%*/
dyna_pop($<vars>1);
}