#
AC_CANONICAL_SYSTEM
case "$target" in
+ *-*-*bsd*)
+ check_threads=false
+ ;;
*)
+ check_threads=true
;;
esac
# ./prepare script will automatically put the correct version. Do not edit!
AM_INIT_AUTOMAKE(SILC_PACKAGE, SILC_VERSION)
-AC_PREREQ(2.3)
+AC_PREREQ(2.52)
AM_CONFIG_HEADER(includes/silcdefs.h)
AC_PROG_CC
AC_C_INLINE
AC_C_CONST
-AC_ARG_PROGRAM
AC_PROG_LN_S
AC_SUBST(LN_S)
# Distribution definition. ./prepare will automatically add here a correct
# value. Do not edit!
+silc_dist=SILC_PACKAGE
AC_DEFINE(SILC_DIST_DEFINE)
# XXX
# More header checking
AC_CHECK_HEADERS(unistd.h string.h getopt.h errno.h fcntl.h assert.h)
AC_CHECK_HEADERS(sys/types.h sys/stat.h sys/time.h)
-AC_CHECK_HEADERS(netinet/in.h netinet/tcp.h netdb.h)
+AC_CHECK_HEADERS(netinet/in.h netinet/tcp.h xti.h netdb.h)
AC_CHECK_HEADERS(pwd.h grp.h termcap.h paths.h)
AC_CHECK_HEADERS(ncurses.h signal.h ctype.h regex.h)
AC_CHECK_HEADERS(arpa/inet.h sys/mman.h limits.h)
AC_MSG_RESULT(Found ncurses on $1/$2)
CURSES_LIBS="$3"
- AC_CHECK_LIB(ncurses, initscr, [
- ], [
+ AC_CHECK_LIB(ncurses, initscr, , [
CHECKLIBS=`echo "$3"|sed 's/-lncurses/-lcurses/g'`
AC_CHECK_LIB(curses, initscr, [
CURSES_LIBS="$CHECKLIBS"
AC_CHECK_FUNCS(select listen bind shutdown close connect)
AC_CHECK_FUNCS(fcntl setsockopt)
AC_CHECK_FUNCS(getopt_long time)
-AC_CHECK_FUNCS(mlock munlock)
AC_CHECK_FUNCS(chmod stat fstat getenv putenv strerror ctime gettimeofday)
AC_CHECK_FUNCS(getpid getgid getsid getpgid getpgrp getuid)
AC_CHECK_FUNCS(strchr strstr strcpy strncpy memcpy memset memmove)
fi
#
-# MP library checking. First check whether system has GMP. If it has that
-# then use it. If not then compile the MPI library in the source tree.
+# MP library checking. First check whether user wants to use GMP and use
+# it if found. If not or not defined then compile the MPI library in the
+# source tree.
#
-mp_gmp=false
-AC_CHECK_HEADER(gmp.h,
- AC_CHECK_LIB(gmp, __gmpz_init,
- mp_gmp=true
- AC_DEFINE(SILC_MP_GMP)
- LIBS="$LIBS -L/usr/lib -L/usr/local/lib -lgmp"
- AC_MSG_RESULT(Using GMP as MP library)
- )
+AC_MSG_CHECKING(whether to support GMP)
+AC_ARG_WITH(gmp,
+[ --with-gmp[=PATH] Compile with GMP support instead of MPI],
+[ case "$withval" in
+ no)
+ AC_MSG_RESULT(no)
+ mp_gmp=false
+ ;;
+ *)
+ AC_MSG_RESULT(yes)
+
+ if test -d "$withval/include"; then
+ CFLAGS="$CFLAGS -I$withval/include"
+ else
+ CFLAGS="$CFLAGS -I$withval"
+ fi
+ if test -d "$withval/lib"; then
+ withval="-L$withval/lib -lgmp"
+ else
+ withval="-L$withval -lgmp"
+ fi
+
+ LIBS="$withval $LIBS"
+ mp_gmp=false
+ AC_CHECK_LIB(gmp, __gmpz_init,
+ mp_gmp=true
+ AC_DEFINE(SILC_MP_GMP)
+ AC_MSG_RESULT(Using GMP as MP library)
+ )
+ ;;
+ esac ],
+ AC_MSG_RESULT(no)
+ mp_gmp=false
)
+
AM_CONDITIONAL(SILC_MP_GMP, test x$mp_gmp = xtrue)
+AM_CONDITIONAL(SILC_MP_NSS_MPI, test x$mp_gmp = xfalse)
if test x$mp_gmp = xfalse; then
- AM_CONDITIONAL(SILC_MP_NSS_MPI, test x$mp_gmp = xfalse)
AC_DEFINE(SILC_MP_NSS_MPI)
AC_MSG_RESULT(Using NSS MPI as MP library)
fi
AC_ARG_WITH(win32,
[ --with-win32 Compile native WIN32 code (-mno-cygwin)],
[ AC_DEFINE(SILC_WIN32)
- AM_CONDITIONAL(SILC_WIN32, test xtrue = xtrue)
+ win32-support = true
CFLAGS="-mno-cygwin $CFLAGS"
LIBS="$LIBS -lwsock32" ])
+AM_CONDITIONAL(SILC_WIN32, test x$win32-support = xtrue)
+
#
# Debug checking
#
AC_MSG_RESULT(no))
#
-# Pthread checking
+# Disable all assembler optimizations
+#
+AC_ARG_ENABLE(asm,
+[ --disable-asm Do not use assembler optimizations ],
+[])
+
+#
+# Threads support
#
+AC_ARG_ENABLE(threads,
+[ --disable-threads Do not compile with multi-thread support],
+[ case "${enableval}" in
+ yes)
+ want_threads=true
+ check_threads=true
+ ;;
+ *)
+ want_threads=false
+ check_threads=false
+ ;;
+esac ])
+
+if test x$check_threads = xtrue; then
want_threads=false
AC_CHECK_HEADERS(pthread.h,
[ AC_DEFINE(SILC_HAVE_PTHREAD)
fi
])
-AC_ARG_ENABLE(threads,
-[ --disable-threads Do not compile with multi-thread support],
-[ case "${enableval}" in
- yes)
- want_threads=true
- ;;
- *)
- want_threads=false
- ;;
-esac ])
-
AM_CONDITIONAL(SILC_THREADS, test x$want_threads = xtrue)
if test x$want_threads = xtrue; then
- AC_DEFINE(SILC_THREADS)
TMP_LIBS="$LIBS"
LIBS="-lpthread"
AC_TRY_LINK([#include <pthread.h>],
- [pthread_attr_t attr; pthread_attr_init(&attr);], ,
+ [pthread_attr_t attr; pthread_attr_init(&attr);],
+ AC_DEFINE(SILC_THREADS),
LIBS="-L/usr/pkg/lib -lpthread"
AC_TRY_LINK([#include <pthread.h>],
- [pthread_attr_t attr; pthread_attr_init(&attr);], ,
+ [pthread_attr_t attr; pthread_attr_init(&attr);],
+ AC_DEFINE(SILC_THREADS),
LIBS="-L/usr/contrib/lib -lpthread"
AC_TRY_LINK([#include <pthread.h>],
- [pthread_attr_t attr; pthread_attr_init(&attr);], , LIBS=""
+ [pthread_attr_t attr; pthread_attr_init(&attr);],
+ AC_DEFINE(SILC_THREADS),
+ LIBS=""
)))
CFLAGS="$CFLAGS -D_REENTRANT"
LIBS="$TMP_LIBS $LIBS"
fi
+fi
#
# Other configure scripts
#
AC_CONFIG_SUBDIRS(lib/dotconf)
AC_CONFIG_SUBDIRS(lib/trq)
-AC_CONFIG_SUBDIRS(lib/silcmath/mpi)
AC_CONFIG_SUBDIRS(irssi)
+AC_CONFIG_SUBDIRS(lib/silcmath/mpi)
#AC_CONFIG_SUBDIRS(lib/zlib)
SILC_TOP_SRCDIR=`pwd`
#
# Makefile outputs
#
-AC_OUTPUT( \
+AC_CONFIG_FILES( \
Makefile
Makefile.defines
Makefile.defines_int
-irssi/Makefile.defines
-irssi/Makefile.defines_int
-doc/Makefile
+doc/Makefile
includes/Makefile
lib/Makefile
lib/contrib/Makefile
-lib/silcclient/Makefile
lib/silccore/Makefile
-lib/silccrypt/Makefile
+lib/silccrypt/Makefile
lib/silcmath/Makefile
lib/silcmath/mpi/Makefile.defines
lib/silcmath/mpi/Makefile.defines_int
lib/silcutil/Makefile
lib/silcutil/unix/Makefile
lib/silcutil/win32/Makefile
+lib/silcsftp/Makefile
+lib/silcsftp/tests/Makefile
+)
+
+if test "x$silc_dist" = "xsilc-client" ||
+ test "x$silc_dist" = "xsilc-toolkit"; then
+AC_CONFIG_FILES( \
+lib/silcclient/Makefile
+irssi/Makefile.defines
+irssi/Makefile.defines_int
+)
+fi
+
+if test "x$silc_dist" = "xsilc-server" ||
+ test "x$silc_dist" = "xsilc-toolkit"; then
+AC_CONFIG_FILES( \
+silcd/Makefile
+)
+fi
+
+if test "x$silc_dist" = "xsilc-toolkit"; then
+AC_CONFIG_FILES( \
silc/Makefile
-silcd/Makefile)
+win32/Makefile
+win32/libsilc/Makefile
+win32/libsilcclient/Makefile
+)
+fi
+
+AC_OUTPUT