X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fstrtoimax.c;h=f7c20a4454b29a74505652255e52a990180503f9;hb=bc835ff38e3fb6a3d0f5ed6eed0981dde8884124;hp=dcdd1810c348ba825f6d4b8f87eb522c8820baff;hpb=82ff49b55425e14156a89f4d2ab4267409665f54;p=gnulib.git diff --git a/lib/strtoimax.c b/lib/strtoimax.c index dcdd1810c..f7c20a445 100644 --- a/lib/strtoimax.c +++ b/lib/strtoimax.c @@ -3,10 +3,10 @@ Copyright (C) 1999, 2001, 2002, 2003, 2004, 2006 Free Software Foundation, Inc. - This program is free software; you can redistribute it and/or modify + This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2, or (at your option) - any later version. + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -14,14 +14,11 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software Foundation, - Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ + along with this program. If not, see . */ /* Written by Paul Eggert. */ -#ifdef HAVE_CONFIG_H -# include -#endif +#include /* Verify interface. */ #include @@ -35,7 +32,7 @@ "this configure-time declaration test was not run" # endif # if !HAVE_DECL_STRTOULL && HAVE_UNSIGNED_LONG_LONG_INT -unsigned long long strtoull (char const *, char **, int); +unsigned long long int strtoull (char const *, char **, int); # endif #else @@ -43,33 +40,35 @@ 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_INT -long long strtoll (char const *, char **, int); +# if !HAVE_DECL_STRTOLL && HAVE_LONG_LONG_INT +long long int strtoll (char const *, char **, int); # endif #endif #ifdef UNSIGNED -# undef HAVE_LONG_LONG_INT -# define HAVE_LONG_LONG_INT HAVE_UNSIGNED_LONG_LONG_INT -# define INT uintmax_t +# define Have_long_long HAVE_UNSIGNED_LONG_LONG_INT +# define Int uintmax_t +# define Unsigned unsigned # define strtoimax strtoumax # define strtol strtoul # define strtoll strtoull #else -# define INT intmax_t +# define Have_long_long HAVE_LONG_LONG_INT +# define Int intmax_t +# define Unsigned #endif -INT +Int strtoimax (char const *ptr, char **endptr, int base) { -#if HAVE_LONG_LONG_INT - verify (sizeof (INT) == sizeof (long int) - || sizeof (INT) == sizeof (long long int)); +#if Have_long_long + verify (sizeof (Int) == sizeof (Unsigned long int) + || sizeof (Int) == sizeof (Unsigned long long int)); - if (sizeof (INT) != sizeof (long int)) + if (sizeof (Int) != sizeof (Unsigned long int)) return strtoll (ptr, endptr, base); #else - verify (sizeof (INT) == sizeof (long int)); + verify (sizeof (Int) == sizeof (Unsigned long int)); #endif return strtol (ptr, endptr, base);