c-lex.c (lex_number): If pedantic and not C99...
authorJoseph Myers <jsm28@cam.ac.uk>
Tue, 22 May 2001 11:02:17 +0000 (12:02 +0100)
committerJoseph Myers <jsm28@gcc.gnu.org>
Tue, 22 May 2001 11:02:17 +0000 (12:02 +0100)
* 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

gcc/ChangeLog
gcc/c-lex.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/c90-hexfloat-1.c

index d21080bc93f7e815e3c0f1720a2aa1314a56c280..b9eeac7cf93878862afbae634b799595b0ae87f6 100644 (file)
@@ -1,3 +1,10 @@
+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.
index 914da81cd92bb3a5f68b0ce8f8670b855703f835..37d175a4c62205ac4abd893b7fff22ba48297412 100644 (file)
@@ -1092,9 +1092,7 @@ lex_number (str, len)
 
       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!");
@@ -1190,6 +1188,9 @@ lex_number (str, len)
       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");
 
index 661d5ea2ba03382ceebb3b6d092c1b0d5c3739df..e7247cf5aa6f8004503e44fa632365d679393431 100644 (file)
@@ -1,3 +1,7 @@
+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
index 9139677cad35a37c4d13be7d2b545294c2169117..122d5ee5e719ee1f4737fa9e781fba2e46a9136c 100644 (file)
@@ -5,3 +5,7 @@
 
 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 } */