summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: f6ac83f)
raw | patch | inline | side by side (parent: f6ac83f)
author | Kalle Wallin <kaw@linux.se> | |
Tue, 6 Apr 2004 19:31:05 +0000 (19:31 +0000) | ||
committer | Kalle Wallin <kaw@linux.se> | |
Tue, 6 Apr 2004 19:31:05 +0000 (19:31 +0000) |
configure.ac | patch | blob | history | |
m4/socklen_t.m4 | [new file with mode: 0644] | patch | blob |
diff --git a/configure.ac b/configure.ac
index b799344121e5c2e9ec590032d852d0c6c4d06cfa..28961b1a2027ec07a3bac48db038ebc93f7d320e 100644 (file)
--- a/configure.ac
+++ b/configure.ac
dnl
dnl Check for types
dnl
-AC_CHECK_TYPE(socklen_t,
- AC_DEFINE(HAVE_SOCKLEN_T, 1, socklen_t defined in sys/socket.h),
-)
+dnl AC_CHECK_TYPE(socklen_t,
+dnl AC_DEFINE(HAVE_SOCKLEN_T, 1, socklen_t defined in sys/socket.h),
+dnl )
+
+AC_SOCKLEN_T
+
+
+
dnl
diff --git a/m4/socklen_t.m4 b/m4/socklen_t.m4
--- /dev/null
+++ b/m4/socklen_t.m4
@@ -0,0 +1,66 @@
+
+dnl Like AC_TRY_EVAL but also errors out if the compiler generates
+dnl _any_ output. Some compilers might issue warnings which we want
+dnl to catch.
+AC_DEFUN([AC_TRY_EVAL2],
+[{ (eval echo configure:__oline__: \"[$]$1\") 1>&AC_FD_CC; dnl
+(eval [$]$1) 2>&AC_FD_CC; _out=`eval [$]$1 2>&1` && test "x$_out" = x; }])
+
+
+dnl Like AC_TRY_COMPILE but calls AC_TRY_EVAL2 instead of AC_TRY_EVAL
+AC_DEFUN([AC_TRY_COMPILE2],
+[cat > conftest.$ac_ext <<EOF
+[#]line __oline__ "configure"
+#include "confdefs.h"
+[$1]
+int main(void) {
+[$2]
+; return 0; }
+EOF
+if AC_TRY_EVAL2(ac_compile); then
+ ifelse([$3], , :, [rm -rf conftest*
+ $3])
+else
+ echo "configure: failed program was:" >&AC_FD_CC
+ cat conftest.$ac_ext >&AC_FD_CC
+ifelse([$4], , , [ rm -rf conftest*
+ $4
+])dnl
+fi
+rm -f conftest*])
+
+dnl Determine what socket length (socklen_t) data type is
+AC_DEFUN([AC_SOCKLEN_T],
+[
+AC_MSG_CHECKING([for type of socket length (socklen_t)])
+AC_TRY_COMPILE2([
+#include <stddef.h>
+#include <sys/types.h>
+#include <sys/socket.h>],[
+(void)getsockopt (1, 1, 1, NULL, (socklen_t *)NULL)],[
+ AC_MSG_RESULT(socklen_t *)
+ SOCKLEN_T=socklen_t],[
+ AC_TRY_COMPILE2([
+#include <stddef.h>
+#include <sys/types.h>
+#include <sys/socket.h>],[
+(void)getsockopt (1, 1, 1, NULL, (size_t *)NULL)],[
+ AC_MSG_RESULT(size_t *)
+ SOCKLEN_T=size_t],[
+ AC_TRY_COMPILE2([
+#include <stddef.h>
+#include <sys/types.h>
+#include <sys/socket.h>],[
+(void)getsockopt (1, 1, 1, NULL, (int *)NULL)],[
+ AC_MSG_RESULT(int *)
+ SOCKLEN_T=int],[
+ AC_MSG_WARN(could not determine)
+ SOCKLEN_T="unsigned int"])])])
+
+if test "$SOCKLEN_T" = socklen_t; then
+ AC_DEFINE(HAVE_SOCKLEN_T, 1, socklen_t defined in sys/socket.h)
+fi
+
+AC_DEFINE_UNQUOTED(SOCKLEN_T, $SOCKLEN_T, [Determine what socket length (socklen_t) data type is])
+
+])