diff options
| author | Andrey A. Chernov <ache@FreeBSD.org> | 2001-12-07 16:33:47 +0000 | 
|---|---|---|
| committer | Andrey A. Chernov <ache@FreeBSD.org> | 2001-12-07 16:33:47 +0000 | 
| commit | f34b139cda7501c64f60f699c87a263197d3dd90 (patch) | |
| tree | 0ee33353ca59b5c4ce8509619edbc992775dbc25 /lib/libc/stdlib/strtoumax.c | |
| parent | 6cbb6156c3103066f1cbe21d8962068e71bee5a1 (diff) | |
Notes
Diffstat (limited to 'lib/libc/stdlib/strtoumax.c')
| -rw-r--r-- | lib/libc/stdlib/strtoumax.c | 22 | 
1 files changed, 12 insertions, 10 deletions
| diff --git a/lib/libc/stdlib/strtoumax.c b/lib/libc/stdlib/strtoumax.c index a2da67878f3b..3d34c3bc8e00 100644 --- a/lib/libc/stdlib/strtoumax.c +++ b/lib/libc/stdlib/strtoumax.c @@ -56,9 +56,9 @@ strtoumax(nptr, endptr, base)  {  	const char *s;  	uintmax_t acc; -	unsigned char c; +	char c;  	uintmax_t cutoff; -	int neg, any, cutlim, n; +	int neg, any, cutlim;  	/*  	 * See strtoimax for comments as to the logic used. @@ -66,7 +66,7 @@ strtoumax(nptr, endptr, base)  	s = nptr;  	do {  		c = *s++; -	} while (isspace(c)); +	} while (isspace((unsigned char)c));  	if (c == '-') {  		neg = 1;  		c = *s++; @@ -90,20 +90,22 @@ strtoumax(nptr, endptr, base)  	cutoff = UINTMAX_MAX / base;  	cutlim = UINTMAX_MAX % base;  	for ( ; ; c = *s++) { -		if (isxdigit(c)) -			n = digittoint(c); -		else if (isalpha(c)) -			n = (char)c - (isupper(c) ? 'A' - 10 : 'a' - 10); +		if (c >= '0' && c <= '9') +			c -= '0'; +		else if (c >= 'A' && c <= 'Z') +			c -= 'A' - 10; +		else if (c >= 'a' && c <= 'z') +			c -= 'a' - 10;  		else  			break; -		if (n < 0 || n >= base) +		if (c >= base)  			break; -		if (any < 0 || acc > cutoff || (acc == cutoff && n > cutlim)) +		if (any < 0 || acc > cutoff || (acc == cutoff && c > cutlim))  			any = -1;  		else {  			any = 1;  			acc *= base; -			acc += n; +			acc += c;  		}  	}  	if (any < 0) { | 
