projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix missing argument in variadic syscall macros
[musl]
/
src
/
stdlib
/
strtod.c
diff --git
a/src/stdlib/strtod.c
b/src/stdlib/strtod.c
index
ecfabdf
..
c6f89e7
100644
(file)
--- a/
src/stdlib/strtod.c
+++ b/
src/stdlib/strtod.c
@@
-5,30
+5,28
@@
static long double strtox(const char *s, char **p, int prec)
{
static long double strtox(const char *s, char **p, int prec)
{
- char *t = (char *)s;
- while (isspace(*t)) t++;
FILE f = {
FILE f = {
- .buf = (void *)
t, .rpos = (void *)t
,
+ .buf = (void *)
s, .rpos = (void *)s
,
.rend = (void *)-1, .lock = -1
};
shlim(&f, 0);
.rend = (void *)-1, .lock = -1
};
shlim(&f, 0);
- long double y = __floatscan(&f,
-1,
prec, 1);
+ long double y = __floatscan(&f, prec, 1);
off_t cnt = shcnt(&f);
off_t cnt = shcnt(&f);
- if (p) *p = cnt ?
t
+ cnt : (char *)s;
+ if (p) *p = cnt ?
(char *)s
+ cnt : (char *)s;
return y;
}
return y;
}
-float strtof(const char *
s, char **
p)
+float strtof(const char *
restrict s, char **restrict
p)
{
return strtox(s, p, 0);
}
{
return strtox(s, p, 0);
}
-double strtod(const char *
s, char **
p)
+double strtod(const char *
restrict s, char **restrict
p)
{
return strtox(s, p, 1);
}
{
return strtox(s, p, 1);
}
-long double strtold(const char *
s, char **
p)
+long double strtold(const char *
restrict s, char **restrict
p)
{
return strtox(s, p, 2);
}
{
return strtox(s, p, 2);
}