summaryrefslogtreecommitdiff
path: root/parse.y
diff options
context:
space:
mode:
authormame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-10-28 12:34:13 +0000
committermame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-10-28 12:34:13 +0000
commitd563f1680cba03335eb38bd9e7bce8b82f03e12d (patch)
tree887136c9eac6605fcfb68ddca342e172eddead9e /parse.y
parent45ea81a4920f1bd99e253b059c665731a3d967d5 (diff)
* parse.y (parser_yylex): check EOF explicitly.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@20000 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'parse.y')
-rw-r--r--parse.y22
1 files changed, 11 insertions, 11 deletions
diff --git a/parse.y b/parse.y
index 07fe72d391..44000df50a 100644
--- a/parse.y
+++ b/parse.y
@@ -6790,7 +6790,7 @@ parser_yylex(struct parser_params *parser)
if (IS_ARG()) arg_ambiguous();
lex_state = EXPR_BEG;
pushback(c);
- if (ISDIGIT(c)) {
+ if (c != -1 && ISDIGIT(c)) {
c = '+';
goto start_num;
}
@@ -6824,7 +6824,7 @@ parser_yylex(struct parser_params *parser)
if (IS_ARG()) arg_ambiguous();
lex_state = EXPR_BEG;
pushback(c);
- if (ISDIGIT(c)) {
+ if (c != -1 && ISDIGIT(c)) {
return tUMINUS_NUM;
}
return tUMINUS;
@@ -6843,7 +6843,7 @@ parser_yylex(struct parser_params *parser)
return tDOT2;
}
pushback(c);
- if (ISDIGIT(c)) {
+ if (c != -1 && ISDIGIT(c)) {
yyerror("no .<digit> floating literal anymore; put 0 before dot");
}
lex_state = EXPR_DOT;
@@ -6868,7 +6868,7 @@ parser_yylex(struct parser_params *parser)
if (c == 'x' || c == 'X') {
/* hexadecimal */
c = nextc();
- if (ISXDIGIT(c)) {
+ if (c != -1 && ISXDIGIT(c)) {
do {
if (c == '_') {
if (nondigit) break;
@@ -6916,7 +6916,7 @@ parser_yylex(struct parser_params *parser)
if (c == 'd' || c == 'D') {
/* decimal */
c = nextc();
- if (ISDIGIT(c)) {
+ if (c != -1 && ISDIGIT(c)) {
do {
if (c == '_') {
if (nondigit) break;
@@ -6944,7 +6944,7 @@ parser_yylex(struct parser_params *parser)
if (c == 'o' || c == 'O') {
/* prefixed octal */
c = nextc();
- if (c == '_' || !ISDIGIT(c)) {
+ if (c == -1 || c == '_' || !ISDIGIT(c)) {
yyerror("numeric literal without digits");
}
}
@@ -7003,7 +7003,7 @@ parser_yylex(struct parser_params *parser)
}
else {
int c0 = nextc();
- if (!ISDIGIT(c0)) {
+ if (c == -1 || !ISDIGIT(c0)) {
pushback(c0);
goto decode_num;
}
@@ -7092,7 +7092,7 @@ parser_yylex(struct parser_params *parser)
lex_state = EXPR_DOT;
return tCOLON2;
}
- if (lex_state == EXPR_END || lex_state == EXPR_ENDARG || ISSPACE(c)) {
+ if (lex_state == EXPR_END || lex_state == EXPR_ENDARG || (c != -1 && ISSPACE(c))) {
pushback(c);
lex_state = EXPR_BEG;
return ':';
@@ -7251,7 +7251,7 @@ parser_yylex(struct parser_params *parser)
c = nextc();
quotation:
- if (!ISALNUM(c)) {
+ if (c == -1 || !ISALNUM(c)) {
term = c;
c = 'Q';
}
@@ -7401,7 +7401,7 @@ parser_yylex(struct parser_params *parser)
do {
tokadd(c);
c = nextc();
- } while (ISDIGIT(c));
+ } while (c != -1 && ISDIGIT(c));
pushback(c);
if (last_state == EXPR_FNAME) goto gvar;
tokfix();
@@ -7426,7 +7426,7 @@ parser_yylex(struct parser_params *parser)
tokadd('@');
c = nextc();
}
- if (ISDIGIT(c)) {
+ if (c != -1 && ISDIGIT(c)) {
if (tokidx == 1) {
compile_error(PARSER_ARG "`@%c' is not allowed as an instance variable name", c);
}