[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] Who would have thought that some systems define intfoo_t, b...
- To: or-cvs@freehaven.net
- Subject: [or-cvs] Who would have thought that some systems define intfoo_t, b...
- From: nickm@seul.org (Nick Mathewson)
- Date: Mon, 11 Aug 2003 17:16:15 -0400 (EDT)
- Delivered-to: archiver@seul.org
- Delivered-to: or-cvs-outgoing@seul.org
- Delivered-to: or-cvs@seul.org
- Delivery-date: Mon, 11 Aug 2003 17:16:32 -0400
- Reply-to: or-dev@freehaven.net
- Sender: owner-or-cvs@freehaven.net
Update of /home/or/cvsroot/src/common
In directory moria.mit.edu:/tmp/cvs-serv27788/src/common
Modified Files:
torint.h
Log Message:
Who would have thought that some systems define intfoo_t, but not uintfoo_t? Cygwin is such a system.
Index: torint.h
===================================================================
RCS file: /home/or/cvsroot/src/common/torint.h,v
retrieving revision 1.2
retrieving revision 1.3
diff -u -d -r1.2 -r1.3
--- torint.h 11 Aug 2003 20:50:30 -0000 1.2
+++ torint.h 11 Aug 2003 21:16:13 -0000 1.3
@@ -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 */