X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fstdlib%2Fstrtod.c;h=461dcf858e0c3acadf9754c56c8ec4c9af052a8c;hb=c243d6f09570010a448789dd296b14b7a61cb2ea;hp=388058fe630d1fed46d4656f0e29fedf5b3dd2fb;hpb=0b44a0315b47dd8eced9f3b7f31580cf14bbfc01;p=musl diff --git a/src/stdlib/strtod.c b/src/stdlib/strtod.c index 388058fe..461dcf85 100644 --- a/src/stdlib/strtod.c +++ b/src/stdlib/strtod.c @@ -1,6 +1,40 @@ #include +#include "shgetc.h" +#include "floatscan.h" +#include "stdio_impl.h" +#include "libc.h" -double strtod(const char *s, char **p) +static long double strtox(const char *s, char **p, int prec) { - return strtold(s, p); + FILE f = { + .buf = (void *)s, .rpos = (void *)s, + .rend = (void *)-1, .lock = -1 + }; + shlim(&f, 0); + long double y = __floatscan(&f, prec, 1); + off_t cnt = shcnt(&f); + if (p) *p = cnt ? (char *)s + cnt : (char *)s; + return y; } + +float strtof(const char *restrict s, char **restrict p) +{ + return strtox(s, p, 0); +} + +double strtod(const char *restrict s, char **restrict p) +{ + return strtox(s, p, 1); +} + +long double strtold(const char *restrict s, char **restrict p) +{ + return strtox(s, p, 2); +} + +weak_alias(strtof, strtof_l); +weak_alias(strtod, strtod_l); +weak_alias(strtold, strtold_l); +weak_alias(strtof, __strtof_l); +weak_alias(strtod, __strtod_l); +weak_alias(strtold, __strtold_l);