X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=configure.in;h=c9516371cc33c2d30873fa097d1f912a811444c7;hp=bae72e31c369b3a1e46c6f8c201584f66d73a288;hb=9d469a19691f9749b5d729a1ae903d7aa224a6e8;hpb=7926a156e5b118d06295228e57de0cc9de0433b4 diff --git a/configure.in b/configure.in index bae72e31..c9516371 100644 --- a/configure.in +++ b/configure.in @@ -9,9 +9,6 @@ AM_INIT_AUTOMAKE(tinc, 1.0-cvs) AC_CONFIG_HEADERS([config.h]) AM_MAINTAINER_MODE -dnl Include the macros from the m4/ directory -AM_ACLOCAL_INCLUDE(m4) - AM_GNU_GETTEXT([external]) AM_GNU_GETTEXT_VERSION(0.12.1) @@ -26,11 +23,8 @@ ALL_LINGUAS="nl" dnl Checks for programs. AC_PROG_CC AC_PROG_CPP -AC_PROG_GCC_TRADITIONAL -AC_PROG_AWK AC_PROG_INSTALL AC_PROG_LN_S -AC_PROG_MAKE_SET AC_PROG_RANLIB AC_ISC_POSIX @@ -46,11 +40,11 @@ case $host_os in ;; *freebsd*) AC_DEFINE(HAVE_FREEBSD, 1, [FreeBSD]) - [ rm -f src/device.c; ln -sf freebsd/device.c src/device.c ] + [ rm -f src/device.c; ln -sf bsd/device.c src/device.c ] ;; *darwin*) AC_DEFINE(HAVE_DARWIN, 1, [Darwin (MacOS/X)]) - [ rm -f src/device.c; ln -sf darwin/device.c src/device.c ] + [ rm -f src/device.c; ln -sf bsd/device.c src/device.c ] ;; *solaris*) AC_DEFINE(HAVE_SOLARIS, 1, [Solaris/SunOS]) @@ -58,11 +52,16 @@ case $host_os in ;; *openbsd*) AC_DEFINE(HAVE_OPENBSD, 1, [OpenBSD]) - [ rm -f src/device.c; ln -sf openbsd/device.c src/device.c ] + [ rm -f src/device.c; ln -sf bsd/device.c src/device.c ] ;; *netbsd*) AC_DEFINE(HAVE_NETBSD, 1, [NetBSD]) - [ rm -f src/device.c; ln -sf netbsd/device.c src/device.c ] + [ rm -f src/device.c; ln -sf bsd/device.c src/device.c ] + ;; + *bsd*) + AC_MSG_WARN("Unknown BSD variant, tinc might not compile or work!") + AC_DEFINE(HAVE_BSD, 1, [Unknown BSD variant]) + [ rm -f src/device.c; ln -sf bsd/device.c src/device.c ] ;; *cygwin*) AC_DEFINE(HAVE_CYGWIN, 1, [Cygwin]) @@ -93,99 +92,15 @@ dnl Checks for header files. dnl We do this in multiple stages, because unlike Linux all the other operating systems really suck and don't include their own dependencies. AC_HEADER_STDC -AC_CHECK_HEADERS([stdbool.h syslog.h sys/file.h sys/ioctl.h sys/param.h sys/time.h sys/socket.h sys/wait.h sys/mman.h netdb.h arpa/inet.h]) -AC_CHECK_HEADERS([net/if.h net/ethernet.h net/if_arp.h netinet/in_systm.h netinet/in.h netinet/in6.h], - [], [], - [#ifdef HAVE_SYS_TYPES_H - #include - #endif - #ifdef HAVE_NETDB_H - #include - #endif - #ifdef HAVE_ARPA_INET_H - #include - #endif - #ifdef HAVE_SYS_SOCKET_H - #include - #endif - ] +AC_CHECK_HEADERS([stdbool.h syslog.h sys/file.h sys/ioctl.h sys/mman.h sys/param.h sys/socket.h sys/time.h sys/uio.h sys/wait.h netdb.h arpa/inet.h]) +AC_CHECK_HEADERS([net/if.h net/if_types.h net/if_tun.h net/if_tap.h net/ethernet.h net/if_arp.h netinet/in_systm.h netinet/in.h netinet/in6.h], + [], [], [#include "have.h"] ) AC_CHECK_HEADERS([netinet/if_ether.h netinet/ip.h netinet/ip6.h], - [], [], - [#ifdef HAVE_SYS_TYPES_H - #include - #endif - #ifdef HAVE_NETDB_H - #include - #endif - #ifdef HAVE_ARPA_INET_H - #include - #endif - #ifdef HAVE_SYS_SOCKET_H - #include - #endif - #ifdef HAVE_NET_IF_H - #include - #endif - #ifdef HAVE_NETINET_IN_SYSTM_H - #include - #endif - #ifdef HAVE_NETINET_IN_H - #include - #endif - #ifdef HAVE_NETINET_IN6_H - #include - #endif - #ifdef HAVE_NET_ETHERNET_H - #include - #endif - #ifdef HAVE_NET_IF_ARP_H - #include - #endif - ] + [], [], [#include "have.h"] ) AC_CHECK_HEADERS([netinet/tcp.h netinet/ip_icmp.h netinet/icmp6.h], - [], [], - [#ifdef HAVE_SYS_TYPES_H - #include - #endif - #ifdef HAVE_NETDB_H - #include - #endif - #ifdef HAVE_ARPA_INET_H - #include - #endif - #ifdef HAVE_SYS_SOCKET_H - #include - #endif - #ifdef HAVE_NET_IF_H - #include - #endif - #ifdef HAVE_NETINET_IN_SYSTM_H - #include - #endif - #ifdef HAVE_NETINET_IN_H - #include - #endif - #ifdef HAVE_NETINET_IP_H - #include - #endif - #ifdef HAVE_NETINET_IN6_H - #include - #endif - #ifdef HAVE_NETINET_IP6_H - #include - #endif - #ifdef HAVE_NET_ETHERNET_H - #include - #endif - #ifdef HAVE_NET_IF_ARP_H - #include - #endif - #ifdef HAVE_NETINET_IF_ETHER_H - #include - #endif - ] + [], [], [#include "have.h"] ) dnl Checks for typedefs, structures, and compiler characteristics. @@ -199,62 +114,16 @@ AC_STRUCT_TM tinc_ATTRIBUTE(__malloc__) AC_CHECK_TYPES([socklen_t, struct ether_header, struct arphdr, struct ether_arp, struct in_addr, struct addrinfo, struct ip, struct icmp, struct in6_addr, struct sockaddr_in6, struct ip6_hdr, struct icmp6_hdr, struct nd_neighbor_solicit, struct nd_opt_hdr], , , - [#ifdef HAVE_SYS_TYPES_H - #include - #endif - #ifdef HAVE_NETDB_H - #include - #endif - #ifdef HAVE_ARPA_INET_H - #include - #endif - #ifdef HAVE_SYS_SOCKET_H - #include - #endif - #ifdef HAVE_NET_IF_H - #include - #endif - #ifdef HAVE_NETINET_IN_SYSTM_H - #include - #endif - #ifdef HAVE_NETINET_IN_H - #include - #endif - #ifdef HAVE_NETINET_IP_H - #include - #endif - #ifdef HAVE_NETINET_TCP_H - #include - #endif - #ifdef HAVE_NETINET_IN6_H - #include - #endif - #ifdef HAVE_NETINET_IP6_H - #include - #endif - #ifdef HAVE_NET_ETHERNET_H - #include - #endif - #ifdef HAVE_NET_IF_ARP_H - #include - #endif - #ifdef HAVE_NETINET_IF_ETHER_H - #include - #endif - #ifdef HAVE_NETINET_IP_ICMP_H - #include - #endif - #ifdef HAVE_NETINET_ICMP6_H - #include - #endif - ] + [#include "have.h"] ) dnl Checks for library functions. AC_FUNC_MEMCMP AC_FUNC_ALLOCA AC_TYPE_SIGNAL -AC_CHECK_FUNCS([asprintf daemon fchmod flock ftime fork get_current_dir_name gettimeofday mlockall putenv random select strdup strerror strsignal strtol system unsetenv vsyslog]) +AC_CHECK_FUNCS([asprintf daemon fchmod flock ftime fork get_current_dir_name gettimeofday mlockall putenv random select strdup strerror strsignal strtol system unsetenv vsyslog writev], + [], [], [#include "have.h"] +) jm_FUNC_MALLOC jm_FUNC_REALLOC @@ -267,7 +136,9 @@ AC_CHECK_FUNC(gethostbyname, [], [ AC_CHECK_LIB(nsl, gethostbyname) ]) -AC_CHECK_FUNCS([freeaddrinfo gai_strerror getaddrinfo getnameinfo inet_aton]) +AC_CHECK_FUNCS([freeaddrinfo gai_strerror getaddrinfo getnameinfo inet_aton], + [], [], [#include "have.h"] +) AC_CACHE_SAVE @@ -297,6 +168,6 @@ AC_ARG_ENABLE(tracing, AC_SUBST(INCLUDES) -AC_CONFIG_FILES([Makefile src/Makefile doc/Makefile doc/tincd.8 doc/tinc.conf.5 doc/tincinclude.texi lib/Makefile po/Makefile.in m4/Makefile]) +AC_CONFIG_FILES([Makefile src/Makefile doc/Makefile lib/Makefile po/Makefile.in m4/Makefile]) AC_OUTPUT