mirror of
https://github.com/ruby/ruby.git
synced 2025-09-16 09:04:05 +02:00
merge revision(s) 53753,54131: [Backport #8851]
lex.c.blt: update * lex.c.blt: follows r52429, not removing casts to int. * defs/keywords (alias, undef): symbol literals are allowed. * parse.y (parse_percent): should parse symbol literals for alias and undef. [ruby-dev:47681] [Bug #8851] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_3@54642 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
9dc33b83bb
commit
b7c90baf07
7 changed files with 86 additions and 53 deletions
12
parse.y
12
parse.y
|
@ -73,6 +73,7 @@ enum lex_state_bits {
|
|||
EXPR_CLASS_bit, /* immediate after `class', no here document. */
|
||||
EXPR_LABEL_bit, /* flag bit, label is allowed. */
|
||||
EXPR_LABELED_bit, /* flag bit, just after a label. */
|
||||
EXPR_FITEM_bit, /* symbol literal as FNAME. */
|
||||
EXPR_MAX_STATE
|
||||
};
|
||||
/* examine combinations */
|
||||
|
@ -90,6 +91,7 @@ enum lex_state_e {
|
|||
DEF_EXPR(CLASS),
|
||||
DEF_EXPR(LABEL),
|
||||
DEF_EXPR(LABELED),
|
||||
DEF_EXPR(FITEM),
|
||||
EXPR_VALUE = EXPR_BEG,
|
||||
EXPR_BEG_ANY = (EXPR_BEG | EXPR_MID | EXPR_CLASS),
|
||||
EXPR_ARG_ANY = (EXPR_ARG | EXPR_CMDARG),
|
||||
|
@ -1131,7 +1133,7 @@ stmt_or_begin : stmt
|
|||
%*/
|
||||
}
|
||||
|
||||
stmt : keyword_alias fitem {SET_LEX_STATE(EXPR_FNAME);} fitem
|
||||
stmt : keyword_alias fitem {SET_LEX_STATE(EXPR_FNAME|EXPR_FITEM);} fitem
|
||||
{
|
||||
/*%%%*/
|
||||
$$ = NEW_ALIAS($2, $4);
|
||||
|
@ -1967,7 +1969,7 @@ undef_list : fitem
|
|||
$$ = rb_ary_new3(1, $1);
|
||||
%*/
|
||||
}
|
||||
| undef_list ',' {SET_LEX_STATE(EXPR_FNAME);} fitem
|
||||
| undef_list ',' {SET_LEX_STATE(EXPR_FNAME|EXPR_FITEM);} fitem
|
||||
{
|
||||
/*%%%*/
|
||||
$$ = block_append($1, NEW_UNDEF($4));
|
||||
|
@ -7790,7 +7792,7 @@ parse_percent(struct parser_params *parser, const int space_seen, const enum lex
|
|||
|
||||
case 's':
|
||||
lex_strterm = NEW_STRTERM(str_ssym, term, paren);
|
||||
SET_LEX_STATE(EXPR_FNAME);
|
||||
SET_LEX_STATE(EXPR_FNAME|EXPR_FITEM);
|
||||
return tSYMBEG;
|
||||
|
||||
default:
|
||||
|
@ -7803,7 +7805,7 @@ parse_percent(struct parser_params *parser, const int space_seen, const enum lex
|
|||
SET_LEX_STATE(EXPR_BEG);
|
||||
return tOP_ASGN;
|
||||
}
|
||||
if (IS_SPCARG(c)) {
|
||||
if (IS_SPCARG(c) || (IS_lex_state(EXPR_FITEM) && c == 's')) {
|
||||
goto quotation;
|
||||
}
|
||||
SET_LEX_STATE(IS_AFTER_OPERATOR() ? EXPR_ARG : EXPR_BEG);
|
||||
|
@ -9212,7 +9214,7 @@ id_is_var_gen(struct parser_params *parser, ID id)
|
|||
static const char lex_state_names[][13] = {
|
||||
"EXPR_BEG", "EXPR_END", "EXPR_ENDARG", "EXPR_ENDFN", "EXPR_ARG",
|
||||
"EXPR_CMDARG", "EXPR_MID", "EXPR_FNAME", "EXPR_DOT", "EXPR_CLASS",
|
||||
"EXPR_LABEL", "EXPR_LABELED",
|
||||
"EXPR_LABEL", "EXPR_LABELED","EXPR_FITEM",
|
||||
};
|
||||
|
||||
static VALUE
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue