X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fstrtoimax.c;h=f1828b11f145ffbf144087d52a4f716b75c6058b;hb=331f6ee713f7038d6d1a1c0451016c8aaab6a079;hp=43a690d24be1f8da514cbd31f1148bb57a6d347c;hpb=222b0486b7db1b09293e05512873d633440efcb3;p=gnulib.git diff --git a/lib/strtoimax.c b/lib/strtoimax.c index 43a690d24..f1828b11f 100644 --- a/lib/strtoimax.c +++ b/lib/strtoimax.c @@ -1,6 +1,6 @@ /* Convert string representation of a number into an intmax_t value. - Copyright (C) 1999, 2001, 2002, 2003, 2004 Free Software + Copyright (C) 1999, 2001, 2002, 2003, 2004, 2006 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify @@ -19,27 +19,20 @@ /* Written by Paul Eggert. */ -#ifdef HAVE_CONFIG_H -# include -#endif +#include -#if HAVE_INTTYPES_H -# include -#endif -#if HAVE_STDINT_H -# include -#endif +/* Verify interface. */ +#include #include -/* Verify a requirement at compile-time (unlike assert, which is runtime). */ -#define verify(name, assertion) struct name { char a[(assertion) ? 1 : -1]; } +#include "verify.h" #ifdef UNSIGNED # ifndef HAVE_DECL_STRTOULL "this configure-time declaration test was not run" # endif -# if !HAVE_DECL_STRTOULL && HAVE_UNSIGNED_LONG_LONG +# if !HAVE_DECL_STRTOULL && HAVE_UNSIGNED_LONG_LONG_INT unsigned long long strtoull (char const *, char **, int); # endif @@ -48,14 +41,14 @@ unsigned long long strtoull (char const *, char **, int); # ifndef HAVE_DECL_STRTOLL "this configure-time declaration test was not run" # endif -# if !HAVE_DECL_STRTOLL && HAVE_UNSIGNED_LONG_LONG +# if !HAVE_DECL_STRTOLL && HAVE_UNSIGNED_LONG_LONG_INT long long strtoll (char const *, char **, int); # endif #endif #ifdef UNSIGNED -# undef HAVE_LONG_LONG -# define HAVE_LONG_LONG HAVE_UNSIGNED_LONG_LONG +# undef HAVE_LONG_LONG_INT +# define HAVE_LONG_LONG_INT HAVE_UNSIGNED_LONG_LONG_INT # define INT uintmax_t # define strtoimax strtoumax # define strtol strtoul @@ -67,16 +60,14 @@ long long strtoll (char const *, char **, int); INT strtoimax (char const *ptr, char **endptr, int base) { -#if HAVE_LONG_LONG - verify (size_is_that_of_long_or_long_long, - (sizeof (INT) == sizeof (long int) - || sizeof (INT) == sizeof (long long int))); +#if HAVE_LONG_LONG_INT + verify (sizeof (INT) == sizeof (long int) + || sizeof (INT) == sizeof (long long int)); if (sizeof (INT) != sizeof (long int)) return strtoll (ptr, endptr, base); #else - verify (size_is_that_of_long, - sizeof (INT) == sizeof (long int)); + verify (sizeof (INT) == sizeof (long int)); #endif return strtol (ptr, endptr, base);