+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>
* README.ACORN: Remove obsolete file.
if (c == '.')
{
- if (base == 16 && pedantic && !flag_isoc99)
- pedwarn ("floating constant may not be in radix 16");
- else if (floatflag == AFTER_POINT)
+ if (floatflag == AFTER_POINT)
ERROR ("too many decimal points in floating constant");
else if (floatflag == AFTER_EXPON)
ERROR ("decimal point in exponent - impossible!");
struct pf_args args;
char *copy;
+ if (base == 16 && pedantic && !flag_isoc99)
+ pedwarn ("floating constant may not be in radix 16");
+
if (base == 16 && floatflag != AFTER_EXPON)
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>
* gcc.c-torture/compile/920520-1.x: Merge previous contents into
double d = 0x1.2p2; /* { dg-bogus "warning" "warning in place of error" } */
/* { 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 } */