Some platforms lack socklen_t type
Some platforms do not have a socklen_t type declaration. Signed-off-by: Gary V. Vaughan <gary@thewrittenword.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
5a857c74ba
commit
e88a135bc5
7
Makefile
7
Makefile
@ -8,6 +8,9 @@ all::
|
|||||||
# Define SANE_TOOL_PATH to a colon-separated list of paths to prepend
|
# Define SANE_TOOL_PATH to a colon-separated list of paths to prepend
|
||||||
# to PATH if your tools in /usr/bin are broken.
|
# to PATH if your tools in /usr/bin are broken.
|
||||||
#
|
#
|
||||||
|
# Define SOCKLEN_T to a suitable type (such as 'size_t') if your
|
||||||
|
# system headers do not define a socklen_t type.
|
||||||
|
#
|
||||||
# Define SNPRINTF_RETURNS_BOGUS if your are on a system which snprintf()
|
# Define SNPRINTF_RETURNS_BOGUS if your are on a system which snprintf()
|
||||||
# or vsnprintf() return -1 instead of number of characters which would
|
# or vsnprintf() return -1 instead of number of characters which would
|
||||||
# have been written to the final string if enough space had been available.
|
# have been written to the final string if enough space had been available.
|
||||||
@ -1087,6 +1090,10 @@ else
|
|||||||
BROKEN_PATH_FIX = '/^\# @@BROKEN_PATH_FIX@@$$/d'
|
BROKEN_PATH_FIX = '/^\# @@BROKEN_PATH_FIX@@$$/d'
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifneq (,$(SOCKLEN_T))
|
||||||
|
BASIC_CFLAGS += -Dsocklen_t=$(SOCKLEN_T)
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(uname_S),Darwin)
|
ifeq ($(uname_S),Darwin)
|
||||||
ifndef NO_FINK
|
ifndef NO_FINK
|
||||||
ifeq ($(shell test -d /sw/lib && echo y),y)
|
ifeq ($(shell test -d /sw/lib && echo y),y)
|
||||||
|
40
aclocal.m4
vendored
Normal file
40
aclocal.m4
vendored
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
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.
|
||||||
|
AC_DEFUN([TYPE_SOCKLEN_T],
|
||||||
|
[
|
||||||
|
AC_CHECK_TYPE([socklen_t], ,[
|
||||||
|
AC_MSG_CHECKING([for socklen_t equivalent])
|
||||||
|
AC_CACHE_VAL([git_cv_socklen_t_equiv],
|
||||||
|
[
|
||||||
|
# Systems have either "struct sockaddr *" or
|
||||||
|
# "void *" as the second argument to getpeername
|
||||||
|
git_cv_socklen_t_equiv=
|
||||||
|
for arg2 in "struct sockaddr" void; do
|
||||||
|
for t in int size_t unsigned long "unsigned long"; do
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
|
||||||
|
int getpeername (int, $arg2 *, $t *);
|
||||||
|
],[
|
||||||
|
$t len;
|
||||||
|
getpeername(0,0,&len);
|
||||||
|
],[
|
||||||
|
git_cv_socklen_t_equiv="$t"
|
||||||
|
break 2
|
||||||
|
])
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
|
if test "x$git_cv_socklen_t_equiv" = x; then
|
||||||
|
AC_MSG_ERROR([Cannot find a type to use in place of socklen_t])
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
AC_MSG_RESULT($git_cv_socklen_t_equiv)
|
||||||
|
AC_DEFINE_UNQUOTED(socklen_t, $git_cv_socklen_t_equiv,
|
||||||
|
[type to use in place of socklen_t if not defined])],
|
||||||
|
[#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>])
|
||||||
|
])
|
@ -58,6 +58,7 @@ NO_INET_PTON=@NO_INET_PTON@
|
|||||||
NO_ICONV=@NO_ICONV@
|
NO_ICONV=@NO_ICONV@
|
||||||
OLD_ICONV=@OLD_ICONV@
|
OLD_ICONV=@OLD_ICONV@
|
||||||
NO_DEFLATE_BOUND=@NO_DEFLATE_BOUND@
|
NO_DEFLATE_BOUND=@NO_DEFLATE_BOUND@
|
||||||
|
SOCKLEN_T=@SOCKLEN_T@
|
||||||
FREAD_READS_DIRECTORIES=@FREAD_READS_DIRECTORIES@
|
FREAD_READS_DIRECTORIES=@FREAD_READS_DIRECTORIES@
|
||||||
SNPRINTF_RETURNS_BOGUS=@SNPRINTF_RETURNS_BOGUS@
|
SNPRINTF_RETURNS_BOGUS=@SNPRINTF_RETURNS_BOGUS@
|
||||||
NO_PTHREADS=@NO_PTHREADS@
|
NO_PTHREADS=@NO_PTHREADS@
|
||||||
|
@ -633,6 +633,12 @@ AC_SUBST(OLD_ICONV)
|
|||||||
## Checks for typedefs, structures, and compiler characteristics.
|
## Checks for typedefs, structures, and compiler characteristics.
|
||||||
AC_MSG_NOTICE([CHECKS for typedefs, structures, and compiler characteristics])
|
AC_MSG_NOTICE([CHECKS for typedefs, structures, and compiler characteristics])
|
||||||
#
|
#
|
||||||
|
TYPE_SOCKLEN_T
|
||||||
|
case $ac_cv_type_socklen_t in
|
||||||
|
yes) ;;
|
||||||
|
*) AC_SUBST([SOCKLEN_T], [$git_cv_socklen_t_equiv]) ;;
|
||||||
|
esac
|
||||||
|
|
||||||
# Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent.
|
# Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent.
|
||||||
AC_CHECK_MEMBER(struct dirent.d_ino,
|
AC_CHECK_MEMBER(struct dirent.d_ino,
|
||||||
[NO_D_INO_IN_DIRENT=],
|
[NO_D_INO_IN_DIRENT=],
|
||||||
|
Loading…
Reference in New Issue
Block a user