diff options
author | Nick Mathewson <nickm@torproject.org> | 2011-01-12 13:05:19 -0500 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2011-01-12 13:05:19 -0500 |
commit | a84c6e86fe3e739a21094cf1e02dd5d7d54056e4 (patch) | |
tree | 55146c22802ab6be5d22f35fe4394e98b9f24e90 | |
parent | 71d786b2d353715031cd3c3ef2dd7fc46b44489b (diff) | |
parent | a2c41aa3e84ba697cc14b4b2345d8e3467cd22ac (diff) | |
download | tor-a84c6e86fe3e739a21094cf1e02dd5d7d54056e4.tar.gz tor-a84c6e86fe3e739a21094cf1e02dd5d7d54056e4.zip |
Merge remote branch 'origin/maint-0.2.2'
-rw-r--r-- | changes/bug2337 | 3 | ||||
-rw-r--r-- | configure.in | 17 |
2 files changed, 20 insertions, 0 deletions
diff --git a/changes/bug2337 b/changes/bug2337 new file mode 100644 index 0000000000..a4f052dc31 --- /dev/null +++ b/changes/bug2337 @@ -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. diff --git a/configure.in b/configure.in index be1ee33ca2..eddab6707b 100644 --- a/configure.in +++ b/configure.in @@ -784,6 +784,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> |