summaryrefslogtreecommitdiff
path: root/db-4.8.30/dist/aclocal/socklen.m4
diff options
context:
space:
mode:
Diffstat (limited to 'db-4.8.30/dist/aclocal/socklen.m4')
-rw-r--r--db-4.8.30/dist/aclocal/socklen.m455
1 files changed, 55 insertions, 0 deletions
diff --git a/db-4.8.30/dist/aclocal/socklen.m4 b/db-4.8.30/dist/aclocal/socklen.m4
new file mode 100644
index 0000000..b6c4794
--- /dev/null
+++ b/db-4.8.30/dist/aclocal/socklen.m4
@@ -0,0 +1,55 @@
+dnl Copyright (C) 2005, 2006, 2007 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+
+dnl From Albert Chin, Windows fixes from Simon Josefsson.
+
+dnl Check for socklen_t: historically on BSD it is an int, and in
+dnl POSIX 1g it is a type of its own, but some platforms use different
+dnl types for the argument to getsockopt, getpeername, etc. So we
+dnl have to test to find something that will work.
+
+dnl On mingw32, socklen_t is in ws2tcpip.h ('int'), so we try to find
+dnl it there first. That file is included by gnulib's socket_.h, which
+dnl all users of this module should include. Cygwin must not include
+dnl ws2tcpip.h.
+
+dnl Windows fixes removed for Berkeley DB. Functions renamed, basic check
+dnl remains the same though.
+dnl !!!
+dnl The original version had fixes for MinGW -- if you need those, go back
+dnl and look at the original code.
+
+AC_DEFUN([AM_SOCKLEN_T],[
+ AC_CHECK_TYPE([socklen_t], ,
+ [AC_MSG_CHECKING([for socklen_t equivalent])
+ AC_CACHE_VAL([db_cv_socklen_t_equiv],
+ [# Systems have either "struct sockaddr *" or
+ # "void *" as the second argument to getpeername
+ db_cv_socklen_t_equiv=
+ for arg2 in "struct sockaddr" void; do
+ for t in int size_t "unsigned int" "long int" "unsigned long int"; do
+ AC_TRY_COMPILE([$db_includes
+#ifdef HAVE_SYS_SOCKET_H
+#include <sys/socket.h>
+#endif
+ int getpeername (int, $arg2 *, $t *);],
+ [$t len;
+ getpeername (0, 0, &len);],
+ [db_cv_socklen_t_equiv="$t"])
+ test "$db_cv_socklen_t_equiv" != "" && break
+ done
+ test "$db_cv_socklen_t_equiv" != "" && break
+ done
+ ])
+ if test "$db_cv_socklen_t_equiv" = ""; then
+ AC_MSG_ERROR([Cannot find a type to use in place of socklen_t])
+ fi
+ AC_MSG_RESULT([$db_cv_socklen_t_equiv])
+ AC_DEFINE_UNQUOTED([socklen_t], [$db_cv_socklen_t_equiv],
+ [type to use in place of socklen_t if not defined])],
+ [$db_includes
+#ifdef HAVE_SYS_SOCKET_H
+#include <sys/socket.h>
+#endif])])