remove a fixme comment
[musl] / src / stdlib / wcstoumax.c
index e30b063..cee5ff7 100644 (file)
@@ -7,8 +7,8 @@
 
 uintmax_t wcstoumax(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;
 
@@ -20,14 +20,14 @@ uintmax_t wcstoumax(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 UINTMAX_MAX;
        }