fix incorrect overflow errors on strtoul, etc.

This commit is contained in:
Rich Felker 2011-09-05 22:23:06 -04:00
parent 5989dde345
commit 96cea94ad2
4 changed files with 20 additions and 8 deletions

View File

@ -5,8 +5,11 @@
unsigned long strtoul(const char *s, char **p, int base) unsigned long strtoul(const char *s, char **p, int base)
{ {
uintmax_t x = strtoumax(s, p, base); intmax_t x;
if (x > ULONG_MAX) { if (sizeof(intmax_t) == sizeof(long))
return strtoumax(s, p, base);
x = strtoimax(s, p, base);
if (-x > ULONG_MAX || x > ULONG_MAX) {
errno = ERANGE; errno = ERANGE;
return ULONG_MAX; return ULONG_MAX;
} }

View File

@ -5,8 +5,11 @@
unsigned long long strtoull(const char *s, char **p, int base) unsigned long long strtoull(const char *s, char **p, int base)
{ {
uintmax_t x = strtoumax(s, p, base); intmax_t x;
if (x > ULLONG_MAX) { if (sizeof(intmax_t) == sizeof(long long))
return strtoumax(s, p, base);
x = strtoimax(s, p, base);
if (-x > ULLONG_MAX || x > ULLONG_MAX) {
errno = ERANGE; errno = ERANGE;
return ULLONG_MAX; return ULLONG_MAX;
} }

View File

@ -6,8 +6,11 @@
unsigned long wcstoul(const wchar_t *s, wchar_t **p, int base) unsigned long wcstoul(const wchar_t *s, wchar_t **p, int base)
{ {
uintmax_t x = wcstoumax(s, p, base); intmax_t x;
if (x > ULONG_MAX) { if (sizeof(intmax_t) == sizeof(long))
return wcstoumax(s, p, base);
x = wcstoimax(s, p, base);
if (-x > ULONG_MAX || x > ULONG_MAX) {
errno = ERANGE; errno = ERANGE;
return ULONG_MAX; return ULONG_MAX;
} }

View File

@ -6,8 +6,11 @@
unsigned long long wcstoull(const wchar_t *s, wchar_t **p, int base) unsigned long long wcstoull(const wchar_t *s, wchar_t **p, int base)
{ {
uintmax_t x = wcstoumax(s, p, base); intmax_t x;
if (x > ULLONG_MAX) { if (sizeof(intmax_t) == sizeof(long long))
return wcstoumax(s, p, base);
x = wcstoimax(s, p, base);
if (-x > ULLONG_MAX || x > ULLONG_MAX) {
errno = ERANGE; errno = ERANGE;
return ULLONG_MAX; return ULLONG_MAX;
} }