unify strtof/strtod/strtold wrappers and fix initial whitespace issue
authorRich Felker <dalias@aerifal.cx>
Wed, 11 Apr 2012 00:25:06 +0000 (20:25 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 11 Apr 2012 00:25:06 +0000 (20:25 -0400)
src/stdlib/strtod.c
src/stdlib/strtof.c [deleted file]
src/stdlib/strtold.c [deleted file]

index 98b992a..b444f53 100644 (file)
@@ -2,14 +2,31 @@
 #include "floatscan.h"
 #include "stdio_impl.h"
 
-double strtod(const char *s, char **p)
+static long double strtox(const char *s, char **p, int prec)
 {
+       char *t = (char *)s;
+       while (isspace(*t)) t++;
        FILE f = {
-               .buf = (void *)s, .rpos = (void *)s,
+               .buf = (void *)t, .rpos = (void *)t,
                .rend = (void *)-1, .lock = -1
        };
        off_t cnt;
-       double y = __floatscan(&f, -1, 1, 1, &cnt);
-       if (p) *p = (char *)s + cnt;
+       long double y = __floatscan(&f, -1, prec, 1, &cnt);
+       if (p) *p = cnt ? t + cnt : (char *)s;
        return y;
 }
+
+float strtof(const char *s, char **p)
+{
+       return strtox(s, p, 0);
+}
+
+double strtod(const char *s, char **p)
+{
+       return strtox(s, p, 1);
+}
+
+long double strtold(const char *s, char **p)
+{
+       return strtox(s, p, 2);
+}
diff --git a/src/stdlib/strtof.c b/src/stdlib/strtof.c
deleted file mode 100644 (file)
index 2dc349a..0000000
+++ /dev/null
@@ -1,15 +0,0 @@
-#include <stdlib.h>
-#include "floatscan.h"
-#include "stdio_impl.h"
-
-float strtof(const char *s, char **p)
-{
-       FILE f = {
-               .buf = (void *)s, .rpos = (void *)s,
-               .rend = (void *)-1, .lock = -1
-       };
-       off_t cnt;
-       float y = __floatscan(&f, -1, 0, 1, &cnt);
-       if (p) *p = (char *)s + cnt;
-       return y;
-}
diff --git a/src/stdlib/strtold.c b/src/stdlib/strtold.c
deleted file mode 100644 (file)
index 40ecc12..0000000
+++ /dev/null
@@ -1,15 +0,0 @@
-#include <stdlib.h>
-#include "floatscan.h"
-#include "stdio_impl.h"
-
-long double strtold(const char *s, char **p)
-{
-       FILE f = {
-               .buf = (void *)s, .rpos = (void *)s,
-               .rend = (void *)-1, .lock = -1
-       };
-       off_t cnt;
-       long double y = __floatscan(&f, -1, 2, 1, &cnt);
-       if (p) *p = (char *)s + cnt;
-       return y;
-}