Resolve clash between stdint.m4 and uintmax_t.m4.
[gnulib.git] / lib / stdint_.h
index b5a56d2..9e0faab 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2001-2002, 2004-2005 Free Software Foundation, Inc.
+/* Copyright (C) 2001-2002, 2004-2006 Free Software Foundation, Inc.
    Written by Bruno Haible, Sam Steingold, Peter Burwood.
    This file is part of gnulib.
 
    Written by Bruno Haible, Sam Steingold, Peter Burwood.
    This file is part of gnulib.
 
 
 /*
  * ISO C 99 <stdint.h> for platforms that lack it.
 
 /*
  * ISO C 99 <stdint.h> for platforms that lack it.
- * <http://www.opengroup.org/onlinepubs/007904975/basedefs/stdint.h.html>
+ * <http://www.opengroup.org/susv3xbd/stdint.h.html>
  */
 
 /* Get wchar_t, WCHAR_MIN, WCHAR_MAX.  */
 #include <stddef.h>
  */
 
 /* Get wchar_t, WCHAR_MIN, WCHAR_MAX.  */
 #include <stddef.h>
-/* Get CHAR_BIT, LONG_MIN, LONG_MAX, ULONG_MAX.  */
+/* BSD/OS 4.2 defines WCHAR_MIN, WCHAR_MAX in <wchar.h>, not <stddef.h>.  */
+#if !(defined(WCHAR_MIN) && defined(WCHAR_MAX)) && @HAVE_WCHAR_H@
+# include <wchar.h>
+#endif
+
+/* Get LONG_MIN, LONG_MAX, ULONG_MAX.  */
 #include <limits.h>
 
 /* Get those types that are already defined in other system include files.  */
 #include <limits.h>
 
 /* Get those types that are already defined in other system include files.  */
-#if defined(__FreeBSD__)
+#if defined(__FreeBSD__) && (__FreeBSD__ >= 3) && (__FreeBSD__ <= 4)
 # include <sys/inttypes.h>
 #endif
 # include <sys/inttypes.h>
 #endif
-#if defined(__sun) && HAVE_SYS_INTTYPES_H
-# include <sys/inttypes.h>
+#if defined(__OpenBSD__) || defined(__bsdi__) || defined(__sgi)
+  /* In OpenBSD 3.8, <sys/types.h> includes <machine/types.h>, which defines
+     int{8,16,32,64}_t, uint{8,16,32,64}_t and __BIT_TYPES_DEFINED__.
+     <inttypes.h> includes <machine/types.h> and also defines intptr_t and
+     uintptr_t.  */
+  /* BSD/OS 4.2 is similar, but doesn't have <inttypes.h> */
+  /* IRIX 6.5 has <inttypes.h>, and <sys/types.h> defines some of these
+     types as well.  */
+# include <sys/types.h>
+# if @HAVE_INTTYPES_H@
+#  include @FULL_PATH_INTTYPES_H@
+# endif
+#endif
+#if defined(__linux__) && @HAVE_SYS_BITYPES_H@
+  /* Linux libc4 >= 4.6.7 and libc5 have a <sys/bitypes.h> that defines
+     int{8,16,32,64}_t and __BIT_TYPES_DEFINED__.  In libc5 >= 5.2.2 it is
+     included by <sys/types.h>.  */
+# include <sys/bitypes.h>
+#endif
+#if defined(__sun) && @HAVE_SYS_INTTYPES_H@
   /* Solaris 7 <sys/inttypes.h> has the types except the *_fast*_t types, and
      the macros except for *_FAST*_*, INTPTR_MIN, PTRDIFF_MIN, PTRDIFF_MAX.
      But note that <sys/int_types.h> contains only the type definitions!  */
   /* Solaris 7 <sys/inttypes.h> has the types except the *_fast*_t types, and
      the macros except for *_FAST*_*, INTPTR_MIN, PTRDIFF_MIN, PTRDIFF_MAX.
      But note that <sys/int_types.h> contains only the type definitions!  */
-# define HAVE_SYSTEM_INTTYPES
+# include <sys/inttypes.h>
 #endif
 #endif
-#if (defined(__hpux) || defined(_AIX)) && HAVE_INTTYPES_H
-# include <inttypes.h>
+#if (defined(__hpux) || defined(_AIX)) && @HAVE_INTTYPES_H@
   /* HP-UX 10 <inttypes.h> has nearly everything, except UINT_LEAST8_MAX,
      UINT_FAST8_MAX, PTRDIFF_MIN, PTRDIFF_MAX.  */
   /* AIX 4 <inttypes.h> has nearly everything, except INTPTR_MIN, INTPTR_MAX,
      UINTPTR_MAX, PTRDIFF_MIN, PTRDIFF_MAX.  */
   /* HP-UX 10 <inttypes.h> has nearly everything, except UINT_LEAST8_MAX,
      UINT_FAST8_MAX, PTRDIFF_MIN, PTRDIFF_MAX.  */
   /* AIX 4 <inttypes.h> has nearly everything, except INTPTR_MIN, INTPTR_MAX,
      UINTPTR_MAX, PTRDIFF_MIN, PTRDIFF_MAX.  */
-# define HAVE_SYSTEM_INTTYPES
+# include @FULL_PATH_INTTYPES_H@
 #endif
 #endif
-#if !(defined(UNIX_CYGWIN32) && defined(__BIT_TYPES_DEFINED__))
-# define NEED_SIGNED_INT_TYPES
+#if @HAVE_STDINT_H@
+  /* Other systems may have an incomplete <stdint.h>.  */
+  /* On some versions of IRIX, the SGI C compiler comes with an <stdint.h>,
+     but
+       - in c99 mode, <inttypes.h> includes <stdint.h>,
+       - in c89 mode, <stdint.h> spews warnings and defines nothing.
+         <inttypes.h> defines only a subset of the types and macros that
+         <stdint.h> would define in c99 mode.
+     So we rely only on <inttypes.h> (included above).  It means that in
+     c89 mode, we shadow the contents of warning-spewing <stdint.h>.  */
+# if !(defined(__sgi) && @HAVE_INTTYPES_H@ && !defined(__c99))
+#  include @FULL_PATH_STDINT_H@
+# endif
 #endif
 
 #endif
 
-#if !defined(HAVE_SYSTEM_INTTYPES)
-
 /* 7.18.1.1. Exact-width integer types */
 
 /* 7.18.1.1. Exact-width integer types */
 
-#if !defined(__FreeBSD__)
+/* Here we assume a standard architecture where the hardware integer
+   types have 8, 16, 32, optionally 64 bits.  */
 
 
-#ifdef NEED_SIGNED_INT_TYPES
+#if !@HAVE_INT8_T@
 typedef signed char    int8_t;
 #endif
 typedef signed char    int8_t;
 #endif
+#if !@HAVE_UINT8_T@
 typedef unsigned char  uint8_t;
 typedef unsigned char  uint8_t;
+# define _UINT8_T /* avoid collision with Solaris 2.5.1 <pthread.h> */
+#endif
 
 
-#ifdef NEED_SIGNED_INT_TYPES
+#if !@HAVE_INT16_T@
 typedef short          int16_t;
 #endif
 typedef short          int16_t;
 #endif
+#if !@HAVE_UINT16_T@
 typedef unsigned short uint16_t;
 typedef unsigned short uint16_t;
+#endif
 
 
-#ifdef NEED_SIGNED_INT_TYPES
+#if !@HAVE_INT32_T@
 typedef int            int32_t;
 #endif
 typedef int            int32_t;
 #endif
+#if !@HAVE_UINT32_T@
 typedef unsigned int   uint32_t;
 typedef unsigned int   uint32_t;
+# define _UINT32_T /* avoid collision with Solaris 2.5.1 <pthread.h> */
+#endif
 
 
-#if @HAVE_LONG_64BIT@
-#ifdef NEED_SIGNED_INT_TYPES
+#if @HAVE_INT64_T@
+# define _STDINT_H_HAVE_INT64 1
+#else
+# if @HAVE_LONG_64BIT@
 typedef long           int64_t;
 typedef long           int64_t;
+#  define _STDINT_H_HAVE_INT64 1
+# elif @HAVE_LONG_LONG_64BIT@
+typedef long long      int64_t;
+#  define _STDINT_H_HAVE_INT64 1
+# elif defined _MSC_VER
+typedef __int64        int64_t;
+#  define _STDINT_H_HAVE_INT64 1
+# endif
 #endif
 #endif
-typedef unsigned long  uint64_t;
-#elif @HAVE_LONG_LONG_64BIT@
-#ifdef NEED_SIGNED_INT_TYPES
-typedef long long          int64_t;
-#endif
+#if @HAVE_UINT64_T@
+# define _STDINT_H_HAVE_UINT64 1
+#else
+# if @HAVE_LONG_64BIT@
+typedef unsigned long      uint64_t;
+#  define _STDINT_H_HAVE_UINT64 1
+# elif @HAVE_LONG_LONG_64BIT@
 typedef unsigned long long uint64_t;
 typedef unsigned long long uint64_t;
+#  define _UINT64_T /* avoid collision with Solaris 2.5.1 <pthread.h> */
+#  define _STDINT_H_HAVE_UINT64 1
+# elif defined _MSC_VER
+typedef unsigned __int64   uint64_t;
+#  define _STDINT_H_HAVE_UINT64 1
+# endif
 #endif
 
 #endif
 
-#endif /* !FreeBSD */
-
 /* 7.18.1.2. Minimum-width integer types */
 
 /* 7.18.1.2. Minimum-width integer types */
 
+/* Here we assume a standard architecture where the hardware integer
+   types have 8, 16, 32, optionally 64 bits. Therefore the leastN_t types
+   are the same as the corresponding N_t types.  */
+
+#if !@HAVE_INT_LEAST8_T@
 typedef int8_t   int_least8_t;
 typedef int8_t   int_least8_t;
+#endif
+#if !@HAVE_UINT_LEAST8_T@
 typedef uint8_t  uint_least8_t;
 typedef uint8_t  uint_least8_t;
+#endif
+
+#if !@HAVE_INT_LEAST16_T@
 typedef int16_t  int_least16_t;
 typedef int16_t  int_least16_t;
+#endif
+#if !@HAVE_UINT_LEAST16_T@
 typedef uint16_t uint_least16_t;
 typedef uint16_t uint_least16_t;
+#endif
+
+#if !@HAVE_INT_LEAST32_T@
 typedef int32_t  int_least32_t;
 typedef int32_t  int_least32_t;
+#endif
+#if !@HAVE_UINT_LEAST32_T@
 typedef uint32_t uint_least32_t;
 typedef uint32_t uint_least32_t;
-#if @HAVE_LONG_64BIT@ || @HAVE_LONG_LONG_64BIT@
+#endif
+
+#if !@HAVE_INT_LEAST64_T@ && _STDINT_H_HAVE_INT64
 typedef int64_t  int_least64_t;
 typedef int64_t  int_least64_t;
+#endif
+#if !@HAVE_UINT_LEAST64_T@ && _STDINT_H_HAVE_UINT64
 typedef uint64_t uint_least64_t;
 #endif
 
 /* 7.18.1.3. Fastest minimum-width integer types */
 
 typedef uint64_t uint_least64_t;
 #endif
 
 /* 7.18.1.3. Fastest minimum-width integer types */
 
+/* Note: Other <stdint.h> substitutes may define these types differently.
+   It is not recommended to use these types in public header files. */
+
+/* Here we assume a standard architecture where the hardware integer
+   types have 8, 16, 32, optionally 64 bits. Therefore the fastN_t types
+   are taken from the same list of types.  */
+
+/* On alpha processors, int32_t variables are slower than int64_t variables,
+   due to the necessary zap instructions.  */
+#if defined __alpha
+# define _STDINT_H_INT64_FASTER_THAN_INT32 1
+#endif
+
+#if !@HAVE_INT_FAST8_T@
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+typedef int64_t  int_fast8_t;
+# else
 typedef int32_t  int_fast8_t;
 typedef int32_t  int_fast8_t;
+# endif
+#endif
+#if !@HAVE_UINT_FAST8_T@
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+typedef uint64_t uint_fast8_t;
+# else
 typedef uint32_t uint_fast8_t;
 typedef uint32_t uint_fast8_t;
+# endif
+#endif
+
+#if !@HAVE_INT_FAST16_T@
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+typedef int64_t  int_fast16_t;
+# else
 typedef int32_t  int_fast16_t;
 typedef int32_t  int_fast16_t;
+# endif
+#endif
+#if !@HAVE_UINT_FAST16_T@
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+typedef uint64_t uint_fast16_t;
+# else
 typedef uint32_t uint_fast16_t;
 typedef uint32_t uint_fast16_t;
+# endif
+#endif
+
+#if !@HAVE_INT_FAST32_T@
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+typedef int64_t  int_fast32_t;
+# else
 typedef int32_t  int_fast32_t;
 typedef int32_t  int_fast32_t;
+# endif
+#endif
+#if !@HAVE_UINT_FAST32_T@
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+typedef uint64_t uint_fast32_t;
+# else
 typedef uint32_t uint_fast32_t;
 typedef uint32_t uint_fast32_t;
-#if @HAVE_LONG_64BIT@ || @HAVE_LONG_LONG_64BIT@
+# endif
+#endif
+
+#if !@HAVE_INT_FAST64_T@ && _STDINT_H_HAVE_INT64
 typedef int64_t  int_fast64_t;
 typedef int64_t  int_fast64_t;
+#endif
+#if !@HAVE_UINT_FAST64_T@ && _STDINT_H_HAVE_UINT64
 typedef uint64_t uint_fast64_t;
 #endif
 
 /* 7.18.1.4. Integer types capable of holding object pointers */
 
 typedef uint64_t uint_fast64_t;
 #endif
 
 /* 7.18.1.4. Integer types capable of holding object pointers */
 
-#if !defined(__FreeBSD__)
-
 /* On some platforms (like IRIX6 MIPS with -n32) sizeof(void*) < sizeof(long),
    but this doesn't matter here.  */
 /* On some platforms (like IRIX6 MIPS with -n32) sizeof(void*) < sizeof(long),
    but this doesn't matter here.  */
+#if !@HAVE_INTPTR_T@
 typedef long          intptr_t;
 typedef long          intptr_t;
+#endif
+#if !@HAVE_UINTPTR_T@
 typedef unsigned long uintptr_t;
 typedef unsigned long uintptr_t;
-
-#endif /* !FreeBSD */
+#endif
 
 /* 7.18.1.5. Greatest-width integer types */
 
 
 /* 7.18.1.5. Greatest-width integer types */
 
-#if @HAVE_LONG_64BIT@ || @HAVE_LONG_LONG_64BIT@
+/* Note: These types are compiler dependent. It may be unwise to use them in
+   public header files. */
+
+#if !@HAVE_INTMAX_T@
+/* Remove possible redundant definition from gnulib's config.h first.  */
+# undef intmax_t
+# ifdef _STDINT_H_HAVE_INT64
 typedef int64_t  intmax_t;
 typedef int64_t  intmax_t;
-typedef uint64_t uintmax_t;
-#else
+# else
 typedef int32_t  intmax_t;
 typedef int32_t  intmax_t;
+# endif
+#endif
+#if !@HAVE_UINTMAX_T@
+/* Remove possible redundant definition from gnulib's config.h first.  */
+# undef uintmax_t
+# ifdef _STDINT_H_HAVE_UINT64
+typedef uint64_t uintmax_t;
+# else
 typedef uint32_t uintmax_t;
 typedef uint32_t uintmax_t;
+# endif
 #endif
 
 /* 7.18.2. Limits of specified-width integer types */
 #endif
 
 /* 7.18.2. Limits of specified-width integer types */
@@ -140,90 +285,659 @@ typedef uint32_t uintmax_t;
 
 /* 7.18.2.1. Limits of exact-width integer types */
 
 
 /* 7.18.2.1. Limits of exact-width integer types */
 
-#define INT8_MIN  -128
-#define INT8_MAX   127
-#define UINT8_MAX  255U
-#define INT16_MIN  -32768
-#define INT16_MAX   32767
-#define UINT16_MAX  65535U
-#define INT32_MIN   (~INT32_MAX)
-#define INT32_MAX   2147483647
-#define UINT32_MAX  4294967295U
-#if @HAVE_LONG_64BIT@
-#define INT64_MIN   (~INT64_MIN)
-#define INT64_MAX   9223372036854775807L
-#define UINT64_MAX 18446744073709551615UL
-#elif @HAVE_LONG_LONG_64BIT@
-#define INT64_MIN   (~INT64_MIN)
-#define INT64_MAX   9223372036854775807LL
-#define UINT64_MAX 18446744073709551615ULL
+/* Here we assume a standard architecture where the hardware integer
+   types have 8, 16, 32, optionally 64 bits.  */
+
+#if @HAVE_INT8_T@
+# ifndef INT8_MIN
+#  define INT8_MIN  (-1 << (@BITSIZEOF_INT8_T@ - 1))
+# endif
+#else
+# define INT8_MIN  -128
+#endif
+#if @HAVE_INT8_T@
+# ifndef INT8_MAX
+#  define INT8_MAX  (~ (-1 << (@BITSIZEOF_INT8_T@ - 1)))
+# endif
+#else
+# define INT8_MAX  127
+#endif
+#if @HAVE_UINT8_T@
+# ifndef UINT8_MAX
+#  if @BITSIZEOF_UINT8_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT8_MAX  (((1 << (@BITSIZEOF_UINT8_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT8_MAX  (((1U << (@BITSIZEOF_UINT8_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# define UINT8_MAX  255
+#endif
+
+#if @HAVE_INT16_T@
+# ifndef INT16_MIN
+#  define INT16_MIN  (-1 << (@BITSIZEOF_INT16_T@ - 1))
+# endif
+#else
+# define INT16_MIN  -32768
+#endif
+#if @HAVE_INT16_T@
+# ifndef INT16_MAX
+#  define INT16_MAX  (~ (-1 << (@BITSIZEOF_INT16_T@ - 1)))
+# endif
+#else
+# define INT16_MAX  32767
+#endif
+#if @HAVE_UINT16_T@
+# ifndef UINT16_MAX
+#  if @BITSIZEOF_UINT16_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT16_MAX  (((1 << (@BITSIZEOF_UINT16_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT16_MAX  (((1U << (@BITSIZEOF_UINT16_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# define UINT16_MAX  65535
+#endif
+
+#if @HAVE_INT32_T@
+# ifndef INT32_MIN
+#  define INT32_MIN  (-1 << (@BITSIZEOF_INT32_T@ - 1))
+# endif
+#else
+# define INT32_MIN  (~INT32_MAX)
+#endif
+#if @HAVE_INT32_T@
+# ifndef INT32_MAX
+#  define INT32_MAX  (~ (-1 << (@BITSIZEOF_INT32_T@ - 1)))
+# endif
+#else
+# define INT32_MAX  2147483647
+#endif
+#if @HAVE_UINT32_T@
+# ifndef UINT32_MAX
+#  if @BITSIZEOF_UINT32_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT32_MAX  (((1 << (@BITSIZEOF_UINT32_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT32_MAX  (((1U << (@BITSIZEOF_UINT32_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# define UINT32_MAX  4294967295U
+#endif
+
+#if @HAVE_INT64_T@
+# ifndef INT64_MIN
+#  if @HAVE_LONG_64BIT@
+#   define INT64_MIN  (-1L << (@BITSIZEOF_INT64_T@ - 1))
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define INT64_MIN  (-1LL << (@BITSIZEOF_INT64_T@ - 1))
+#  elif defined _MSC_VER
+#   define INT64_MIN  (-1i64 << (@BITSIZEOF_INT64_T@ - 1))
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_INT64
+#  define INT64_MIN  (~INT64_MAX)
+# endif
+#endif
+#if @HAVE_INT64_T@
+# ifndef INT64_MAX
+#  if @HAVE_LONG_64BIT@
+#   define INT64_MAX  (~ (-1L << (@BITSIZEOF_INT64_T@ - 1)))
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define INT64_MAX  (~ (-1LL << (@BITSIZEOF_INT64_T@ - 1)))
+#  elif defined _MSC_VER
+#   define INT64_MAX  (~ (-1i64 << (@BITSIZEOF_INT64_T@ - 1)))
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_INT64
+#  if @HAVE_LONG_64BIT@
+#   define INT64_MAX  9223372036854775807L
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define INT64_MAX  9223372036854775807LL
+#  elif defined _MSC_VER
+#   define INT64_MAX  9223372036854775807i64
+#  endif
+# endif
+#endif
+#if @HAVE_UINT64_T@
+# ifndef UINT64_MAX
+#  if @HAVE_LONG_64BIT@
+#   define UINT64_MAX  (((1UL << (@BITSIZEOF_UINT64_T@ - 1)) - 1) * 2 + 1)
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define UINT64_MAX  (((1ULL << (@BITSIZEOF_UINT64_T@ - 1)) - 1) * 2 + 1)
+#  elif defined _MSC_VER
+#   define UINT64_MAX  (((1ui64 << (@BITSIZEOF_UINT64_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_UINT64
+#  if @HAVE_LONG_64BIT@
+#   define UINT64_MAX 18446744073709551615UL
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define UINT64_MAX 18446744073709551615ULL
+#  elif defined _MSC_VER
+#   define UINT64_MAX 18446744073709551615ui64
+#  endif
+# endif
 #endif
 
 /* 7.18.2.2. Limits of minimum-width integer types */
 
 #endif
 
 /* 7.18.2.2. Limits of minimum-width integer types */
 
-#define INT_LEAST8_MIN INT8_MIN
-#define INT_LEAST8_MAX INT8_MAX
-#define UINT_LEAST8_MAX UINT8_MAX
-#define INT_LEAST16_MIN INT16_MIN
-#define INT_LEAST16_MAX INT16_MAX
-#define UINT_LEAST16_MAX UINT16_MAX
-#define INT_LEAST32_MIN INT32_MIN
-#define INT_LEAST32_MAX INT32_MAX
-#define UINT_LEAST32_MAX UINT32_MAX
-#if @HAVE_LONG_64BIT@ || @HAVE_LONG_LONG_64BIT@
-#define INT_LEAST64_MIN INT64_MIN
-#define INT_LEAST64_MAX INT64_MAX
-#define UINT_LEAST64_MAX UINT64_MAX
+/* Here we assume a standard architecture where the hardware integer
+   types have 8, 16, 32, optionally 64 bits. Therefore the leastN_t types
+   are the same as the corresponding N_t types.  */
+
+#if @HAVE_INT_LEAST8_T@
+# ifndef INT_LEAST8_MIN
+#  define INT_LEAST8_MIN  (-1 << (@BITSIZEOF_INT_LEAST8_T@ - 1))
+# endif
+#else
+# define INT_LEAST8_MIN  INT8_MIN
+#endif
+#if @HAVE_INT_LEAST8_T@
+# ifndef INT_LEAST8_MAX
+#  define INT_LEAST8_MAX  (~ (-1 << (@BITSIZEOF_INT_LEAST8_T@ - 1)))
+# endif
+#else
+# define INT_LEAST8_MAX  INT8_MAX
+#endif
+#if @HAVE_UINT_LEAST8_T@
+# ifndef UINT_LEAST8_MAX
+#  if @BITSIZEOF_UINT_LEAST8_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT_LEAST8_MAX  (((1 << (@BITSIZEOF_UINT_LEAST8_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT_LEAST8_MAX  (((1U << (@BITSIZEOF_UINT_LEAST8_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# define UINT_LEAST8_MAX  UINT8_MAX
+#endif
+
+#if @HAVE_INT_LEAST16_T@
+# ifndef INT_LEAST16_MIN
+#  define INT_LEAST16_MIN  (-1 << (@BITSIZEOF_INT_LEAST16_T@ - 1))
+# endif
+#else
+# define INT_LEAST16_MIN  INT16_MIN
+#endif
+#if @HAVE_INT_LEAST16_T@
+# ifndef INT_LEAST16_MAX
+#  define INT_LEAST16_MAX  (~ (-1 << (@BITSIZEOF_INT_LEAST16_T@ - 1)))
+# endif
+#else
+# define INT_LEAST16_MAX  INT16_MAX
+#endif
+#if @HAVE_UINT_LEAST16_T@
+# ifndef UINT_LEAST16_MAX
+#  if @BITSIZEOF_UINT_LEAST16_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT_LEAST16_MAX  (((1 << (@BITSIZEOF_UINT_LEAST16_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT_LEAST16_MAX  (((1U << (@BITSIZEOF_UINT_LEAST16_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# define UINT_LEAST16_MAX  UINT16_MAX
+#endif
+
+#if @HAVE_INT_LEAST32_T@
+# ifndef INT_LEAST32_MIN
+#  define INT_LEAST32_MIN  (-1 << (@BITSIZEOF_INT_LEAST32_T@ - 1))
+# endif
+#else
+# define INT_LEAST32_MIN  INT32_MIN
+#endif
+#if @HAVE_INT_LEAST32_T@
+# ifndef INT_LEAST32_MAX
+#  define INT_LEAST32_MAX  (~ (-1 << (@BITSIZEOF_INT_LEAST32_T@ - 1)))
+# endif
+#else
+# define INT_LEAST32_MAX  INT32_MAX
+#endif
+#if @HAVE_UINT_LEAST32_T@
+# ifndef UINT_LEAST32_MAX
+#  if @BITSIZEOF_UINT_LEAST32_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT_LEAST32_MAX  (((1 << (@BITSIZEOF_UINT_LEAST32_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT_LEAST32_MAX  (((1U << (@BITSIZEOF_UINT_LEAST32_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# define UINT_LEAST32_MAX  UINT32_MAX
+#endif
+
+#if @HAVE_INT_LEAST64_T@
+# ifndef INT_LEAST64_MIN
+#  if @HAVE_LONG_64BIT@
+#   define INT_LEAST64_MIN  (-1L << (@BITSIZEOF_INT_LEAST64_T@ - 1))
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define INT_LEAST64_MIN  (-1LL << (@BITSIZEOF_INT_LEAST64_T@ - 1))
+#  elif defined _MSC_VER
+#   define INT_LEAST64_MIN  (-1i64 << (@BITSIZEOF_INT_LEAST64_T@ - 1))
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_INT64
+#  define INT_LEAST64_MIN  INT64_MIN
+# endif
+#endif
+#if @HAVE_INT_LEAST64_T@
+# ifndef INT_LEAST64_MAX
+#  if @HAVE_LONG_64BIT@
+#   define INT_LEAST64_MAX  (~ (-1L << (@BITSIZEOF_INT_LEAST64_T@ - 1)))
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define INT_LEAST64_MAX  (~ (-1LL << (@BITSIZEOF_INT_LEAST64_T@ - 1)))
+#  elif defined _MSC_VER
+#   define INT_LEAST64_MAX  (~ (-1i64 << (@BITSIZEOF_INT_LEAST64_T@ - 1)))
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_INT64
+#  define INT_LEAST64_MAX  INT64_MAX
+# endif
+#endif
+#if @HAVE_UINT_LEAST64_T@
+# ifndef UINT_LEAST64_MAX
+#  if @HAVE_LONG_64BIT@
+#   define UINT_LEAST64_MAX  (((1UL << (@BITSIZEOF_UINT_LEAST64_T@ - 1)) - 1) * 2 + 1)
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define UINT_LEAST64_MAX  (((1ULL << (@BITSIZEOF_UINT_LEAST64_T@ - 1)) - 1) * 2 + 1)
+#  elif defined _MSC_VER
+#   define UINT_LEAST64_MAX  (((1ui64 << (@BITSIZEOF_UINT_LEAST64_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_UINT64
+#  define UINT_LEAST64_MAX  UINT64_MAX
+# endif
 #endif
 
 /* 7.18.2.3. Limits of fastest minimum-width integer types */
 
 #endif
 
 /* 7.18.2.3. Limits of fastest minimum-width integer types */
 
-#define INT_FAST8_MIN INT32_MIN
-#define INT_FAST8_MAX INT32_MAX
-#define UINT_FAST8_MAX UINT32_MAX
-#define INT_FAST16_MIN INT32_MIN
-#define INT_FAST16_MAX INT32_MAX
-#define UINT_FAST16_MAX UINT32_MAX
-#define INT_FAST32_MIN INT32_MIN
-#define INT_FAST32_MAX INT32_MAX
-#define UINT_FAST32_MAX UINT32_MAX
-#if @HAVE_LONG_64BIT@ || @HAVE_LONG_LONG_64BIT@
-#define INT_FAST64_MIN INT64_MIN
-#define INT_FAST64_MAX INT64_MAX
-#define UINT_FAST64_MAX UINT64_MAX
+/* Here we assume a standard architecture where the hardware integer
+   types have 8, 16, 32, optionally 64 bits. Therefore the fastN_t types
+   are taken from the same list of types.  */
+
+#if @HAVE_INT_FAST8_T@
+# ifndef INT_FAST8_MIN
+#  define INT_FAST8_MIN  (-1L << (@BITSIZEOF_INT_FAST8_T@ - 1))
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define INT_FAST8_MIN  INT64_MIN
+# else
+#  define INT_FAST8_MIN  INT32_MIN
+# endif
+#endif
+#if @HAVE_INT_FAST8_T@
+# ifndef INT_FAST8_MAX
+#  define INT_FAST8_MAX  (~ (-1L << (@BITSIZEOF_INT_FAST8_T@ - 1)))
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define INT_FAST8_MAX  INT64_MAX
+# else
+#  define INT_FAST8_MAX  INT32_MAX
+# endif
+#endif
+#if @HAVE_UINT_FAST8_T@
+# ifndef UINT_FAST8_MAX
+#  if @BITSIZEOF_UINT_FAST8_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT_FAST8_MAX  (((1 << (@BITSIZEOF_UINT_FAST8_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT_FAST8_MAX  (((1UL << (@BITSIZEOF_UINT_FAST8_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define UINT_FAST8_MAX  UINT64_MAX
+# else
+#  define UINT_FAST8_MAX  UINT32_MAX
+# endif
+#endif
+
+#if @HAVE_INT_FAST16_T@
+# ifndef INT_FAST16_MIN
+#  define INT_FAST16_MIN  (-1L << (@BITSIZEOF_INT_FAST16_T@ - 1))
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define INT_FAST16_MIN  INT64_MIN
+# else
+#  define INT_FAST16_MIN  INT32_MIN
+# endif
+#endif
+#if @HAVE_INT_FAST16_T@
+# ifndef INT_FAST16_MAX
+#  define INT_FAST16_MAX  (~ (-1L << (@BITSIZEOF_INT_FAST16_T@ - 1)))
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define INT_FAST16_MAX  INT64_MAX
+# else
+#  define INT_FAST16_MAX  INT32_MAX
+# endif
+#endif
+#if @HAVE_UINT_FAST16_T@
+# ifndef UINT_FAST16_MAX
+#  if @BITSIZEOF_UINT_FAST16_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT_FAST16_MAX  (((1 << (@BITSIZEOF_UINT_FAST16_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT_FAST16_MAX  (((1UL << (@BITSIZEOF_UINT_FAST16_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define UINT_FAST16_MAX  UINT64_MAX
+# else
+#  define UINT_FAST16_MAX  UINT32_MAX
+# endif
+#endif
+
+#if @HAVE_INT_FAST32_T@
+# ifndef INT_FAST32_MIN
+#  define INT_FAST32_MIN  (-1L << (@BITSIZEOF_INT_FAST32_T@ - 1))
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define INT_FAST32_MIN  INT64_MIN
+# else
+#  define INT_FAST32_MIN  INT32_MIN
+# endif
+#endif
+#if @HAVE_INT_FAST32_T@
+# ifndef INT_FAST32_MAX
+#  define INT_FAST32_MAX  (~ (-1L << (@BITSIZEOF_INT_FAST32_T@ - 1)))
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define INT_FAST32_MAX  INT64_MAX
+# else
+#  define INT_FAST32_MAX  INT32_MAX
+# endif
+#endif
+#if @HAVE_UINT_FAST32_T@
+# ifndef UINT_FAST32_MAX
+#  if @BITSIZEOF_UINT_FAST32_T@ < @BITSIZEOF_UNSIGNED_INT@
+#   define UINT_FAST32_MAX  (((1 << (@BITSIZEOF_UINT_FAST32_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINT_FAST32_MAX  (((1UL << (@BITSIZEOF_UINT_FAST32_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# if _STDINT_H_INT64_FASTER_THAN_INT32
+#  define UINT_FAST32_MAX  UINT64_MAX
+# else
+#  define UINT_FAST32_MAX  UINT32_MAX
+# endif
+#endif
+
+#if @HAVE_INT_FAST64_T@
+# ifndef INT_FAST64_MIN
+#  if @HAVE_LONG_64BIT@
+#   define INT_FAST64_MIN  (-1L << (@BITSIZEOF_INT_FAST64_T@ - 1))
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define INT_FAST64_MIN  (-1LL << (@BITSIZEOF_INT_FAST64_T@ - 1))
+#  elif defined _MSC_VER
+#   define INT_FAST64_MIN  (-1i64 << (@BITSIZEOF_INT_FAST64_T@ - 1))
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_INT64
+#  define INT_FAST64_MIN  INT64_MIN
+# endif
+#endif
+#if @HAVE_INT_FAST64_T@
+# ifndef INT_FAST64_MAX
+#  if @HAVE_LONG_64BIT@
+#   define INT_FAST64_MAX  (~ (-1L << (@BITSIZEOF_INT_FAST64_T@ - 1)))
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define INT_FAST64_MAX  (~ (-1LL << (@BITSIZEOF_INT_FAST64_T@ - 1)))
+#  elif defined _MSC_VER
+#   define INT_FAST64_MAX  (~ (-1i64 << (@BITSIZEOF_INT_FAST64_T@ - 1)))
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_INT64
+#  define INT_FAST64_MAX  INT64_MAX
+# endif
+#endif
+#if @HAVE_UINT_FAST64_T@
+# ifndef UINT_FAST64_MAX
+#  if @HAVE_LONG_64BIT@
+#   define UINT_FAST64_MAX  (((1UL << (@BITSIZEOF_UINT_FAST64_T@ - 1)) - 1) * 2 + 1)
+#  elif @HAVE_LONG_LONG_64BIT@
+#   define UINT_FAST64_MAX  (((1ULL << (@BITSIZEOF_UINT_FAST64_T@ - 1)) - 1) * 2 + 1)
+#  elif defined _MSC_VER
+#   define UINT_FAST64_MAX  (((1ui64 << (@BITSIZEOF_UINT_FAST64_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_UINT64
+#  define UINT_FAST64_MAX  UINT64_MAX
+# endif
 #endif
 
 /* 7.18.2.4. Limits of integer types capable of holding object pointers */
 
 #endif
 
 /* 7.18.2.4. Limits of integer types capable of holding object pointers */
 
-#define INTPTR_MIN LONG_MIN
-#define INTPTR_MAX LONG_MAX
-#define UINTPTR_MAX ULONG_MAX
+#if @HAVE_INTPTR_T@
+# ifndef INTPTR_MIN
+#  if @BITSIZEOF_INTPTR_T@ > @BITSIZEOF_LONG@
+#   define INTPTR_MIN  (-1LL << (@BITSIZEOF_INTPTR_T@ - 1))
+#  else
+#   define INTPTR_MIN  (-1L << (@BITSIZEOF_INTPTR_T@ - 1))
+#  endif
+# endif
+#else
+# define INTPTR_MIN  LONG_MIN
+#endif
+#if @HAVE_INTPTR_T@
+# ifndef INTPTR_MAX
+#  if @BITSIZEOF_INTPTR_T@ > @BITSIZEOF_LONG@
+#   define INTPTR_MAX  (~ (-1LL << (@BITSIZEOF_INTPTR_T@ - 1)))
+#  else
+#   define INTPTR_MAX  (~ (-1L << (@BITSIZEOF_INTPTR_T@ - 1)))
+#  endif
+# endif
+#else
+# define INTPTR_MAX  LONG_MAX
+#endif
+#if @HAVE_UINTPTR_T@
+# ifndef UINTPTR_MAX
+#  if @BITSIZEOF_UINTPTR_T@ > @BITSIZEOF_UNSIGNED_LONG@
+#   define UINTPTR_MAX  (((1ULL << (@BITSIZEOF_UINTPTR_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINTPTR_MAX  (((1UL << (@BITSIZEOF_UINTPTR_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#else
+# define UINTPTR_MAX  ULONG_MAX
+#endif
 
 /* 7.18.2.5. Limits of greatest-width integer types */
 
 
 /* 7.18.2.5. Limits of greatest-width integer types */
 
-#if @HAVE_LONG_64BIT@ || @HAVE_LONG_LONG_64BIT@
-#define INTMAX_MIN INT64_MIN
-#define INTMAX_MAX INT64_MAX
-#define UINTMAX_MAX UINT64_MAX
+#if @HAVE_INTMAX_T@
+# ifndef INTMAX_MIN
+#  if @BITSIZEOF_INTMAX_T@ > @BITSIZEOF_LONG@
+#   define INTMAX_MIN  (-1LL << (@BITSIZEOF_INTMAX_T@ - 1))
+#  else
+#   define INTMAX_MIN  (-1L << (@BITSIZEOF_INTMAX_T@ - 1))
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_INT64
+#  define INTMAX_MIN  INT64_MIN
+# else
+#  define INTMAX_MIN  INT32_MIN
+# endif
+#endif
+#if @HAVE_INTMAX_T@
+# ifndef INTMAX_MAX
+#  if @BITSIZEOF_INTMAX_T@ > @BITSIZEOF_LONG@
+#   define INTMAX_MAX  (~ (-1LL << (@BITSIZEOF_INTMAX_T@ - 1)))
+#  else
+#   define INTMAX_MAX  (~ (-1L << (@BITSIZEOF_INTMAX_T@ - 1)))
+#  endif
+# endif
+#else
+# ifdef _STDINT_H_HAVE_INT64
+#  define INTMAX_MAX  INT64_MAX
+# else
+#  define INTMAX_MAX  INT32_MAX
+# endif
+#endif
+#if @HAVE_UINTMAX_T@
+# ifndef UINTMAX_MAX
+#  if @BITSIZEOF_UINTMAX_T@ > @BITSIZEOF_UNSIGNED_LONG@
+#   define UINTMAX_MAX  (((1ULL << (@BITSIZEOF_UINTMAX_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define UINTMAX_MAX  (((1UL << (@BITSIZEOF_UINTMAX_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
 #else
 #else
-#define INTMAX_MIN INT32_MIN
-#define INTMAX_MAX INT32_MAX
-#define UINTMAX_MAX UINT32_MAX
+# ifdef _STDINT_H_HAVE_INT64
+#  define UINTMAX_MAX  UINT64_MAX
+# else
+#  define UINTMAX_MAX  UINT32_MAX
+# endif
 #endif
 
 /* 7.18.3. Limits of other integer types */
 
 #endif
 
 /* 7.18.3. Limits of other integer types */
 
-#define PTRDIFF_MIN (~(ptrdiff_t)0 << (sizeof(ptrdiff_t)*CHAR_BIT-1))
-#define PTRDIFF_MAX (~PTRDIFF_MIN)
+/* ptrdiff_t limits */
+#ifndef PTRDIFF_MIN
+# if @BITSIZEOF_PTRDIFF_T@ > @BITSIZEOF_LONG@ || @SAME_TYPE_PTRDIFF_T_LONG@
+#  define PTRDIFF_MIN  (-1L << (@BITSIZEOF_PTRDIFF_T@ - 1))
+# else
+#  define PTRDIFF_MIN  (-1 << (@BITSIZEOF_PTRDIFF_T@ - 1))
+# endif
+#endif
+#ifndef PTRDIFF_MAX
+# if @BITSIZEOF_PTRDIFF_T@ > @BITSIZEOF_LONG@ || @SAME_TYPE_PTRDIFF_T_LONG@
+#  define PTRDIFF_MAX  (~ (-1L << (@BITSIZEOF_PTRDIFF_T@ - 1)))
+# else
+#  define PTRDIFF_MAX  (~ (-1 << (@BITSIZEOF_PTRDIFF_T@ - 1)))
+# endif
+#endif
+
+/* sig_atomic_t limits */
+#ifndef SIG_ATOMIC_MIN
+# if @HAVE_SIGNED_SIG_ATOMIC_T@
+#  if @BITSIZEOF_SIG_ATOMIC_T@ > @BITSIZEOF_LONG@ || @SAME_TYPE_SIG_ATOMIC_T_LONG@
+#   define SIG_ATOMIC_MIN  (-1L << (@BITSIZEOF_SIG_ATOMIC_T@ - 1))
+#  else
+#   define SIG_ATOMIC_MIN  (-1 << (@BITSIZEOF_SIG_ATOMIC_T@ - 1))
+#  endif
+# else
+#  if @BITSIZEOF_SIG_ATOMIC_T@ > @BITSIZEOF_UNSIGNED_LONG@ || @SAME_TYPE_SIG_ATOMIC_T_UNSIGNED_LONG@
+#   define SIG_ATOMIC_MIN  0UL
+#  elif @BITSIZEOF_SIG_ATOMIC_T@ >= @BITSIZEOF_UNSIGNED_INT@
+#   define SIG_ATOMIC_MIN  0U
+#  else
+#   define SIG_ATOMIC_MIN  0
+#  endif
+# endif
+#endif
+#ifndef SIG_ATOMIC_MAX
+# if @HAVE_SIGNED_SIG_ATOMIC_T@
+#  if @BITSIZEOF_SIG_ATOMIC_T@ > @BITSIZEOF_LONG@ || @SAME_TYPE_SIG_ATOMIC_T_LONG@
+#   define SIG_ATOMIC_MAX  (~ (-1L << (@BITSIZEOF_SIG_ATOMIC_T@ - 1)))
+#  else
+#   define SIG_ATOMIC_MAX  (~ (-1 << (@BITSIZEOF_SIG_ATOMIC_T@ - 1)))
+#  endif
+# else
+#  if @BITSIZEOF_SIG_ATOMIC_T@ > @BITSIZEOF_UNSIGNED_LONG@ || @SAME_TYPE_SIG_ATOMIC_T_UNSIGNED_LONG@
+#   define SIG_ATOMIC_MAX  (((1UL << (@BITSIZEOF_SIG_ATOMIC_T@ - 1)) - 1) * 2 + 1)
+#  elif @BITSIZEOF_SIG_ATOMIC_T@ >= @BITSIZEOF_UNSIGNED_INT@
+#   define SIG_ATOMIC_MAX  (((1U << (@BITSIZEOF_SIG_ATOMIC_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define SIG_ATOMIC_MAX  (((1 << (@BITSIZEOF_SIG_ATOMIC_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#endif
 
 
-/* This may be wrong...  */
-#define SIG_ATOMIC_MIN 0
-#define SIG_ATOMIC_MAX 127
+/* size_t limit */
+#ifndef SIZE_MAX /* SIZE_MAX may also be defined in config.h. */
+# if @BITSIZEOF_SIZE_T@ > @BITSIZEOF_UNSIGNED_LONG@ || @SAME_TYPE_SIZE_T_UNSIGNED_LONG@
+#  define SIZE_MAX  (((1UL << (@BITSIZEOF_SIZE_T@ - 1)) - 1) * 2 + 1)
+# else
+#  define SIZE_MAX  (((1U << (@BITSIZEOF_SIZE_T@ - 1)) - 1) * 2 + 1)
+# endif
+#endif
 
 
-#define SIZE_MAX (~(size_t)0)
+/* wchar_t limits may already be defined in <stddef.h>.  */
+#ifndef WCHAR_MIN
+# if @HAVE_SIGNED_WCHAR_T@
+#  if @BITSIZEOF_WCHAR_T@ > @BITSIZEOF_LONG@ || @SAME_TYPE_WCHAR_T_LONG@
+#   define WCHAR_MIN  (-1L << (@BITSIZEOF_WCHAR_T@ - 1))
+#  else
+#   define WCHAR_MIN  (-1 << (@BITSIZEOF_WCHAR_T@ - 1))
+#  endif
+# else
+#  if @BITSIZEOF_WCHAR_T@ > @BITSIZEOF_UNSIGNED_LONG@ || @SAME_TYPE_WCHAR_T_UNSIGNED_LONG@
+#   define WCHAR_MIN  0UL
+#  elif @BITSIZEOF_WCHAR_T@ >= @BITSIZEOF_UNSIGNED_INT@
+#   define WCHAR_MIN  0U
+#  else
+#   define WCHAR_MIN  0
+#  endif
+# endif
+#endif
+#ifndef WCHAR_MAX
+# if @HAVE_SIGNED_WCHAR_T@
+#  if @BITSIZEOF_WCHAR_T@ > @BITSIZEOF_LONG@ || @SAME_TYPE_WCHAR_T_LONG@
+#   define WCHAR_MAX  (~ (-1L << (@BITSIZEOF_WCHAR_T@ - 1)))
+#  else
+#   define WCHAR_MAX  (~ (-1 << (@BITSIZEOF_WCHAR_T@ - 1)))
+#  endif
+# else
+#  if @BITSIZEOF_WCHAR_T@ > @BITSIZEOF_UNSIGNED_LONG@ || @SAME_TYPE_WCHAR_T_UNSIGNED_LONG@
+#   define WCHAR_MAX  (((1UL << (@BITSIZEOF_WCHAR_T@ - 1)) - 1) * 2 + 1)
+#  elif @BITSIZEOF_WCHAR_T@ >= @BITSIZEOF_UNSIGNED_INT@
+#   define WCHAR_MAX  (((1U << (@BITSIZEOF_WCHAR_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define WCHAR_MAX  (((1 << (@BITSIZEOF_WCHAR_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#endif
 
 
-/* wchar_t limits already defined in <stddef.h>.  */
-/* wint_t limits already defined in <wchar.h>.  */
+/* wint_t limits */
+#ifndef WINT_MIN
+# if @HAVE_SIGNED_WINT_T@
+#  if @BITSIZEOF_WINT_T@ > @BITSIZEOF_LONG@ || @SAME_TYPE_WINT_T_LONG@
+#   define WINT_MIN  (-1L << (@BITSIZEOF_WINT_T@ - 1))
+#  else
+#   define WINT_MIN  (-1 << (@BITSIZEOF_WINT_T@ - 1))
+#  endif
+# else
+#  if @BITSIZEOF_WINT_T@ > @BITSIZEOF_UNSIGNED_LONG@ || @SAME_TYPE_WINT_T_UNSIGNED_LONG@
+#   define WINT_MIN  0UL
+#  elif @BITSIZEOF_WINT_T@ >= @BITSIZEOF_UNSIGNED_INT@
+#   define WINT_MIN  0U
+#  else
+#   define WINT_MIN  0
+#  endif
+# endif
+#endif
+#ifndef WINT_MAX
+# if @HAVE_SIGNED_WINT_T@
+#  if @BITSIZEOF_WINT_T@ > @BITSIZEOF_LONG@ || @SAME_TYPE_WINT_T_LONG@
+#   define WINT_MAX  (~ (-1L << (@BITSIZEOF_WINT_T@ - 1)))
+#  else
+#   define WINT_MAX  (~ (-1 << (@BITSIZEOF_WINT_T@ - 1)))
+#  endif
+# else
+#  if @BITSIZEOF_WINT_T@ > @BITSIZEOF_UNSIGNED_LONG@ || @SAME_TYPE_WINT_T_UNSIGNED_LONG@
+#   define WINT_MAX  (((1UL << (@BITSIZEOF_WINT_T@ - 1)) - 1) * 2 + 1)
+#  elif @BITSIZEOF_WINT_T@ >= @BITSIZEOF_UNSIGNED_INT@
+#   define WINT_MAX  (((1U << (@BITSIZEOF_WINT_T@ - 1)) - 1) * 2 + 1)
+#  else
+#   define WINT_MAX  (((1 << (@BITSIZEOF_WINT_T@ - 1)) - 1) * 2 + 1)
+#  endif
+# endif
+#endif
 
 #endif
 
 
 #endif
 
@@ -232,36 +946,78 @@ typedef uint32_t uintmax_t;
 #if !defined(__cplusplus) || defined(__STDC_CONSTANT_MACROS)
 
 /* 7.18.4.1. Macros for minimum-width integer constants */
 #if !defined(__cplusplus) || defined(__STDC_CONSTANT_MACROS)
 
 /* 7.18.4.1. Macros for minimum-width integer constants */
+/* According to ISO C 99 Technical Corrigendum 1 */
 
 
+#undef INT8_C
+#undef UINT8_C
 #define INT8_C(x) x
 #define INT8_C(x) x
-#define UINT8_C(x) x##U
+#if @HAVE_UINT8_T@
+# if @BITSIZEOF_UINT8_T@ < @BITSIZEOF_UNSIGNED_INT@
+#  define UINT8_C(x) x
+# else
+#  define UINT8_C(x) x##U
+# endif
+#else
+# define UINT8_C(x) x
+#endif
+
+#undef INT16_C
+#undef UINT16_C
 #define INT16_C(x) x
 #define INT16_C(x) x
-#define UINT16_C(x) x##U
+#if @HAVE_UINT16_T@
+# if @BITSIZEOF_UINT16_T@ < @BITSIZEOF_UNSIGNED_INT@
+#  define UINT16_C(x) x
+# else
+#  define UINT16_C(x) x##U
+# endif
+#else
+# define UINT16_C(x) x
+#endif
+
+#undef INT32_C
+#undef UINT32_C
 #define INT32_C(x) x
 #define INT32_C(x) x
-#define UINT32_C(x) x##U
+#if @HAVE_UINT32_T@
+# if @BITSIZEOF_UINT32_T@ < @BITSIZEOF_UNSIGNED_INT@
+#  define UINT32_C(x) x
+# else
+#  define UINT32_C(x) x##U
+# endif
+#else
+# define UINT32_C(x) x
+#endif
+
+#undef INT64_C
+#undef UINT64_C
 #if @HAVE_LONG_64BIT@
 #if @HAVE_LONG_64BIT@
-#define INT64_C(x) x##L
-#define UINT64_C(x) x##UL
+# define INT64_C(x) x##L
+# define UINT64_C(x) x##UL
 #elif @HAVE_LONG_LONG_64BIT@
 #elif @HAVE_LONG_LONG_64BIT@
-#define INT64_C(x) x##LL
-#define UINT64_C(x) x##ULL
+# define INT64_C(x) x##LL
+# define UINT64_C(x) x##ULL
+#elif defined(_MSC_VER)
+# define INT64_C(x) x##i64
+# define UINT64_C(x) x##ui64
 #endif
 
 /* 7.18.4.2. Macros for greatest-width integer constants */
 
 #endif
 
 /* 7.18.4.2. Macros for greatest-width integer constants */
 
+#undef INTMAX_C
+#undef UINTMAX_C
 #if @HAVE_LONG_64BIT@
 #if @HAVE_LONG_64BIT@
-#define INTMAX_C(x) x##L
-#define UINTMAX_C(x) x##UL
+# define INTMAX_C(x) x##L
+# define UINTMAX_C(x) x##UL
 #elif @HAVE_LONG_LONG_64BIT@
 #elif @HAVE_LONG_LONG_64BIT@
-#define INTMAX_C(x) x##LL
-#define UINTMAX_C(x) x##ULL
+# define INTMAX_C(x) x##LL
+# define UINTMAX_C(x) x##ULL
+#elif defined(_MSC_VER)
+# define INTMAX_C(x) x##i64
+# define UINTMAX_C(x) x##ui64
 #else
 #else
-#define INTMAX_C(x) x
-#define UINTMAX_C(x) x##U
+# define INTMAX_C(x) x
+# define UINTMAX_C(x) x##U
 #endif
 
 #endif
 
 #endif
 
 #endif
 
-#endif  /* !HAVE_SYSTEM_INTTYPES */
-
 #endif /* _STDINT_H */
 #endif /* _STDINT_H */