]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Detect signed size_t and report an error at configure time.
authorNick Mathewson <nickm@torproject.org>
Mon, 3 Jan 2011 21:54:57 +0000 (16:54 -0500)
committerNick Mathewson <nickm@torproject.org>
Mon, 3 Jan 2011 21:54:57 +0000 (16:54 -0500)
changes/bug2337 [new file with mode: 0644]
configure.in

diff --git a/changes/bug2337 b/changes/bug2337
new file mode 100644 (file)
index 0000000..a4f052d
--- /dev/null
@@ -0,0 +1,3 @@
+  o Minor bugfixes
+    - Detect broken platforms with a signed size_t, and refuse to
+      build there.  Found and analyzed by doorss and rransom.
index 68c593a11b2940400995f894f304e3b00bbe563f..394be9e82d5eaf9187eeb7c8690a94930d9063d0 100644 (file)
@@ -548,6 +548,23 @@ if test "$tor_cv_time_t_signed" != no; then
             [Define to 1 iff time_t is signed])
 fi
 
+AC_CACHE_CHECK([whether size_t is signed], tor_cv_size_t_signed, [
+AC_RUN_IFELSE(AC_LANG_SOURCE([
+#ifdef HAVE_SYS_TYPES_H
+#include <sys/types.h>
+#endif
+int main(int c, char**v) { if (((size_t)-1)<0) return 1; else return 0; }]),
+  tor_cv_size_t_signed=no, tor_cv_size_t_signed=yes, tor_cv_size_t_signed=cross)
+])
+
+if test "$tor_cv_size_t_signed" = cross; then
+  AC_MSG_NOTICE([Cross compiling: assuming that size_t is not signed.])
+fi
+
+if test "$tor_cv_size_t_signed" = yes; then
+  AC_MSG_ERROR([You have a signed size_t; that's grossly nonconformant.])
+fi
+
 AC_CHECK_SIZEOF(socklen_t, , [AC_INCLUDES_DEFAULT()
 #ifdef HAVE_SYS_SOCKET_H
 #include <sys/socket.h>