summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
26d4bfa)
(strtoimax): Use sizeof (long), not sizeof strtol (ptr, endptr, base),
to work around bug in IBM C compiler.
+# undef HAVE_LONG_LONG
+# define HAVE_LONG_LONG HAVE_UNSIGNED_LONG_LONG
# define INT uintmax_t
# define strtoimax strtoumax
# define strtol strtoul
# define INT uintmax_t
# define strtoimax strtoumax
# define strtol strtoul
INT
strtoimax (char const *ptr, char **endptr, int base)
{
INT
strtoimax (char const *ptr, char **endptr, int base)
{
-#if HAVE_UNSIGNED_LONG_LONG
verify (size_is_that_of_long_or_long_long,
verify (size_is_that_of_long_or_long_long,
- (sizeof (INT) == sizeof strtol (ptr, endptr, base)
- || sizeof (INT) == sizeof strtoll (ptr, endptr, base)));
+ (sizeof (INT) == sizeof (long)
+ || sizeof (INT) == sizeof (long long)));
- if (sizeof (INT) != sizeof strtol (ptr, endptr, base))
+ if (sizeof (INT) != sizeof (long))
return strtoll (ptr, endptr, base);
#else
verify (size_is_that_of_long,
return strtoll (ptr, endptr, base);
#else
verify (size_is_that_of_long,
- sizeof (INT) == sizeof strtol (ptr, endptr, base));
+ sizeof (INT) == sizeof (long));
#endif
return strtol (ptr, endptr, base);
#endif
return strtol (ptr, endptr, base);