From 85cb4ee236ee14ec00aebcd90130555ce909d3a2 Mon Sep 17 00:00:00 2001 From: nobu Date: Tue, 20 Apr 2010 03:09:57 +0000 Subject: [PATCH] * parse.y (parser_yylex): simplified with IS_ARG and IS_END. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@27413 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- parse.y | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/parse.y b/parse.y index 0ba786c939..36d9d75eff 100644 --- a/parse.y +++ b/parse.y @@ -6658,10 +6658,9 @@ parser_yylex(struct parser_params *parser) case '<': c = nextc(); if (c == '<' && - lex_state != EXPR_END && lex_state != EXPR_DOT && - lex_state != EXPR_ENDARG && lex_state != EXPR_CLASS && + !IS_END() && (!IS_ARG() || space_seen)) { int token = heredoc_identifier(); if (token) return token; @@ -6737,7 +6736,7 @@ parser_yylex(struct parser_params *parser) return tSTRING_BEG; case '?': - if (lex_state == EXPR_END || lex_state == EXPR_ENDARG) { + if (IS_END()) { lex_state = EXPR_VALUE; return '?'; } @@ -7625,8 +7624,7 @@ parser_yylex(struct parser_params *parser) } if ((lex_state == EXPR_BEG && !cmd_state) || - lex_state == EXPR_ARG || - lex_state == EXPR_CMDARG) { + IS_ARG()) { if (peek(':') && !(lex_p + 1 < lex_pend && lex_p[1] == ':')) { lex_state = EXPR_BEG; nextc();