Commit f9339f5c authored by Yukihiro Matsumoto's avatar Yukihiro Matsumoto

EXPR_BEG by keywords is a start point of commands; backport r35457 from CRuby

parent 8b367098
...@@ -2581,6 +2581,7 @@ superclass : term ...@@ -2581,6 +2581,7 @@ superclass : term
| '<' | '<'
{ {
p->lstate = EXPR_BEG; p->lstate = EXPR_BEG;
p->cmd_start = TRUE;
} }
expr_value term expr_value term
{ {
...@@ -3346,8 +3347,9 @@ parse_string(parser_state *p, int term) ...@@ -3346,8 +3347,9 @@ parse_string(parser_state *p, int term)
c = nextc(p); c = nextc(p);
if (c == '{') { if (c == '{') {
tokfix(p); tokfix(p);
p->lstate = EXPR_END; p->lstate = EXPR_BEG;
p->sterm = term; p->sterm = term;
p->cmd_start = TRUE;
yylval.node = new_str(p, tok(p), toklen(p)); yylval.node = new_str(p, tok(p), toklen(p));
return tSTRING_PART; return tSTRING_PART;
} }
...@@ -3477,6 +3479,7 @@ parser_yylex(parser_state *p) ...@@ -3477,6 +3479,7 @@ parser_yylex(parser_state *p)
} }
} }
normal_newline: normal_newline:
p->cmd_start = TRUE;
p->lstate = EXPR_BEG; p->lstate = EXPR_BEG;
return '\n'; return '\n';
...@@ -3582,6 +3585,8 @@ parser_yylex(parser_state *p) ...@@ -3582,6 +3585,8 @@ parser_yylex(parser_state *p)
switch (p->lstate) { switch (p->lstate) {
case EXPR_FNAME: case EXPR_DOT: case EXPR_FNAME: case EXPR_DOT:
p->lstate = EXPR_ARG; break; p->lstate = EXPR_ARG; break;
case EXPR_CLASS:
p->cmd_start = TRUE;
default: default:
p->lstate = EXPR_BEG; break; p->lstate = EXPR_BEG; break;
} }
...@@ -4536,6 +4541,9 @@ parser_yylex(parser_state *p) ...@@ -4536,6 +4541,9 @@ parser_yylex(parser_state *p)
yylval.id = intern(kw->name); yylval.id = intern(kw->name);
return kw->id[0]; return kw->id[0];
} }
if (p->lstate == EXPR_BEG) {
p->cmd_start = TRUE;
}
if (kw->id[0] == keyword_do) { if (kw->id[0] == keyword_do) {
if (p->lpar_beg && p->lpar_beg == p->paren_nest) { if (p->lpar_beg && p->lpar_beg == p->paren_nest) {
p->lpar_beg = 0; p->lpar_beg = 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment