aboutsummaryrefslogtreecommitdiffstats
path: root/parse.y
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-02-08 07:06:37 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-02-08 07:06:37 +0000
commitfd264ef51c569210edacff30c8d3053de4077fbe (patch)
tree6c759a5ecabbe1b6ea3968d4d7364b5b547aa1c1 /parse.y
parent5aa49b7d8698e2b35eaaae6ac4eab02ed7e8c95c (diff)
downloadruby-fd264ef51c569210edacff30c8d3053de4077fbe.tar.gz
parse.y: named caputre into match_op_gen
* parse.y (match_op_gen): move making named capture assignment nodes. remove repeated conditions. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@57576 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'parse.y')
-rw-r--r--parse.y11
1 files changed, 4 insertions, 7 deletions
diff --git a/parse.y b/parse.y
index 009ee673c7..0e1734bf6a 100644
--- a/parse.y
+++ b/parse.y
@@ -2259,12 +2259,6 @@ arg : lhs '=' arg_rhs
{
/*%%%*/
$$ = match_op($1, $3);
- if (nd_type($1) == NODE_LIT) {
- VALUE lit = $1->nd_lit;
- if (RB_TYPE_P(lit, T_REGEXP)) {
- $$->nd_args = reg_named_capture_assign(lit);
- }
- }
/*%
$$ = dispatch3(binary, $1, ID2SYM(idEqTilde), $3);
%*/
@@ -8975,7 +8969,10 @@ match_op_gen(struct parser_params *parser, NODE *node1, NODE *node2)
case NODE_LIT:
if (RB_TYPE_P(node1->nd_lit, T_REGEXP)) {
- return NEW_MATCH2(node1, node2);
+ const VALUE lit = node1->nd_lit;
+ NODE *match = NEW_MATCH2(node1, node2);
+ match->nd_args = reg_named_capture_assign(lit);
+ return match;
}
}
}