fix wcsto[iu]max with high characters
authorRich Felker <dalias@aerifal.cx>
Thu, 14 Jul 2011 05:12:05 +0000 (01:12 -0400)
committerRich Felker <dalias@aerifal.cx>
Thu, 14 Jul 2011 05:12:05 +0000 (01:12 -0400)
stopping without letting the parser see a stop character prevented
getting a result. so treat all high chars as the null character and
pass them into the parser.

also eliminated ugly tmp var using compound literals.

src/stdlib/wcstoimax.c
src/stdlib/wcstoumax.c

index b83206b..50647f6 100644 (file)
@@ -7,7 +7,6 @@
 intmax_t wcstoimax(const wchar_t *s, wchar_t **p, int base)
 {
        struct intparse ip = {0};
-       unsigned char tmp;
 
        if (p) *p = (wchar_t *)s;
 
@@ -19,7 +18,7 @@ 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;
index e30b063..af7ba3d 100644 (file)
@@ -8,7 +8,6 @@
 uintmax_t wcstoumax(const wchar_t *s, wchar_t **p, int base)
 {
        struct intparse ip = {0};
-       unsigned char tmp;
 
        if (p) *p = (wchar_t *)s;
 
@@ -20,7 +19,7 @@ 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;