diff options
author | Richard Kenner <kenner@gcc.gnu.org> | 1995-12-28 07:21:45 -0500 |
---|---|---|
committer | Richard Kenner <kenner@gcc.gnu.org> | 1995-12-28 07:21:45 -0500 |
commit | 91b0989ef6b76a65e56a59420aa9a85a5bfa5ba5 (patch) | |
tree | 48640af19b4a94b0ad8caa83de0ab31c501db18a /gcc | |
parent | 70ce27baada6cf22edc3f1971b57d088e5824557 (diff) | |
download | gcc-91b0989ef6b76a65e56a59420aa9a85a5bfa5ba5.zip gcc-91b0989ef6b76a65e56a59420aa9a85a5bfa5ba5.tar.gz gcc-91b0989ef6b76a65e56a59420aa9a85a5bfa5ba5.tar.bz2 |
(yylex): Improve error message for bogus numbers.
Consolidate duplicated code.
From-SVN: r10892
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/c-lex.c | 49 |
1 files changed, 10 insertions, 39 deletions
diff --git a/gcc/c-lex.c b/gcc/c-lex.c index edb7075..210c365 100644 --- a/gcc/c-lex.c +++ b/gcc/c-lex.c @@ -1282,7 +1282,7 @@ yylex () if (floatflag != NOT_FLOAT) { tree type = double_type_node; - int garbage_chars = 0, exceeds_double = 0; + int exceeds_double = 0; int imag = 0; REAL_VALUE_TYPE value; jmp_buf handler; @@ -1418,19 +1418,6 @@ yylex () } } #endif - garbage_chars = 0; - while (isalnum (c) || c == '.' || c == '_' - || (!flag_traditional && (c == '+' || c == '-') - && (p[-1] == 'e' || p[-1] == 'E'))) - { - if (p >= token_buffer + maxtoken - 3) - p = extend_token_buffer (p); - *p++ = c; - c = getc (finput); - garbage_chars++; - } - if (garbage_chars > 0) - error ("garbage at end of number"); /* If the result is not a number, assume it must have been due to some error message above, so silently convert @@ -1444,9 +1431,6 @@ yylex () build_real (type, value)); else yylval.ttype = build_real (type, value); - - ungetc (c, finput); - *p = 0; } else { @@ -1487,32 +1471,13 @@ yylex () spec_imag = 1; } else - { - if (isalnum (c) || c == '.' || c == '_' - || (!flag_traditional && (c == '+' || c == '-') - && (p[-1] == 'e' || p[-1] == 'E'))) - { - error ("garbage at end of number"); - while (isalnum (c) || c == '.' || c == '_' - || (!flag_traditional && (c == '+' || c == '-') - && (p[-1] == 'e' || p[-1] == 'E'))) - { - if (p >= token_buffer + maxtoken - 3) - p = extend_token_buffer (p); - *p++ = c; - c = getc (finput); - } - } - break; - } + break; if (p >= token_buffer + maxtoken - 3) p = extend_token_buffer (p); *p++ = c; c = getc (finput); } - ungetc (c, finput); - /* If the constant is not long long and it won't fit in an unsigned long, or if the constant is long long and won't fit in an unsigned long long, then warn that the constant is out @@ -1648,10 +1613,16 @@ yylex () } else TREE_TYPE (yylval.ttype) = type; - - *p = 0; } + ungetc (c, finput); + *p = 0; + + if (isalnum (c) || c == '.' || c == '_' + || (!flag_traditional && (c == '-' || c == '+') + && (p[-1] == 'e' || p[-1] == 'E'))) + error ("missing white space after number `%s'", token_buffer); + value = CONSTANT; break; } |