diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-05-10 14:56:37 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-05-10 14:56:37 +0000 |
commit | 0542f05b321ef4f0d0083cc442ee1f347753f529 (patch) | |
tree | 80dcc4445780db4fcb94d787d7dee3f71453a31e /parse.y | |
parent | 980bf275fae4b50b06f330d854aa326444916a46 (diff) | |
download | ruby-0542f05b321ef4f0d0083cc442ee1f347753f529.tar.gz |
parse.y: lex_state macros
* parse.y (parser_yylex): use IS_lex_state() and IS_lex_state_for()
instead of direct comparison.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@40634 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'parse.y')
-rw-r--r-- | parse.y | 10 |
1 files changed, 5 insertions, 5 deletions
@@ -8006,11 +8006,11 @@ parser_yylex(struct parser_params *parser) if (kw) { enum lex_state_e state = lex_state; lex_state = kw->state; - if (state == EXPR_FNAME) { + if (IS_lex_state_for(state, EXPR_FNAME)) { set_yylval_name(rb_intern(kw->name)); return kw->id[0]; } - if (lex_state == EXPR_BEG) { + if (IS_lex_state(EXPR_BEG)) { command_start = TRUE; } if (kw->id[0] == keyword_do) { @@ -8020,13 +8020,13 @@ parser_yylex(struct parser_params *parser) return keyword_do_LAMBDA; } if (COND_P()) return keyword_do_cond; - if (CMDARG_P() && state != EXPR_CMDARG) + if (CMDARG_P() && !IS_lex_state_for(state, EXPR_CMDARG)) return keyword_do_block; - if (state & (EXPR_BEG | EXPR_ENDARG)) + if (IS_lex_state_for(state, (EXPR_BEG | EXPR_ENDARG))) return keyword_do_block; return keyword_do; } - if (state & (EXPR_BEG | EXPR_VALUE)) + if (IS_lex_state_for(state, (EXPR_BEG | EXPR_VALUE))) return kw->id[0]; else { if (kw->id[0] != kw->id[1]) |