X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fstdlib%2Fwcstoimax.c;h=344fe3a3232e939eacdce33a4abb7db018f216a8;hb=f4ad36c4bf23899a3164ebd40ff5781c152bcb01;hp=b83206b7b562bb8125501344a9ba81cdd74f1491;hpb=ecc9c5fcfa4831b290cc1a63c0346cbb0c1fcf42;p=musl diff --git a/src/stdlib/wcstoimax.c b/src/stdlib/wcstoimax.c index b83206b7..344fe3a3 100644 --- a/src/stdlib/wcstoimax.c +++ b/src/stdlib/wcstoimax.c @@ -6,8 +6,8 @@ intmax_t wcstoimax(const wchar_t *s, wchar_t **p, int base) { + const wchar_t *s1 = s; struct intparse ip = {0}; - unsigned char tmp; if (p) *p = (wchar_t *)s; @@ -19,14 +19,14 @@ intmax_t wcstoimax(const wchar_t *s, wchar_t **p, int base) for (; iswspace(*s); s++); ip.base = base; - for (; *s<256 && (tmp=*s, __intparse(&ip, &tmp, 1)); s++); + for (; __intparse(&ip, (char[]){(*s&-(*s<128U))}, 1); s++); if (p && ip.err != EINVAL) - *p = (wchar_t *)s; + *p = (wchar_t *)s1 + ip.cnt; if (ip.err) { errno = ip.err; - if (ip.err = EINVAL) return 0; + if (ip.err == EINVAL) return 0; return ip.neg ? INTMAX_MIN : INTMAX_MAX; }