1 dnl Process this file with autoconf to produce a configure script.
2 AC_REVISION($Revision$)
4 test -z "$CFLAGS" && CFLAGS="-g"
5 AC_INIT([Heimdal],[0.8-RC1],[heimdal-bugs@pdc.kth.se])
6 AC_CONFIG_SRCDIR([kuser/kinit.c])
7 AC_CONFIG_HEADERS(include/config.h)
9 AM_INIT_AUTOMAKE([foreign no-dependencies 1.8])
12 dnl Checks for programs.
17 AC_PREFIX_DEFAULT(/usr/heimdal)
19 test "$sysconfdir" = '${prefix}/etc' && sysconfdir='/etc'
20 test "$localstatedir" = '${prefix}/var' && localstatedir='/var/heimdal'
24 AC_SUBST(CANONICAL_HOST)
26 dnl Hints for autobuild
32 dnl this is needed to run the configure tests against glibc
34 AC_DEFINE([_GNU_SOURCE], 1,
35 [Define to enable extensions on glibc-based systems such as Linux.])
49 libdir="$libdir$abilibdirext"
55 rk_WFLAGS(-Wall -Wmissing-prototypes -Wpointer-arith -Wbad-function-cast -Wmissing-declarations -Wnested-externs)
57 rk_TEST_PACKAGE(openldap,
60 [-lldap -llber],,,OPENLDAP)
62 AC_ARG_ENABLE(hdb-openldap-module,
63 AS_HELP_STRING([--enable-hdb-openldap-module],
64 [if you want support to build openldap hdb as shared object]))
65 if test "$enable_hdb_openldap_module" = yes -a "$with_openldap" = yes; then
66 AC_DEFINE(OPENLDAP_MODULE, 1, [Define if you want support for hdb ldap module])
68 AM_CONDITIONAL(OPENLDAP_MODULE, test "$enable_hdb_openldap_module" = yes -a "$with_openldap" = yes)
70 AC_ARG_ENABLE(pk-init,
71 AS_HELP_STRING([--disable-pk-init],
72 [if you want disable to PK-INIT support]))
73 if test "$enable_pk_init" != no ;then
74 AC_DEFINE([PKINIT], 1, [Define to enable PKINIT.])
76 AM_CONDITIONAL(PKINIT, test "$enable_pk_init" != no)
79 rk_TEST_PACKAGE(krb4,[#include <krb.h>],-lkrb,-ldes,/usr/athena, KRB4, krb4-config)
82 if test "$with_krb4" != "no"; then
84 CFLAGS="$CFLAGS $INCLUDE_krb4"
86 LIBS="$LIB_krb4 $LIBS"
89 AC_CACHE_CHECK(for four valued krb_put_int, ac_cv_func_krb_put_int_four,
90 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <krb.h>]], [[
92 krb_put_int(17, tmp, 4, sizeof(tmp));]])],
93 [ac_cv_func_krb_put_int_four=yes],
94 [ac_cv_func_krb_put_int_four=no])
96 if test "$ac_cv_func_krb_put_int_four" = yes; then
97 AC_DEFINE(HAVE_FOUR_VALUED_KRB_PUT_INT, 1,
98 [define if krb_put_int takes four arguments.])
100 AH_BOTTOM([#if defined(HAVE_FOUR_VALUED_KRB_PUT_INT) || !defined(KRB4)
101 #define KRB_PUT_INT(F, T, L, S) krb_put_int((F), (T), (L), (S))
103 #define KRB_PUT_INT(F, T, L, S) krb_put_int((F), (T), (S))
106 AC_CACHE_CHECK(for KRB_VERIFY_SECURE, ac_cv_func_krb_verify_secure,
107 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <krb.h>]], [[
108 int x = KRB_VERIFY_SECURE]])],
109 [ac_cv_func_krb_verify_secure=yes],
110 [ac_cv_func_krb_verify_secure=no])
112 if test "$ac_cv_func_krb_verify_secure" != yes; then
113 AC_DEFINE(KRB_VERIFY_SECURE, 1,
114 [Define to one if your krb.h doesn't])
115 AC_DEFINE(KRB_VERIFY_SECURE_FAIL, 2,
116 [Define to two if your krb.h doesn't])
118 AC_CACHE_CHECK(for KRB_VERIFY_NOT_SECURE,
119 ac_cv_func_krb_verify_not_secure,
120 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <krb.h>]], [[
121 int x = KRB_VERIFY_NOT_SECURE]])],
122 [ac_cv_func_krb_verify_not_secure=yes],
123 [ac_cv_func_krb_verify_not_secure=no])
125 if test "$ac_cv_func_krb_verify_not_secure" != yes; then
126 AC_DEFINE(KRB_VERIFY_NOT_SECURE, 0,
127 [Define to zero if your krb.h doesn't])
129 AC_FIND_FUNC(krb_enable_debug)
130 AC_FIND_FUNC(krb_disable_debug)
131 AC_FIND_FUNC(krb_get_our_ip_for_realm)
132 AC_FIND_FUNC(krb_kdctimeofday)
134 [#ifndef HAVE_KRB_KDCTIMEOFDAY
135 #define krb_kdctimeofday(X) gettimeofday((X), NULL)
137 AC_FIND_FUNC(krb_get_kdc_time_diff)
139 [#ifndef HAVE_KRB_GET_KDC_TIME_DIFF
140 #define krb_get_kdc_time_diff() (0)
142 AC_CACHE_CHECK([for KRB_SENDAUTH_VERS],
143 ac_cv_func_krb_sendauth_vers,
144 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <krb.h>
145 #include <prot.h>]], [[
146 char *x = KRB_SENDAUTH_VERS]])],
147 [ac_cv_func_krb_sendauth_vers=yes],
148 [ac_cv_func_krb_sendauth_vers=no])
150 if test "$ac_cv_func_krb_sendauth_vers" != yes; then
151 AC_DEFINE(KRB_SENDAUTH_VERS, ["AUTHV0.1"],
152 [This is the krb4 sendauth version.])
154 AC_CACHE_CHECK(for krb_mk_req with const arguments,
155 ac_cv_func_krb_mk_req_const,
156 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <krb.h>
157 int krb_mk_req(KTEXT a, const char *s, const char *i,
158 const char *r, int32_t checksum)
159 { return 17; }]], [[]])],
160 [ac_cv_func_krb_mk_req_const=yes],
161 [ac_cv_func_krb_mk_req_const=no])
163 if test "$ac_cv_func_krb_mk_req_const" = "yes"; then
164 AC_DEFINE(KRB_MK_REQ_CONST, 1,
165 [Define if krb_mk_req takes const char *])
169 CFLAGS="$save_CFLAGS"
170 LIB_kdb="-lkdb -lkrb"
172 AM_CONDITIONAL(KRB4, test "$with_krb4" != "no")
173 AM_CONDITIONAL(KRB5, true)
174 AM_CONDITIONAL(do_roken_rename, true)
176 AC_DEFINE(KRB5, 1, [Enable Kerberos 5 support in applications.])dnl
184 AS_HELP_STRING([--enable-dce],[if you want support for DCE/DFS PAG's]))
185 if test "$enable_dce" = yes; then
186 AC_DEFINE(DCE, 1, [Define if you want support for DCE/DFS PAG's.])
188 AM_CONDITIONAL(DCE, test "$enable_dce" = yes)
190 ## XXX quite horrible:
191 if test -f /etc/ibmcxx.cfg; then
192 dpagaix_ldadd=`sed -n '/^xlc_r4/,/^$/p' /etc/ibmcxx.cfg | sed -n -e '/libraries/{;s/^[[^=]]*=\(.*\)/\1/;s/,/ /gp;}'`
193 dpagaix_cflags=`sed -n '/^xlc_r4/,/^$/p' /etc/ibmcxx.cfg | sed -n -e '/options/{;s/^[[^=]]*=\(.*\)/\1/;s/-q[^,]*//;s/,/ /gp;}'`
196 dpagaix_cflags="-D_THREAD_SAFE -D_AIX_PTHREADS_D7 -D_AIX32_THREADS=1 -D_AES_SOURCE -D_AIX41 -I/usr/include/dce"
197 dpagaix_ldadd="-L/usr/lib/threads -ldcelibc_r -ldcepthreads -lpthreads_compat lpthreads -lc_r"
198 dpagaix_ldflags="-Wl,-bI:dfspag.exp"
200 AC_SUBST(dpagaix_cflags)
201 AC_SUBST(dpagaix_ldadd)
202 AC_SUBST(dpagaix_ldflags)
204 AC_ARG_ENABLE([afs-support],
205 AC_HELP_STRING([--disable-afs-support],
206 [if you don't want support for AFS]))
207 if test "$enable_afs_support" = no; then
208 AC_DEFINE(NO_AFS, 1, [Define if you don't wan't support for AFS.])
213 dnl AC_ROKEN(10,[/usr/heimdal /usr/athena],[lib/roken],[$(top_builddir)/lib/roken/libroken.la],[-I$(top_builddir)/lib/roken -I$(top_srcdir)/lib/roken])
216 LIB_roken="\$(top_builddir)/lib/vers/libvers.la $LIB_roken"
223 AS_HELP_STRING([--disable-mmap],[disable use of mmap]))
224 if test "$enable_mmap" = "no"; then
225 AC_DEFINE(NO_MMAP, 1, [Define if you don't want to use mmap.])
228 AC_ARG_ENABLE(afs-string-to-key,
229 AS_HELP_STRING([--disable-afs-string-to-key],
230 [disable use of weak AFS string-to-key functions]),
231 [], [enable_afs_string_to_key=yes])
233 if test "$enable_afs_string_to_key" = "yes"; then
234 AC_DEFINE(ENABLE_AFS_STRING_TO_KEY, 1, [Define if want to use the weak AFS string to key functions.])
240 rk_TEST_PACKAGE(readline,
242 #include <readline.h>],-lreadline,,, READLINE)
244 rk_TEST_PACKAGE(hesiod,[#include <hesiod.h>],-lhesiod,,, HESIOD)
255 AM_CONDITIONAL(HAVE_X, test "$no_x" != yes)
261 dnl Checks for typedefs, structures, and compiler characteristics.
264 AC_CHECK_TYPE_EXTRA(mode_t, unsigned short, [])
265 AC_CHECK_TYPE_EXTRA(sig_atomic_t, int, [#include <signal.h>])
266 AC_HAVE_TYPE([long long])
270 dnl Checks for header files.
287 netinet/in6_machtypes.h \
328 dnl On Solaris 8 there's a compilation warning for term.h because
329 dnl it doesn't define `bool'.
330 AC_CHECK_HEADERS(term.h, , , -)
332 AC_CHECK_HEADERS(net/if.h, , , [AC_INCLUDES_DEFAULT
333 #if HAVE_SYS_SOCKET_H
334 #include <sys/socket.h>
337 AC_CHECK_HEADERS(sys/ptyvar.h, , , [AC_INCLUDES_DEFAULT
342 AC_CHECK_HEADERS(sys/strtty.h, , , [AC_INCLUDES_DEFAULT
346 #if HAVE_SYS_STREAM_H
347 #include <sys/stream.h>
350 AC_CHECK_HEADERS(sys/ucred.h, , , [AC_INCLUDES_DEFAULT
352 #include <sys/types.h>
355 #include <sys/param.h>
358 AC_CHECK_HEADERS(security/pam_modules.h, , , [AC_INCLUDES_DEFAULT
359 #include <security/pam_appl.h>
362 AC_ARG_ENABLE(netinfo,
363 AS_HELP_STRING([--enable-netinfo],[enable netinfo for configuration lookup]))
365 if test "$ac_cv_header_netinfo_ni_h" = yes -a "$enable_netinfo" = yes; then
366 AC_DEFINE(HAVE_NETINFO, 1,
367 [Define if you want to use Netinfo instead of krb5.conf.])
371 rk_WIN32_EXPORT(BUILD_KRB5_LIB, KRB5_LIB_FUNCTION)
372 rk_WIN32_EXPORT(BUILD_ROKEN_LIB, ROKEN_LIB_FUNCTION)
374 dnl Checks for libraries.
376 AC_FIND_FUNC_NO_LIBS(logwtmp, util,[
381 AC_FIND_FUNC_NO_LIBS(logout, util,[
386 AC_FIND_FUNC_NO_LIBS(openpty, util,[
392 AC_FIND_FUNC_NO_LIBS(tgetent, termcap ncurses curses,[
393 #ifdef HAVE_TERMCAP_H
401 dnl Checks for library functions.
432 yp_get_default_domain \
439 AC_CHECK_GETPWNAM_R_POSIX
441 dnl detect doors on solaris
442 if test "$enable_pthread_support" != no; then
444 LIBS="$LIBS $PTHREADS_LIBS"
445 AC_FIND_FUNC_NO_LIBS(door_create, door)
450 AS_HELP_STRING([--enable-kcm],[enable Kerberos Credentials Manager]),
453 if test "$enable_kcm" = yes ; then
454 if test "$ac_cv_header_sys_un_h" != yes -a "$ac_cv_funclib_door_create" != yes ; then
458 if test "$enable_kcm" = yes; then
459 AC_DEFINE(HAVE_KCM, 1,
460 [Define if you want to use the Kerberos Credentials Manager.])
462 AM_CONDITIONAL(KCM, test "$enable_kcm" = yes)
467 AC_CHECK_FUNCS(getudbnam setlim)
469 dnl AC_KRB_FUNC_GETCWD_BROKEN
472 dnl Check for fields in struct utmp
475 AC_HAVE_STRUCT_FIELD(struct utmp, ut_addr, [#include <utmp.h>])
476 AC_HAVE_STRUCT_FIELD(struct utmp, ut_host, [#include <utmp.h>])
477 AC_HAVE_STRUCT_FIELD(struct utmp, ut_id, [#include <utmp.h>])
478 AC_HAVE_STRUCT_FIELD(struct utmp, ut_pid, [#include <utmp.h>])
479 AC_HAVE_STRUCT_FIELD(struct utmp, ut_type, [#include <utmp.h>])
480 AC_HAVE_STRUCT_FIELD(struct utmp, ut_user, [#include <utmp.h>])
481 AC_HAVE_STRUCT_FIELD(struct utmpx, ut_exit, [#include <utmpx.h>])
482 AC_HAVE_STRUCT_FIELD(struct utmpx, ut_syslen, [#include <utmpx.h>])
484 AC_CHECK_TYPES([int8_t, int16_t, int32_t, int64_t,
485 u_int8_t, u_int16_t, u_int32_t, u_int64_t,
486 uint8_t, uint16_t, uint32_t, uint64_t],,,[
487 #ifdef HAVE_INTTYPES_H
488 #include <inttypes.h>
490 #ifdef HAVE_SYS_TYPES_H
491 #include <sys/types.h>
493 #ifdef HAVE_SYS_BITYPES_H
494 #include <sys/bitypes.h>
496 #ifdef HAVE_BIND_BITYPES_H
497 #include <bind/bitypes.h>
499 #ifdef HAVE_NETINET_IN6_MACHTYPES_H
500 #include <netinet/in6_machtypes.h>
508 dnl Some operating systems already have com_err and compile_et
511 rk_AUTH_MODULES([sia afskauthlib])
515 AH_BOTTOM([#ifdef ROKEN_RENAME
516 #include "roken_rename.h"
519 AC_CONFIG_FILES(Makefile \
521 include/gssapi/Makefile \
522 include/hcrypto/Makefile \
523 include/kadm5/Makefile \
527 lib/auth/afskauthlib/Makefile \
528 lib/auth/pam/Makefile \
529 lib/auth/sia/Makefile \
531 lib/com_err/Makefile \
533 lib/editline/Makefile \
535 lib/gssapi/Makefile \
552 appl/afsutil/Makefile \
554 appl/ftp/common/Makefile \
555 appl/ftp/ftp/Makefile \
556 appl/ftp/ftpd/Makefile \
557 appl/gssmask/Makefile \
559 appl/login/Makefile \
561 appl/popper/Makefile \
566 appl/xnlock/Makefile \
567 appl/telnet/Makefile \
568 appl/telnet/libtelnet/Makefile \
569 appl/telnet/telnet/Makefile \
570 appl/telnet/telnetd/Makefile \
573 appl/dceutils/Makefile \
585 dnl This is the release version name-number[beta]
588 cat > include/newversion.h.in <<EOF
589 const char *heimdal_long_version = "@([#])\$Version: $PACKAGE_STRING by @USER@ on @HOST@ ($host) @DATE@ \$";
590 const char *heimdal_version = "AC_PACKAGE_STRING";
593 if test -f include/version.h && cmp -s include/newversion.h.in include/version.h.in; then
594 echo "include/version.h is unchanged"
595 rm -f include/newversion.h.in
597 echo "creating include/version.h"
598 User=${USER-${LOGNAME}}
599 Host=`(hostname || uname -n || echo unknown) 2>/dev/null | sed 1q`
601 mv -f include/newversion.h.in include/version.h.in
602 sed -e "s/@USER@/$User/" -e "s/@HOST@/$Host/" -e "s/@DATE@/$Date/" include/version.h.in > include/version.h