diff options
author | Brad King <brad.king@kitware.com> | 2009-11-04 18:10:11 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-11-04 18:10:11 (GMT) |
commit | c9a9c88634c98174d9fae712a31327cbd8d0963d (patch) | |
tree | 64eff28a03a5ca2992ca9d7b66d7c8c3be74416e | |
parent | 12baf7b7f18fcc13db5542c116d59bdc056595d8 (diff) | |
download | CMake-c9a9c88634c98174d9fae712a31327cbd8d0963d.zip CMake-c9a9c88634c98174d9fae712a31327cbd8d0963d.tar.gz CMake-c9a9c88634c98174d9fae712a31327cbd8d0963d.tar.bz2 |
libarchive: Fix Borland integer constants
Some versions of Borland provide <stdint.h>, so we use it when possible.
However, the 64-bit signed and unsigned integer min/max constants cause
overflow warnings from Borland itself! For these constants we fall back
on our default definitions.
6 files changed, 29 insertions, 5 deletions
diff --git a/Utilities/cmlibarchive/build/cmake/config.h.in b/Utilities/cmlibarchive/build/cmake/config.h.in index e5f7e59..07e7386 100644 --- a/Utilities/cmlibarchive/build/cmake/config.h.in +++ b/Utilities/cmlibarchive/build/cmake/config.h.in @@ -698,7 +698,7 @@ /* Define to `unsigned int' if <sys/types.h> does not define. */ #cmakedefine uintptr_t ${uintptr_t } -#ifdef __BORLANDC__ +#if defined(__BORLANDC__) && !defined(HAVE_STDINT_H) #define uintptr_t unsigned int #define intptr_t int #endif diff --git a/Utilities/cmlibarchive/libarchive/archive.h b/Utilities/cmlibarchive/libarchive/archive.h index 23bdf9b..a6c12ce 100644 --- a/Utilities/cmlibarchive/libarchive/archive.h +++ b/Utilities/cmlibarchive/libarchive/archive.h @@ -61,7 +61,7 @@ #else #include <unistd.h> /* ssize_t, uid_t, and gid_t */ #endif -#if defined(__BORLANDC__) +#if defined(__BORLANDC__) && !defined(HAVE_SYS_TYPES_H) #define __LA_INT64_T __int64 #define __LA_SSIZE_T long #else diff --git a/Utilities/cmlibarchive/libarchive/archive_entry.h b/Utilities/cmlibarchive/libarchive/archive_entry.h index 10ca1e8..b1e24c2 100644 --- a/Utilities/cmlibarchive/libarchive/archive_entry.h +++ b/Utilities/cmlibarchive/libarchive/archive_entry.h @@ -58,7 +58,7 @@ #else # include <unistd.h> #endif -#if defined(__BORLANDC__) +#if defined(__BORLANDC__) && !defined(HAVE_SYS_TYPES_H) #define __LA_INT64_T __int64 #else #define __LA_INT64_T int64_t diff --git a/Utilities/cmlibarchive/libarchive/archive_entry_copy_bhfi.c b/Utilities/cmlibarchive/libarchive/archive_entry_copy_bhfi.c index 9a64880..4e09c2f 100644 --- a/Utilities/cmlibarchive/libarchive/archive_entry_copy_bhfi.c +++ b/Utilities/cmlibarchive/libarchive/archive_entry_copy_bhfi.c @@ -30,7 +30,7 @@ __FBSDID("$FreeBSD$"); #if defined(_WIN32) && !defined(__CYGWIN__) #if defined(__BORLANDC__) || (defined(_MSC_VER) && _MSC_VER <= 1300) -# define EPOC_TIME (116444736000000000) +# define EPOC_TIME (116444736000000000UI64) #else # define EPOC_TIME (116444736000000000ULL) #endif diff --git a/Utilities/cmlibarchive/libarchive/archive_platform.h b/Utilities/cmlibarchive/libarchive/archive_platform.h index 2c43a28..8cd5015 100644 --- a/Utilities/cmlibarchive/libarchive/archive_platform.h +++ b/Utilities/cmlibarchive/libarchive/archive_platform.h @@ -86,6 +86,30 @@ #include <stdint.h> #endif +/* Borland warns about its own constants! */ +#if defined(__BORLANDC__) +# if HAVE_DECL_UINT64_MAX +# undef UINT64_MAX +# undef HAVE_DECL_UINT64_MAX +# define HAVE_DECL_UINT64_MAX 0 +# endif +# if HAVE_DECL_UINT64_MIN +# undef UINT64_MIN +# undef HAVE_DECL_UINT64_MIN +# define HAVE_DECL_UINT64_MIN 0 +# endif +# if HAVE_DECL_INT64_MAX +# undef INT64_MAX +# undef HAVE_DECL_INT64_MAX +# define HAVE_DECL_INT64_MAX 0 +# endif +# if HAVE_DECL_INT64_MIN +# undef INT64_MIN +# undef HAVE_DECL_INT64_MIN +# define HAVE_DECL_INT64_MIN 0 +# endif +#endif + /* Some platforms lack the standard *_MAX definitions. */ #if !HAVE_DECL_SIZE_MAX #define SIZE_MAX (~(size_t)0) diff --git a/Utilities/cmlibarchive/libarchive/archive_windows.c b/Utilities/cmlibarchive/libarchive/archive_windows.c index 65d6116..ddd0352 100644 --- a/Utilities/cmlibarchive/libarchive/archive_windows.c +++ b/Utilities/cmlibarchive/libarchive/archive_windows.c @@ -60,7 +60,7 @@ #include <wchar.h> #include <windows.h> #if defined(__BORLANDC__) || (defined(_MSC_VER) && _MSC_VER <= 1300) -# define EPOC_TIME (116444736000000000) +# define EPOC_TIME (116444736000000000UI64) #else # define EPOC_TIME (116444736000000000ULL) #endif |