X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fconfigure.ac;h=820f91dc2a9702012412414830ea9a728087078d;hb=c08adcea52e85d6139ad158c17eb3d1941df2eb5;hp=18f006637347e3396ab2bdd4ad9a5409bf5ed334;hpb=68b90ad48010aa46265549f3ddd4534d7826184f;p=citadel.git diff --git a/webcit/configure.ac b/webcit/configure.ac index 18f006637..820f91dc2 100644 --- a/webcit/configure.ac +++ b/webcit/configure.ac @@ -1,6 +1,6 @@ dnl Process this file with autoconf to produce a configure script. dnl $Id$ -AC_INIT([WebCit], [7.37], [http://www.citadel.org/]) +AC_INIT([WebCit], [7.86], [http://www.citadel.org/]) AC_SUBST(PROG_SUBDIRS) @@ -63,9 +63,11 @@ dnl Configure compiler flags for GCC if test "$GCC" = yes; then case "$host" in *-*-solaris*) +dnl CFLAGS="$CFLAGS -Wall -Wno-char-subscripts --pedantic" CFLAGS="$CFLAGS -Wall -Wno-char-subscripts" ;; *) +dnl CFLAGS="$CFLAGS -Wall --pedantic" CFLAGS="$CFLAGS -Wall" ;; esac @@ -86,6 +88,33 @@ dnl Checks for header files. AC_HEADER_STDC dnl AC_HEADER_SYS_WAIT +AC_CACHE_CHECK( + [for call semantics from getpwuid_r], + ac_cv_call_getpwuid_r, + [AC_TRY_COMPILE([#include +#include ], + [ + struct passwd pw, *pwp; + char pwbuf[64]; + uid_t uid; + + getpwuid_r(uid, &pw, pwbuf, sizeof(pwbuf), &pwp); + ], + ac_cv_call_getpwuid_r=yes, + ac_cv_call_getpwuid_r=no) + ]) + +if test $ac_cv_call_getpwuid_r = no; then + AC_DEFINE(SOLARIS_GETPWUID,[],[do we need to use solaris call syntax?]) + AC_DEFINE(SOLARIS_LOCALTIME_R,[], [do we need to use soralis call syntax?]) + AC_DEFINE(F_UID_T, "%ld", [whats the matching format string for uid_t?]) + AC_DEFINE(F_PID_T, "%ld", [whats the matching format string for pid_t?]) + AC_DEFINE(F_XPID_T, "%lx", [whats the matching format string for xpid_t?]) +else + AC_DEFINE(F_UID_T, "%d", [whats the matching format string for uid_t?]) + AC_DEFINE(F_PID_T, "%d", [whats the matching format string for pid_t?]) + AC_DEFINE(F_XPID_T, "%x", [whats the matching format string for xpid_t?]) +fi @@ -93,14 +122,36 @@ dnl Checks for typedefs, structures, and compiler characteristics. AC_C_CONST AC_TYPE_OFF_T AC_TYPE_SIZE_T +dnl Check the size of various builtin types; see typesize.h (error) +AC_CHECK_SIZEOF(char, 0) +AC_CHECK_SIZEOF(short, 0) +AC_CHECK_SIZEOF(int, 0) +AC_CHECK_SIZEOF(long, 0) +AC_CHECK_SIZEOF(long unsigned int, 0) +AC_CHECK_SIZEOF(size_t, 0) dnl AC_HEADER_TIME dnl Checks for library functions. AC_TYPE_SIGNAL dnl AC_FUNC_VPRINTF AC_REPLACE_FUNCS(snprintf) +AC_CHECK_HEADER(CUnit/CUnit.h, [AC_DEFINE(ENABLE_TESTS, [], [whether we should compile the test-suite])]) + AC_CHECK_HEADERS(fcntl.h limits.h sys/time.h unistd.h iconv.h xlocale.h) +dnl Checks for the zlib compression library. +if test "x$with_zlib" != xno ; then + AC_CHECK_HEADERS(zlib.h, + [AC_CHECK_LIB(z, zlibVersion, + [ok_zlib=yes],, + )]) +fi + +if test "x$ok_zlib" = xyes ; then +dnl libcitadel will bring libz, so we don't need it here. LDFLAGS="-lz $LDFLAGS" + AC_DEFINE(HAVE_ZLIB, [], [define this if you have zlib compression available]) +fi + dnl Here is the check for a libc integrated iconv AC_ARG_ENABLE(iconv, @@ -152,64 +203,53 @@ if test "$ok_iconv" = no; then ) fi if test "$ok_iconv" != "no"; then - AC_MSG_RESULT(WebCit will be built with character set conversion.) + AC_MSG_RESULT(webcit will be built with character set conversion.) AC_DEFINE(HAVE_ICONV,[],[whether we have iconv for charset conversion]) else - AC_MSG_RESULT(WebCit will be built without character set conversion.) + AC_MSG_RESULT(webcit will be built without character set conversion.) fi -AC_CHECK_LIB(intl, libintl_bindtextdomain, [LDFLAGS="$LDFLAGS -lintl"]) - -dnl Checks for the zlib compression library. -AC_ARG_WITH(with_zlib, [ --with-zlib use zlib compression if present]) -if test "x$with_zlib" != xno ; then - AC_CHECK_HEADERS(zlib.h, - [AC_CHECK_LIB(z, zlibVersion, - [ok_zlib=yes],, - )]) -fi -if test "x$ok_zlib" = xyes ; then - LIBS="-lz $LIBS" - AC_DEFINE(HAVE_ZLIB,[],[whether we have zlib]) -fi +AC_CHECK_LIB(intl, libintl_bindtextdomain, [LDFLAGS="$LDFLAGS -lintl"]) -dnl Check for libcitadel -AC_CHECK_HEADER(libcitadel.h, - [AC_CHECK_LIB(citadel, libcitadel_version_string, +dnl Checks for the libical iCalendar library. +AC_CHECK_HEADER(libical/ical.h, + [AC_CHECK_LIB(ical, icaltimezone_set_tzid_prefix, [ - LIBS="-lcitadel $LIBS" + LIBS="-lical $LIBS" ], [ - AC_MSG_ERROR(libcitadel was not found or is not usable. Please install libcitadel.) + AC_MSG_ERROR(libical was not found and is required. More info: http://www.citadel.org/doku.php/installation:start) ] , )], [ - AC_MSG_ERROR(libcitadel.h was not found or is not usable. Please install libcitadel.) + AC_MSG_ERROR(libical/ical.h was not found and is required. More info: http://www.citadel.org/doku.php/installation:start) ] ) -dnl Checks for the libical iCalendar library. -AC_CHECK_HEADER(libical/ical.h, - [AC_CHECK_LIB(ical, icalcomponent_as_ical_string_r, +dnl Check for libcitadel +AC_CHECK_HEADER(libcitadel.h, + [AC_CHECK_LIB(citadel, libcitadel_version_string, [ - LIBS="-lical $LIBS" + LIBS="-lcitadel $LIBS" + SETUP_LIBS="-lcitadel $SETUP_LIBS" ], [ - AC_MSG_ERROR(libical was not found and is required. More info: http://www.citadel.org/doku.php/installation:start) + AC_MSG_ERROR(libcitadel was not found or is not usable. Please install libcitadel.) ] , )], [ - AC_MSG_ERROR(libical/ical.h was not found and is required. More info: http://www.citadel.org/doku.php/installation:start) + AC_MSG_ERROR(libcitadel.h was not found or is not usable. Please install libcitadel.) ] ) +found_ssl=no # The big search for OpenSSL if test "$with_ssl" != "no"; then saved_LIBS="$LIBS" @@ -292,6 +332,7 @@ if test "$with_ssl" != "no"; then if test "x$ac_cv_openssldir" != "xno" ; then AC_DEFINE(HAVE_OPENSSL,[],[whethe we have openssl]) + found_ssl=yes LIBS="-lssl -lcrypto $LIBS" dnl Need to recover ssldir - test above runs in subshell ssldir=$ac_cv_openssldir @@ -327,6 +368,10 @@ AC_ARG_WITH(ssldir, [ if test "x$withval" != "xno" ; then ssl_dir="$withval" + if test "$found_ssl" = "no"; then + echo "Your setup was incomplete; ssldir doesn't make sense without openssl" + exit + fi fi AC_SUBST(MAKE_SSL_DIR) ] @@ -456,12 +501,34 @@ AC_ARG_WITH(editordir, ) AC_DEFINE_UNQUOTED(EDITORDIR, "$editordir", [where to find our mail editor]) -./mk_module_init.sh +abs_srcdir="`cd $srcdir && pwd`" +abs_builddir="`pwd`" +if test "$abs_srcdir" != "$abs_builddir"; then + CFLAGS="$CFLAGS -I $abs_builddir" +fi AC_CONFIG_HEADER(sysdep.h) -AC_OUTPUT(Makefile po/Makefile ) +AC_OUTPUT(Makefile po/Makefile tests/Makefile) + +if test "$abs_srcdir" != "$abs_builddir"; then + ln -s $abs_srcdir/static $abs_builddir + ln -s $abs_srcdir/tiny_mce $abs_builddir + ln -s $abs_srcdir/*.h $abs_builddir + make mkdir-init + +else +dnl just run it on devel systems and if non vdir build. + if test -d .svn; then + ./mk_module_init.sh + fi +fi + +if test -n "$srcdir"; then + export srcdir=. +fi + echo ------------------------------------------------------------------------ -echo 'zlib compression: ' $ok_zlib echo 'Character set conversion support:' $ok_iconv echo 'National language support: ' $ok_nls +echo 'Compression support: ' $ok_zlib echo