]> arthur.barton.de Git - netatalk.git/blobdiff - configure.in
Changes made by Michel Jouvin - jouvin@lal.in2p3.fr - 23/11/2000
[netatalk.git] / configure.in
index 1dd181a72fba2dbef584e773330a001a9c5a7243..b18a02a7acfa70029864f3a93b51bfeb116272f6 100644 (file)
@@ -8,6 +8,7 @@ AC_SUBST(NETATALK_VERSION)
 AC_CANONICAL_SYSTEM
 AM_INIT_AUTOMAKE(netatalk, ${NETATALK_VERSION})
 AM_CONFIG_HEADER(config.h)
+AM_PROG_LIBTOOL
 
 dnl Reset locations to proper places
 AC_PREFIX_DEFAULT(/usr)
@@ -38,14 +39,10 @@ dnl Replace `main' with a function in -lcom_err:
 AC_CHECK_LIB(com_err, main)
 dnl Replace `main' with a function in -lcrypt:
 AC_CHECK_LIB(crypt, main)
-dnl Replace `main' with a function in -lcrypto:
-AC_CHECK_LIB(crypto, main)
 dnl Replace `main' with a function in -ld:
 AC_CHECK_LIB(d, main)
 dnl Replace `main' with a function in -ldb:
 AC_CHECK_LIB(db, main)
-dnl Replace `main' with a function in -ldes:
-AC_CHECK_LIB(des, main)
 dnl Replace `main' with a function in -ldl:
 AC_CHECK_LIB(dl, main)
 dnl Replace `main' with a function in -lkauth:
@@ -75,11 +72,41 @@ AC_CHECK_LIB(sys, main)
 dnl Replace `main' with a function in -lubik:
 AC_CHECK_LIB(ubik, main)
 
+#
+# Check presence of some functions
+#
+# Check for XPG4 access() function
+# Be sure to test before adding AFS libs in LIBS path as AFS lib
+# has such a function that works only on AFS filesystems.
+AC_CHECK_FUNCS(access)
+
 dnl Checks for header files.
 AC_HEADER_DIRENT
 AC_HEADER_STDC
 AC_HEADER_SYS_WAIT
-AC_CHECK_HEADERS(fcntl.h limits.h strings.h sys/file.h sys/ioctl.h sys/time.h syslog.h unistd.h)
+AC_CHECK_HEADERS(fcntl.h limits.h stdint.h strings.h sys/file.h sys/ioctl.h sys/time.h syslog.h unistd.h termios.h netdb.h)
+AC_CHECK_HEADER(sys/cdefs.h,,
+       AC_MSG_RESULT([enabling generic cdefs.h from tree])
+       CFLAGS="-I\$(top_srcdir)/sys/generic $CFLAGS"
+)
+
+# Allow user to specify flags
+AC_ARG_WITH(cflags,
+       [  --with-cflags           specify additional flags to pass to compiler],
+       [
+               if test "x$withval" != "xno" ; then
+                       CFLAGS="$CFLAGS $withval"
+               fi
+       ]       
+)
+AC_ARG_WITH(libs,
+       [  --with-libs             specify additional libraries to link with],
+       [
+               if test "x$withval" != "xno" ; then
+                       LIBS="$LIBS $withval"
+               fi
+       ]
+)
 
 dnl Checks for typedefs, structures, and compiler characteristics.
 AC_C_CONST
@@ -102,18 +129,22 @@ AC_FUNC_MMAP
 AC_TYPE_SIGNAL
 AC_FUNC_UTIME_NULL
 AC_FUNC_WAIT3
-AC_CHECK_FUNCS(getcwd gethostname gettimeofday getusershell mkdir rmdir select socket strdup strstr strtoul)
+AC_CHECK_FUNCS(getcwd gethostname gettimeofday getusershell mkdir rmdir select socket strdup strstr strtoul setpgrp)
+AC_FUNC_SETPGRP
 
 dnl --------------------------------------------------------------------------
 dnl specific configuration comes in here:
 dnl --------------------------------------------------------------------------
 
+AC_DEFINE(ADMIN_GRP, 1)
+
 AC_ARG_WITH(admin-group,
-       [  --with-admin-group=grp  enable and set administrative group],
-       admin_grp="$withval"
-       AC_DEFINE_UNQUOTED(ADMIN_GRP, "$admin_grp")
-       AC_MSG_RESULT([enabling administrative group "$admin_grp"]),
-)
+       [  --disable-admin-group  disable admin group],
+        if test "$enableval" = "no"; then
+               AC_DEFINE(ADMIN_GRP, 0)
+               AC_MSG_RESULT([disabling administrative group support])
+        fi
+ )
 
 AC_ARG_WITH(auth-printing-dir,
        [  --with-auth-printing-dir=path
@@ -133,36 +164,67 @@ AC_DEFINE_UNQUOTED(CONFIG_DIR, "$config_dir",
        [path to config dir [default=/etc/atalk]])
 CONFIG_DIR="$config_dir"
 AC_SUBST(CONFIG_DIR)
-AC_MSG_RESULT([setting configuration files location to $CONFIG_DIR]),
+AC_MSG_RESULT([setting configuration files location to $CONFIG_DIR])
 
-AC_ARG_WITH(crackdict,
+AC_ARG_WITH(cracklib,
        [  --with-cracklib=dict    enable/set location of cracklib dictionary],
-       crackdict="$withval"
+       cracklib="$withval"
        AC_CHECK_LIB(crack, main,
                AC_DEFINE(USE_CRACKLIB) 
                LIBS="$LIBS -lcrack"
                AC_MSG_RESULT([enabling cracklib support])
-               if test x"$crackdict" = "x"; then
-                       crackdict="$prefix/lib/cracklib_dict"
+               if test "$cracklib" = "yes"; then
+                       cracklib="/usr/lib/cracklib_dict"
                fi
-               AC_DEFINE_UNQUOTED(_PATH_CRACKLIB, "$crackdict",
+               AC_DEFINE_UNQUOTED(_PATH_CRACKLIB, "$cracklib",
                        [path to cracklib dictionary])
-               AC_MSG_RESULT([setting cracklib dictionary to $crackdict]),
+               AC_MSG_RESULT([setting cracklib dictionary to $cracklib]),
                AC_MSG_ERROR([cracklib not found!])
        )
 )
 
 AC_ARG_ENABLE(ddp,
-       [  --disable-ddp           disable DDP],,
-       AC_DEFINE(NO_DDP, 1)
-       AC_MSG_RESULT([disabling DDP])
+       [  --disable-ddp           disable DDP],
+       if test "$enableval" = "no"; then 
+               AC_DEFINE(NO_DDP, 1)
+               AC_MSG_RESULT([disabling DDP])
+       fi
 )
 
 AC_ARG_ENABLE(debug,
        [  --enable-debug          enable debug code],
-       AC_DEFINE(DEBUG, 1)
-       AC_MSG_RESULT([enabling debugging code]),
-       AC_DEFINE(DEBUG, 0)
+       if test "$enableval" != "no"; then
+               if test "$enableval" = "yes"; then
+                       AC_DEFINE(DEBUG, 1)
+               else
+                       AC_DEFINE_UNQUOTED(DEBUG, $enableval)
+               fi 
+               AC_MSG_RESULT([enabling debugging code])
+       else
+               AC_DEFINE(DEBUG, 0)
+       fi
+)
+
+
+dnl ----------- A NOTE ABOUT DROPKLUDGE
+dnl The trouble with this fix is that if you know what the file is called, it
+dnl can be read from the Unix side.  That's okay for most academic institutions
+dnl since the students don't have telnet access to the Mac servers.  There is
+dnl currently no one working on further development/fixes of DROPKLUDGE.
+dnl -----------
+
+AC_ARG_ENABLE(dropkludge,
+       [  --enable-dropkludge     enable the experimental dropbox fix (INSECURE!) ],
+       AC_DEFINE(DROPKLUDGE, 1)
+       AC_MSG_RESULT([enabling experimental dropbox support])
+)
+
+AC_ARG_ENABLE(lastdid,
+       [  --enable-lastdid        enable build without DID dev/inode mapping kludge],
+       if test "$enableval" = "yes"; then 
+               AC_DEFINE(USE_LASTDID, 1)
+               AC_MSG_RESULT([enabling build without DID dev/inode mapping kludge])
+       fi
 )
 
 msg_dir=""
@@ -178,14 +240,21 @@ AC_ARG_WITH(message-dir,
                AC_SUBST(SERVERTEXT)
 )
 
+AC_CHECK_LIB(pam, pam_start,
+       AC_DEFINE(USE_PAM, 1)
+       LIBS="$LIBS -lpam"
+       compile_pam=yes)
+AM_CONDITIONAL(BUILD_PAM, test x$compile_pam = xyes)
+
 AC_ARG_WITH(pam,
        [  --with-pam              enable password authentication modules support],
-       AC_CHECK_LIB(pam, main,
-               AC_DEFINE(USE_PAM)
-               LIBS="$LIBS -lpam"
+       if test "x$compile_pam" = "xyes"; then
+               use_pam_so=yes
                AC_MSG_RESULT([enabling pam modules support])
+       else
+               AC_MSG_RESULT([pam libraries not found. Disabling pam modules support])
+       fi
        )
-)
 
 AC_ARG_WITH(shadow,
        [  --with-shadow           enable shadow password support],
@@ -208,10 +277,26 @@ AC_ARG_WITH(tcp-wrappers,
        )
 )
 
+AC_ARG_ENABLE(redhat,
+       [  --enable-redhat     use redhat-style sysv configuration ],
+    if test "$enableval" = "yes"; then
+               sysv_style=redhat
+       fi
+       AC_MSG_RESULT([enabling redhat-style sysv support])
+)
+
+AC_ARG_ENABLE(cobalt,
+       [  --enable-cobalt     use cobalt-style sysv configuration ],
+    if test "$enableval" = "yes"; then
+               sysv_style=cobalt
+       fi
+       AC_MSG_RESULT([enabling cobalt-style sysv support])
+)
+
 AC_ARG_WITH(uams-path,
        [  --with-uams-path=path   path to UAMs [default=/etc/atalk/uams]],
        uams_path="$withval",
-       uams_path="/etc/atalk/uams"
+       uams_path="$config_dir/uams"
 )
 AC_DEFINE_UNQUOTED(UAMS_PATH, "$uams_path",
        [path to UAMs [default=/etc/atalk/uams]])
@@ -223,27 +308,166 @@ dnl drop in includes for top level directory structures here...
 dnl --------------------------------------------------------------------------
 LIBS="$LIBS -L\$(top_srcdir)/libatalk/"
 CFLAGS="$CFLAGS -I\$(top_srcdir)/include -I\$(top_srcdir)/sys"
-AC_SUBST(LIBS)
-AC_SUBST(CFLAGS)
 
 dnl --------------------------------------------------------------------------
 dnl specific configuration comes in here:
 dnl --------------------------------------------------------------------------
 
+dnl ac_cv_target_os is now host_os, ac_cv_target_cpu is now host_cpu
+
 dnl --------------------- determine operating system from "target"
-case "$target" in
-*linux*)   this_os=linux ;;
-*solaris*) this_os=solaris ;;
+case "$host_os" in
+       *freebsd*)                      this_os=freebsd ;;
+       *linux*)                        this_os=linux ;;
+       *osx*)                          this_os=macosx ;;
+       *netbsd*)                       this_os=netbsd ;;
+       *openbsd*)                      this_os=openbsd ;;
+       *osf*)                          this_os=tru64 ;;
+       *solaris*)                      this_os=solaris ;;
 esac
 
-dnl --------------------- conditional libraries, etc from "target"
+case "$host_cpu" in
+       i386|i486|i586|i686|k7)         this_cpu=x86 ;;
+       alpha)                          this_cpu=alpha ;;
+       mips)                           this_cpu=mips ;;
+       powerpc|ppc)                    this_cpu=ppc ;;
+esac
+
+dnl --------------------- operating system specific flags (port from sys/*)
+
+dnl ----- FreeBSD specific -----
+if test x"$this_os" = "xfreebsd"; then 
+       AC_MSG_RESULT([ * FreeBSD specific configuration])
+       AC_DEFINE(BSD4_4)
+       AC_DEFINE(SENDFILE_FLAVOR_BSD)
+fi
+
+dnl ----- Linux specific -----
+if test x"$this_os" = "xlinux"; then 
+       AC_MSG_RESULT([ * Linux specific configuration])
+       AC_DEFINE(SENDFILE_FLAVOR_LINUX)
+
+       dnl ----- check if we need the quotactl wrapper
+       AC_CHECK_HEADER(sys/quota.h,,
+               AC_MSG_RESULT([enabling quotactl wrapper])
+               AC_DEFINE(NEED_QUOTACTL_WRAPPER)
+       )
+
+       dnl ----- Linux/alpha specific -----
+       if test x"$this_cpu" = "xalpha"; then 
+               AC_MSG_RESULT([enabling gcc memcpy bug workaround])
+               AC_DEFINE(HAVE_GCC_MEMCPY_BUG)
+       fi
+       need_dash_r=no
+fi
+
+dnl ----- Mac OSX specific -----
+if test x"$this_os" = "xmacosx"; then 
+       AC_MSG_RESULT([ * Mac OSX specific configuration])
+       AC_DEFINE(BSD4_4)
+       AC_DEFINE(HAVE_BROKEN_CPP)
+       AC_DEFINE(HAVE_2ARG_DBTOB)
+       AC_DEFINE(NO_DLFCN_H)
+       AC_DEFINE(MACOSX_SERVER)
+fi
+
+dnl ----- NetBSD specific -----
+if test x"$this_os" = "xnetbsd"; then 
+       AC_MSG_RESULT([ * NetBSD specific configuration])
+       AC_DEFINE(BSD4_4)
+       AC_DEFINE(DLSYM_PREPEND_UNDERSCORE)
+       CFLAGS="-I\$(top_srcdir)/sys/netbsd -I/usr/include/kerberosIV $CFLAGS"
+       need_dash_r=yes 
+fi
+
+dnl ----- OpenBSD specific -----
+if test x"$this_os" = "xopenbsd"; then 
+       AC_MSG_RESULT([ * OpenBSD specific configuration])
+       AC_DEFINE(BSD4_4)
+fi
+
+dnl ----- Solaris specific -----
+if test x"$this_os" = "xsolaris"; then 
+       AC_MSG_RESULT([ * Solaris specific configuration])
+       AC_DEFINE(__svr4__)
+       AC_DEFINE(_ISOC9X_SOURCE)
+       AC_DEFINE(NO_STRUCT_TM_GMTOFF)
+       AC_DEFINE(SOLARIS)
+       CFLAGS="-I\$(top_srcdir)/sys/generic $CFLAGS"
+       need_dash_r=yes
+fi
+
+dnl ----- Tru64 specific -----
+if test x"$this_os" = "xtru64"; then 
+       AC_MSG_RESULT([ * Tru64 specific configuration])
+       AC_DEFINE(NO_DDP)
+       AC_DEFINE(HAVE_64BIT_LONGS)
+       AC_DEFINE(USE_MOUNT_H)
+       AC_DEFINE(USE_OLD_RQUOTA)
+       AC_DEFINE(USE_UFS_QUOTA_H)
+       AC_DEFINE(TRU64)
+       CFLAGS="-I\$(top_srcdir)/sys/tru64 $CFLAGS"
+       LDSHAREDFLAGS="-expect_unresolved \*"
+       need_dash_r=no
+       sysv_style=tru64
+fi
+
+dnl -- look for openssl  
+AC_ARG_WITH(ssl-dir,
+       [  --with-ssl-dir=PATH     specify path to openssl installation (must contain
+                          lib and include dirs) ],
+       [
+               if test "x$withval" != "$xno"; then
+                       tryssldir=$withval
+               fi
+       ]
+)
+
+for ssldir in "" $tryssldir /usr /usr/local/openssl /usr/lib/openssl/ /usr/local/ssl /usr/lib/ssl /usr/local /usr/pkg /opt /opt/openssl ; do
+       if test -f "$ssldir/include/openssl/cast.h" ; then
+               LIBS="$LIBS -L$ssldir/lib -L$ssldir"
+               CFLAGS="$CFLAGS -I$ssldir/include -I$ssldir/include/openssl"
+               if test "$need_dash_r" = "yes"; then
+                       LIBS="$LIBS -R$ssldir/lib -R$ssldir"
+               fi
+
+               dnl Check for the crypto library:
+               AC_CHECK_LIB(crypto, main)
+               dnl LIBS="$LIBS -lcrypto"
+               dnl Check for "DES" library (for SSLeay, not openssl):
+               AC_CHECK_LIB(des, main)
+
+               AC_DEFINE(OPENSSL_DHX,  1)
+               AC_DEFINE(UAM_DHX,      1)
+dnl            AC_DEFINE(UAM_PGP,      1)
+               AC_DEFINE(UAM_RNDNUM,   1)
+               use_pgp=no
+               compile_dhx=yes
+               AC_MSG_RESULT([Found ssl and enabling RANDNUM and DHX support "$ssldir"])
+               break
+       fi
+done
+
+dnl --------------------- last minute substitutions
+
+AC_SUBST(LIBS)
+AC_SUBST(CFLAGS)
+AC_SUBST(LDSHAREDFLAGS)
+AM_CONDITIONAL(USE_DHX, test x$compile_dhx = xyes)
+AM_CONDITIONAL(USE_PAM_SO, test x$use_pam_so = xyes)
+AM_CONDITIONAL(USE_PAM, test x$compile_pam = xyes)
+AM_CONDITIONAL(USE_PGP, test x$compile_pgp = xyes)
+AM_CONDITIONAL(USE_COBALT, test x$sysv_style = xcobalt)
+AM_CONDITIONAL(USE_REDHAT, test x$sysv_style = xredhat)
+AM_CONDITIONAL(USE_TRU64, test x$sysv_style = xtru64)
 
-dnl List of Makefiles to generate
+dnl --------------------- generate files
 
 AC_OUTPUT([Makefile
        bin/Makefile
        bin/adv1tov2/Makefile
        bin/aecho/Makefile
+       bin/afile/Makefile
        bin/afppasswd/Makefile
        bin/getzones/Makefile
        bin/megatron/Makefile
@@ -254,11 +478,12 @@ AC_OUTPUT([Makefile
        contrib/Makefile
        contrib/nu/Makefile
        contrib/printing/Makefile
+       contrib/shell_utils/Makefile
+       contrib/timelord/Makefile
        distrib/Makefile
        distrib/config/Makefile
        distrib/config/netatalk-config
        distrib/initscripts/Makefile
-       distrib/initscripts/rc.atalk.redhat
        distrib/m4/Makefile
        etc/Makefile
        etc/afpd/Makefile
@@ -282,10 +507,11 @@ AC_OUTPUT([Makefile
        man/man1/Makefile
        man/man3/Makefile
        man/man4/Makefile
+       man/man5/Makefile
        man/man8/Makefile
        sys/Makefile
        sys/netatalk/Makefile
        ],
-       [chmod a+x distrib/config/netatalk-config]
+       [chmod a+x distrib/config/netatalk-config contrib/shell_utils/apple_*]
 )