Commit c215b29f by Joseph Myers Committed by Joseph Myers

c-lex.c (lex_number): If pedantic and not C99...

	* c-lex.c (lex_number): If pedantic and not C99, pedwarn exactly
	once for hexadecimal floats, whether or not they contain a decimal
	point.  Don't let the setting of pedantic otherwise affect the
	parsing of hexadecimal floats.

testsuite:
	* gcc.dg/c90-hexfloat-1.c: Add more tests.

From-SVN: r42440
parent a7bc0fbb
2001-05-22 Joseph S. Myers <jsm28@cam.ac.uk>
* c-lex.c (lex_number): If pedantic and not C99, pedwarn exactly
once for hexadecimal floats, whether or not they contain a decimal
point. Don't let the setting of pedantic otherwise affect the
parsing of hexadecimal floats.
2001-05-22 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at> 2001-05-22 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
* README.ACORN: Remove obsolete file. * README.ACORN: Remove obsolete file.
......
...@@ -1092,9 +1092,7 @@ lex_number (str, len) ...@@ -1092,9 +1092,7 @@ lex_number (str, len)
if (c == '.') if (c == '.')
{ {
if (base == 16 && pedantic && !flag_isoc99) if (floatflag == AFTER_POINT)
pedwarn ("floating constant may not be in radix 16");
else if (floatflag == AFTER_POINT)
ERROR ("too many decimal points in floating constant"); ERROR ("too many decimal points in floating constant");
else if (floatflag == AFTER_EXPON) else if (floatflag == AFTER_EXPON)
ERROR ("decimal point in exponent - impossible!"); ERROR ("decimal point in exponent - impossible!");
...@@ -1190,6 +1188,9 @@ lex_number (str, len) ...@@ -1190,6 +1188,9 @@ lex_number (str, len)
struct pf_args args; struct pf_args args;
char *copy; char *copy;
if (base == 16 && pedantic && !flag_isoc99)
pedwarn ("floating constant may not be in radix 16");
if (base == 16 && floatflag != AFTER_EXPON) if (base == 16 && floatflag != AFTER_EXPON)
ERROR ("hexadecimal floating constant has no exponent"); ERROR ("hexadecimal floating constant has no exponent");
......
2001-05-22 Joseph S. Myers <jsm28@cam.ac.uk>
* gcc.dg/c90-hexfloat-1.c: Add more tests.
2001-05-21 Geoff Keating <geoffk@redhat.com> 2001-05-21 Geoff Keating <geoffk@redhat.com>
* gcc.c-torture/compile/920520-1.x: Merge previous contents into * gcc.c-torture/compile/920520-1.x: Merge previous contents into
......
...@@ -5,3 +5,7 @@ ...@@ -5,3 +5,7 @@
double d = 0x1.2p2; /* { dg-bogus "warning" "warning in place of error" } */ double d = 0x1.2p2; /* { dg-bogus "warning" "warning in place of error" } */
/* { dg-error "radix 16" "hex float error" { target *-*-* } 6 } */ /* { dg-error "radix 16" "hex float error" { target *-*-* } 6 } */
double d1 = 0x1p2; /* { dg-bogus "warning" "warning in place of error" } */
/* { dg-error "radix 16" "hex float error" { target *-*-* } 8 } */
double d2 = 0x1...p2; /* { dg-bogus "warning" "warning in place of error" } */
/* { dg-error "too many decimal points" "bad hex float" { target *-*-* } 10 } */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment