diff options
-rw-r--r-- | ChangeLog | 10 | ||||
-rw-r--r-- | locale/weightwc.h | 4 | ||||
-rw-r--r-- | stdio-common/tstscanf.c | 20 | ||||
-rw-r--r-- | stdio-common/vfscanf.c | 2 | ||||
-rw-r--r-- | stdlib/strtod.c | 9 | ||||
-rw-r--r-- | stdlib/tst-strtod.c | 4 |
6 files changed, 41 insertions, 8 deletions
diff --git a/ChangeLog b/ChangeLog index e68176cfdf..ae45c3ffbd 100644 --- 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> diff --git a/locale/weightwc.h b/locale/weightwc.h index 6a6f323b32..7eb72187f6 100644 --- a/locale/weightwc.h +++ b/locale/weightwc.h @@ -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; diff --git a/stdio-common/tstscanf.c b/stdio-common/tstscanf.c index dc02acc4a1..44ddf49e15 100644 --- a/stdio-common/tstscanf.c +++ b/stdio-common/tstscanf.c @@ -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; } diff --git a/stdio-common/vfscanf.c b/stdio-common/vfscanf.c index 9809ea33a8..aa0f091c06 100644 --- a/stdio-common/vfscanf.c +++ b/stdio-common/vfscanf.c @@ -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) diff --git a/stdlib/strtod.c b/stdlib/strtod.c index bcd284c54c..db0938404c 100644 --- a/stdlib/strtod.c +++ b/stdlib/strtod.c @@ -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; } diff --git a/stdlib/tst-strtod.c b/stdlib/tst-strtod.c index c466695d2f..adf6255f66 100644 --- a/stdlib/tst-strtod.c +++ b/stdlib/tst-strtod.c @@ -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 } }; |