Update.
authorUlrich Drepper <drepper@redhat.com>
Tue, 7 Aug 2001 04:37:18 +0000 (04:37 +0000)
committerUlrich Drepper <drepper@redhat.com>
Tue, 7 Aug 2001 04:37:18 +0000 (04:37 +0000)
2001-08-06  Jakub Jelinek  <jakub@redhat.com>

* stdlib/strtod.c (STRTOF): Skip whole infinity, not just inf.
* stdio-common/vfscanf.c (__vfscanf): +- can be followed by i in +-Inf.

* stdlib/tst-strtod.c (tests): Add Inf tests.
* stdio-common/tstscanf.c (main): Add tests for +- before Inf.

* locale/weightwc.h (findidx): Change type of i to int32_t.

ChangeLog
locale/weightwc.h
stdio-common/tstscanf.c
stdio-common/vfscanf.c
stdlib/strtod.c
stdlib/tst-strtod.c

index e68176c..ae45c3f 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,15 @@
+2001-08-06  Jakub Jelinek  <jakub@redhat.com>
+
+       * stdlib/strtod.c (STRTOF): Skip whole infinity, not just inf.
+       * stdio-common/vfscanf.c (__vfscanf): +- can be followed by i in +-Inf.
+
+       * stdlib/tst-strtod.c (tests): Add Inf tests.
+       * stdio-common/tstscanf.c (main): Add tests for +- before Inf.
+
 2001-08-06  Ulrich Drepper  <drepper@redhat.com>
 
+       * locale/weightwc.h (findidx): Change type of i to int32_t.
+
        * wcsmbs/wcsmbs-tst1.c (main): Avoid warning.  Pretty printing.
 
 2001-08-05  Roland McGrath  <roland@frob.com>
index 6a6f323..7eb7218 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996, 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
+/* Copyright (C) 1996-2000, 2001 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Written by Ulrich Drepper, <drepper@cygnus.com>.
 
@@ -21,7 +21,7 @@
 static inline int32_t
 findidx (const wint_t **cpp)
 {
-  int_fast32_t i;
+  int32_t i;
   const wint_t *cp;
   wint_t ch;
 
index dc02acc..44ddf49 100644 (file)
@@ -21,6 +21,7 @@
 #else
 #include <stdio.h>
 #endif
+#include <math.h>
 #include <stdlib.h>
 #include <string.h>
 
@@ -331,6 +332,25 @@ main (int argc, char **argv)
       }
   }
 
+  fputs ("Test 13:\n", stdout);
+  {
+    float value;
+    int res;
+
+    res = sscanf ("-InF", "%f", &value);
+    if (res != 1 || isinf (value) != -1)
+      {
+       fputs ("test failed!\n", stdout);
+       result = 1;
+      }
+
+    res = sscanf ("+InfiNiTY", "%f", &value);
+    if (res != 1 || isinf (value) != 1)
+      {
+       fputs ("test failed!\n", stdout);
+       result = 1;
+      }
+  }
 
   return result;
 }
index 9809ea3..aa0f091 100644 (file)
@@ -1604,7 +1604,7 @@ __vfscanf (FILE *s, const char *format, va_list argptr)
              if (width == 0 || inchar () == EOF)
                /* EOF is only an input error before we read any chars.  */
                conv_error ();
-             if (! ISDIGIT (c))
+             if (! ISDIGIT (c) && TOLOWER (c) != L_('i'))
                {
 #ifdef COMPILE_WSCANF
                  if (c != decimal)
index bcd284c..db09384 100644 (file)
@@ -573,15 +573,14 @@ INTERNAL (STRTOF) (nptr, endptr, group LOCALE_PARAM)
 #endif
   else if (c < L_('0') || c > L_('9'))
     {
-      int matched = 0;
       /* Check for `INF' or `INFINITY'.  */
-      if (TOLOWER (c) == L_('i')
-         && ((STRNCASECMP (cp, L_("inf"), 3) == 0 && (matched = 3))
-             || (STRNCASECMP (cp, L_("infinity"), 8) == 0 && (matched = 8))))
+      if (TOLOWER (c) == L_('i') && STRNCASECMP (cp, L_("inf"), 3) == 0)
        {
          /* Return +/- infinity.  */
          if (endptr != NULL)
-           *endptr = (STRING_TYPE *) (cp + matched);
+           *endptr = (STRING_TYPE *)
+                     (cp + (STRNCASECMP (cp + 3, L_("inity"), 5) == 0
+                            ? 8 : 3));
 
          return negative ? -FLOAT_HUGE_VAL : FLOAT_HUGE_VAL;
        }
index c466695..adf6255 100644 (file)
@@ -23,6 +23,7 @@
 #include <stdlib.h>
 #include <errno.h>
 #include <string.h>
+#include <math.h>
 
 struct ltest
   {
@@ -64,6 +65,9 @@ static const struct ltest tests[] =
     { "0x0.8p-1022",
       1.11253692925360069154511635866620203210960799023116591527666e-308,
       '\0', 0 },
+    { "Inf", HUGE_VAL, '\0', 0 },
+    { "-Inf", -HUGE_VAL, '\0', 0 },
+    { "+InFiNiTy", HUGE_VAL, '\0', 0 },
     { NULL, 0, '\0', 0 }
   };