diff options
author | ache <ache@FreeBSD.org> | 2001-11-28 00:48:11 +0000 |
---|---|---|
committer | ache <ache@FreeBSD.org> | 2001-11-28 00:48:11 +0000 |
commit | 950bfdf509d69b5c71a77c19ecb6ea5be2336016 (patch) | |
tree | 39609fa880161cf047c27ac96bdf1f70f43a0e14 /lib/libc/stdlib/strtoul.c | |
parent | c5c274cf2c1c3f51f2c5da3acf04d8098f3e2784 (diff) | |
download | FreeBSD-src-950bfdf509d69b5c71a77c19ecb6ea5be2336016.zip FreeBSD-src-950bfdf509d69b5c71a77c19ecb6ea5be2336016.tar.gz |
Understand national (non-ASCII) digits now
Allow bases >=36 again
Misc cleanup
Diffstat (limited to 'lib/libc/stdlib/strtoul.c')
-rw-r--r-- | lib/libc/stdlib/strtoul.c | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/lib/libc/stdlib/strtoul.c b/lib/libc/stdlib/strtoul.c index 1f23368..e952663 100644 --- a/lib/libc/stdlib/strtoul.c +++ b/lib/libc/stdlib/strtoul.c @@ -52,13 +52,13 @@ unsigned long strtoul(nptr, endptr, base) const char *nptr; char **endptr; - register int base; + int base; { - register const char *s; - register unsigned long acc; - register unsigned char c; - register unsigned long cutoff; - register int neg, any, cutlim; + const char *s; + unsigned long acc; + unsigned char c; + unsigned long cutoff; + int neg, any, cutlim; /* * See strtol for comments as to the logic used. @@ -84,17 +84,15 @@ strtoul(nptr, endptr, base) if (base == 0) base = c == '0' ? 8 : 10; acc = any = 0; - if (base < 2 || base > 36) + if (base < 2) goto noconv; cutoff = ULONG_MAX / base; cutlim = ULONG_MAX % base; for ( ; ; c = *s++) { - if (!isascii(c)) - break; - if (isdigit(c)) - c -= '0'; - else if (isalpha(c)) + if (isxdigit(c)) + c = digittoint(c); + else if (isascii(c) && isalpha(c)) c -= isupper(c) ? 'A' - 10 : 'a' - 10; else break; |