strtod: fix const diagnostic
authorPaul Eggert <eggert@cs.ucla.edu>
Tue, 10 Aug 2010 17:39:30 +0000 (10:39 -0700)
committerPaul Eggert <eggert@cs.ucla.edu>
Tue, 10 Aug 2010 17:40:17 +0000 (10:40 -0700)
* lib/strtod.c (strtod): Don't assign const char * to char *,
as this elicits a warning from GCC when warnings are enabled.

ChangeLog
lib/strtod.c

index dffc9ed..b6e8887 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2010-08-10  Paul Eggert  <eggert@cs.ucla.edu>
+
+       strtod: fix const diagnostic
+       * lib/strtod.c (strtod): Don't assign const char * to char *,
+       as this elicits a warning from GCC when warnings are enabled.
+
 2010-08-10  Pádraig Brady <P@draigbrady.com>
        and Eric Blake  <eblake@redhat.com>
 
index 94eb817..64b62ff 100644 (file)
@@ -200,7 +200,8 @@ strtod (const char *nptr, char **endptr)
   double num;
 
   const char *s = nptr;
-  char *end;
+  const char *end;
+  char *endbuf;
 
   /* Eat whitespace.  */
   while (locale_isspace (*s))
@@ -211,7 +212,8 @@ strtod (const char *nptr, char **endptr)
   if (*s == '-' || *s == '+')
     ++s;
 
-  num = underlying_strtod (s, &end);
+  num = underlying_strtod (s, &endbuf);
+  end = endbuf;
 
   if (c_isdigit (s[*s == '.']))
     {
@@ -224,7 +226,10 @@ strtod (const char *nptr, char **endptr)
           if (! c_isxdigit (s[2 + (s[2] == '.')]))
             end = s + 1;
           else if (end <= s + 2)
-            num = parse_number (s + 2, 16, 2, 4, 'p', &end);
+            {
+              num = parse_number (s + 2, 16, 2, 4, 'p', &endbuf);
+              end = endbuf;
+            }
           else
             {
               const char *p = s + 2;