further fixes to leading space issue (forgot the wide versions)

This commit is contained in:
Rich Felker 2012-04-19 12:56:29 -04:00
parent cb81b6947c
commit 1bf725eda7
2 changed files with 9 additions and 5 deletions

View File

@ -39,9 +39,11 @@ static long double wcstox(const wchar_t *s, wchar_t **p, int prec)
while (iswspace(*t)) t++; while (iswspace(*t)) t++;
f.cookie = (void *)t; f.cookie = (void *)t;
shlim(&f, 0); shlim(&f, 0);
long double y = __floatscan(&f, -1, prec, 1); long double y = __floatscan(&f, prec, 1);
off_t cnt = shcnt(&f); if (p) {
if (p) *p = cnt ? t + cnt : (wchar_t *)s; size_t cnt = shcnt(&f);
*p = cnt ? t + cnt : (wchar_t *)s;
}
return y; return y;
} }

View File

@ -27,6 +27,7 @@ static size_t do_read(FILE *f, unsigned char *buf, size_t len)
static unsigned long long wcstox(const wchar_t *s, wchar_t **p, int base, unsigned long long lim) static unsigned long long wcstox(const wchar_t *s, wchar_t **p, int base, unsigned long long lim)
{ {
wchar_t *t = (wchar_t *)s;
unsigned char buf[64]; unsigned char buf[64];
FILE f = {0}; FILE f = {0};
f.flags = 0; f.flags = 0;
@ -35,12 +36,13 @@ static unsigned long long wcstox(const wchar_t *s, wchar_t **p, int base, unsign
f.buf_size = sizeof buf - 4; f.buf_size = sizeof buf - 4;
f.lock = -1; f.lock = -1;
f.read = do_read; f.read = do_read;
f.cookie = (void *)s; while (iswspace(*t)) t++;
f.cookie = (void *)t;
shlim(&f, 0); shlim(&f, 0);
unsigned long long y = __intscan(&f, base, 1, lim); unsigned long long y = __intscan(&f, base, 1, lim);
if (p) { if (p) {
size_t cnt = shcnt(&f); size_t cnt = shcnt(&f);
*p = (wchar_t *)s + cnt; *p = cnt ? t + cnt : (wchar_t *)s;
} }
return y; return y;
} }