diff options
author | Nick Mathewson <nickm@torproject.org> | 2003-08-11 21:16:13 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2003-08-11 21:16:13 +0000 |
commit | 58e2edfb24ed19427ec52d058ffa8aecb5a94cf8 (patch) | |
tree | bce1ba579a9c219004ead1328cfade9a1babded6 | |
parent | 7284c25b3460790c3c0b61366c1b4350fc953746 (diff) | |
download | tor-58e2edfb24ed19427ec52d058ffa8aecb5a94cf8.tar tor-58e2edfb24ed19427ec52d058ffa8aecb5a94cf8.tar.gz |
Who would have thought that some systems define intfoo_t, but not uintfoo_t? Cygwin is such a system.
svn:r378
-rw-r--r-- | configure.in | 4 | ||||
-rw-r--r-- | src/common/torint.h | 120 |
2 files changed, 95 insertions, 29 deletions
diff --git a/configure.in b/configure.in index 4338f2bd2..cf5ab525e 100644 --- a/configure.in +++ b/configure.in @@ -137,12 +137,12 @@ AC_CHECK_HEADERS(unistd.h string.h signal.h netdb.h ctype.h poll.h sys/poll.h sy dnl These headers are not essential -AC_CHECK_HEADERS(stdint.h sys/types.h) +AC_CHECK_HEADERS(stdint.h sys/types.h inttypes.h) dnl In case we aren't given a working stdint.h, we'll need to grow our own. dnl Watch out. -AC_CHECK_TYPES([int8_t, int16_t, int32_t, int64_t]) +AC_CHECK_TYPES([int8_t, int16_t, int32_t, int64_t, uint8_t, uint16_t, uint32_t, uint64_t]) AC_CHECK_SIZEOF(char) AC_CHECK_SIZEOF(short) diff --git a/src/common/torint.h b/src/common/torint.h index 4ab7e62ed..75032d8f6 100644 --- a/src/common/torint.h +++ b/src/common/torint.h @@ -5,61 +5,127 @@ #ifndef __TORINT_H #define __TORINT_H +#include "orconfig.h" + #ifdef HAVE_STDINT_H #include <stdint.h> #endif #ifdef HAVE_SYS_TYPES_H #include <sys/types.h> +#endif + -#ifndef HAVE_INT8_T #if (SIZEOF_CHAR == 1) -typedef unsigned char uint8_t; +#ifndef HAVE_INT8_T typedef signed char int8_t; -#else -#error "sizeof(char) != 1" +#define HAVE_INT8_T +#endif +#ifndef HAVE_UINT8_T +typedef unsigned char uint8_t; +#define HAVE_UINT8_T #endif #endif +#if (SIZEOF_SHORT == 2) #ifndef HAVE_INT16_T -#if (SIZEOF_SHORT == 2) -typedef unsigned short uint16_t; typedef signed short int16_t; -#elif (SIZEOF_INT == 2) -typedef unsigned int uint16_t; -typedef signed int int16_t; -#else -#error "sizeof(short) != 2 && sizeof(int) != 2" +#define HAVE_INT16_T #endif +#ifndef HAVE_UINT16_T +typedef unsigned short uint16_t; +#define HAVE_UINT16_T #endif +#endif + +#if (SIZEOF_INT == 2) +#ifndef HAVE_INT16_T +typedef signed int int16_t; +#define HAVE_INT16_T +#endif +#ifndef HAVE_UINT16_T +typedef unsigned int uint16_t; +#define HAVE_UINT16_T +#endif +#elif (SIZEOF_INT == 4) #ifndef HAVE_INT32_T -#if (SIZEOF_INT == 4) -typedef unsigned int uint32_t; typedef signed int int32_t; -#elif (SIZEOF_LONG == 4) -typedef unsigned long uint32_t; -typedef signed long int32_t; -#else -#error "sizeof(int) != 4 && sizeof(long) != 4" +#define HAVE_INT32_T #endif +#ifndef HAVE_UINT32_T +typedef unsigned int uint32_t; +#define HAVE_UINT32_T #endif +#endif + +#if (SIZEOF_LONG == 4) +#ifndef HAVE_INT32_T +typedef signed long int32_t; +#define HAVE_INT32_T +#endif +#ifndef HAVE_UINT32_T +typedef unsigned long uint32_t; +#define HAVE_UINT32_T +#endif +#elif (SIZEOF_LONG == 8) #ifndef HAVE_INT64_T -#if (SIZEOF_LONG == 8) -typedef unsigned long uint64_t; typedef signed long int64_t; -#elif (SIZEOF_LONG_LONG == 8) -typedef unsigned long long uint64_t; +#define HAVE_INT64_T +#endif +#ifndef HAVE_UINT32_T +typedef unsigned long uint64_t; +#define HAVE_UINT32_T +#endif +#endif + +#if (SIZEOF_LONG_LONG == 8) +#ifndef HAVE_INT64_T typedef signed long long int64_t; -#elif (SIZEOF___INT64 == 8) -typedef unsigned __int64 uint64_t; +#define HAVE_INT64_T +#endif +#ifndef HAVE_UINT64_T +typedef unsigned long long uint64_t; +#define HAVE_UINT64_T +#endif +#endif + +#if (SIZEOF___INT64 == 8) +#ifndef HAVE_INT64_T typedef signed __int64 int64_t; -#else -#error "sizeof(long) != 8 && sizeof(long long) != 8 && sizeof(__int64) != 8" +#define HAVE_INT64_T +#endif +#ifndef HAVE_UINT64_T +typedef unsigned __int64 uint64_t; +#define HAVE_UINT64_T #endif #endif -#endif /* HAVE_STDINT_H */ + +#ifndef HAVE_INT8_T +#error "Missing type int8_t" +#endif +#ifndef HAVE_UINT8_T +#error "Missing type uint8_t" +#endif +#ifndef HAVE_INT16_T +#error "Missing type int16_t" +#endif +#ifndef HAVE_UINT16_T +#error "Missing type uint16_t" +#endif +#ifndef HAVE_INT32_T +#error "Missing type int32_t" +#endif +#ifndef HAVE_UINT32_T +#error "Missing type uint32_t" +#endif +#ifndef HAVE_INT64_T +#error "Missing type int64_t" +#endif +#ifndef HAVE_UINT64_T +#error "Missing type uint64_t" +#endif #endif /* __TORINT_H */ |