diff --git a/ChangeLog b/ChangeLog index 5bb46f861b..38daa47132 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Tue Oct 14 08:28:31 2008 Yukihiro Matsumoto + + * parse.y (parser_yylex): allow reserved word to be keyword argument. + Mon Oct 13 19:07:52 2008 NARUSE, Yui * parse.y (token_info_pop): show source filename. [ruby-dev:36710] diff --git a/parse.y b/parse.y index 4adf43e871..b5743e4472 100644 --- a/parse.y +++ b/parse.y @@ -7523,6 +7523,16 @@ parser_yylex(struct parser_params *parser) } } + if ((lex_state == EXPR_BEG && !cmd_state) || + lex_state == EXPR_ARG || + lex_state == EXPR_CMDARG) { + if (peek(':') && !(lex_p + 1 < lex_pend && lex_p[1] == ':')) { + lex_state = EXPR_BEG; + nextc(); + set_yylval_id(TOK_INTERN(!ENC_SINGLE(mb))); + return tLABEL; + } + } if (mb == ENC_CODERANGE_7BIT && lex_state != EXPR_DOT) { const struct kwtable *kw; @@ -7559,16 +7569,6 @@ parser_yylex(struct parser_params *parser) } } - if ((lex_state == EXPR_BEG && !cmd_state) || - lex_state == EXPR_ARG || - lex_state == EXPR_CMDARG) { - if (peek(':') && !(lex_p + 1 < lex_pend && lex_p[1] == ':')) { - lex_state = EXPR_BEG; - nextc(); - set_yylval_id(TOK_INTERN(!ENC_SINGLE(mb))); - return tLABEL; - } - } if (IS_BEG() || lex_state == EXPR_DOT || IS_ARG()) {