summaryrefslogtreecommitdiff
path: root/parse.y
diff options
context:
space:
mode:
authornagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-05-12 14:04:24 +0000
committernagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-05-12 14:04:24 +0000
commitd5cf6c1128d04beb84ac960ec5855f2fb64f3d27 (patch)
tree0e7d627dc1ec2da8433a7e5a4bf8f0cb29ac2e9d /parse.y
parent86f8f5d94e484745b4e406d5410168e7d131d92c (diff)
merge revision(s) r45637: [Backport #9726]
* parse.y (primary): flush cmdarg flags inside left-paren in a command argument, to allow parenthesed do-block as an argument without arguments parentheses. [ruby-core:61950] [Bug #9726] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_1@45929 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'parse.y')
-rw-r--r--parse.y12
1 files changed, 9 insertions, 3 deletions
diff --git a/parse.y b/parse.y
index 25946dccda..fdc3e0cf9b 100644
--- a/parse.y
+++ b/parse.y
@@ -2612,12 +2612,18 @@ primary : literal
$$ = dispatch1(paren, 0);
%*/
}
- | tLPAREN_ARG expr {lex_state = EXPR_ENDARG;} rparen
+ | tLPAREN_ARG
{
+ $<val>1 = cmdarg_stack;
+ cmdarg_stack = 0;
+ }
+ expr {lex_state = EXPR_ENDARG;} rparen
+ {
+ cmdarg_stack = $<val>1;
/*%%%*/
- $$ = $2;
+ $$ = $3;
/*%
- $$ = dispatch1(paren, $2);
+ $$ = dispatch1(paren, $3);
%*/
}
| tLPAREN compstmt ')'