aboutsummaryrefslogtreecommitdiffstats
path: root/configure.ac
diff options
context:
space:
mode:
Diffstat (limited to 'configure.ac')
-rw-r--r--configure.ac1595
1 files changed, 1595 insertions, 0 deletions
diff --git a/configure.ac b/configure.ac
new file mode 100644
index 0000000000..8a0c56d1ec
--- /dev/null
+++ b/configure.ac
@@ -0,0 +1,1595 @@
+dnl Evolution Versions
+m4_define([evo_major_version], [3])
+m4_define([evo_minor_version], [9])
+m4_define([evo_micro_version], [90])
+m4_define([evo_version],
+ [evo_major_version.evo_minor_version.evo_micro_version])
+m4_define([evo_stable_version],
+ [m4_if(m4_eval(evo_minor_version % 2), [1],
+ [evo_major_version.m4_eval(evo_minor_version - 1)],
+ [evo_version])])
+
+dnl Base Version: This is for API/version tracking for things like
+dnl Bonobo server files. This should always be the major/minor of
+dnl the stable version or stable version to be. Note, this is set
+dnl the way it is so that GETTEXT_PACKAGE will be parsed correctly.
+BASE_VERSION=3.10
+m4_define([base_version], [3.10])
+
+dnl Autoconf / Automake Initialization
+AC_PREREQ([2.64])
+AC_INIT([evolution],[evo_version],[http://bugzilla.gnome.org/enter_bug.cgi?product=Evolution],[evolution],[http://www.gnome.org/projects/evolution/])
+AM_INIT_AUTOMAKE([1.10 dist-xz no-dist-gzip -Wall -Wno-portability foreign])
+AC_CONFIG_MACRO_DIR([m4])
+AC_CONFIG_HEADERS(config.h)
+AC_CONFIG_SRCDIR(README)
+
+dnl This is for the autoconf tests only - it set's the language we use
+AC_LANG(C)
+
+dnl Automake 1.11 - Silent Build Rules
+m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
+
+dnl Required Packages
+
+dnl Keep these two definitions in agreement.
+m4_define([glib_minimum_version], [2.34.0])
+m4_define([glib_encoded_version], [GLIB_VERSION_2_34])
+
+dnl Keep these two definitions in agreement.
+m4_define([gdk_minimum_version], [3.4.0])
+m4_define([gdk_encoded_version], [GDK_VERSION_3_4])
+
+dnl Keep these two definitions in agreement.
+m4_define([soup_minimum_version], [2.40.3])
+m4_define([soup_encoded_version], [SOUP_VERSION_2_40])
+
+m4_define([eds_minimum_version], [evo_version])
+m4_define([gtkhtml_minimum_version], [4.5.2])
+m4_define([gdk_pixbuf_minimum_version], [2.24.0])
+m4_define([gnome_desktop_minimum_version], [2.91.3])
+m4_define([gnome_icon_theme_minimum_version], [2.30.2.1])
+m4_define([gsettings_desktop_schemas_minimum_version], [2.91.92])
+m4_define([webkitgtk_minimum_version], [1.10.0])
+m4_define([libgdata_minimum_version], [0.10])
+m4_define([libxml_minimum_version], [2.7.3])
+m4_define([shared_mime_info_minimum_version], [0.22])
+m4_define([libpst_minimum_version], [0.6.54])
+
+dnl Optional Packages
+m4_define([champlain_minimum_version], [0.12])
+m4_define([clutter_gtk_minimum_version], [0.90])
+m4_define([geoclue_minimum_version], [0.12.0])
+m4_define([gladeui_minimum_version], [3.10.0])
+m4_define([gweather_minimum_version], [3.5.0])
+m4_define([libcanberra_gtk_minimum_version], [0.25])
+m4_define([libnotify_minimum_version], [0.7])
+
+dnl XXX These versions don't yet exist. The latest releases
+dnl link to gtk+-2.0 so we've bumped the versions to some
+dnl bogus value to force some plugins to be disabled.
+m4_define([gtkimageview_minimum_version], [2.0])
+
+dnl ******************************
+dnl Compiler Warning Flags
+dnl ******************************
+AS_COMPILER_FLAGS(WARNING_FLAGS,
+ "-Wall -Wextra
+ -Wdeprecated-declarations
+ -Wno-missing-field-initializers
+ -Wno-sign-compare
+ -Wno-unused-parameter
+ -Wdeclaration-after-statement
+ -Werror-implicit-function-declaration
+ -Wformat-security -Winit-self
+ -Wmissing-declarations -Wmissing-include-dirs
+ -Wmissing-noreturn -Wnested-externs -Wpointer-arith
+ -Wredundant-decls -Wundef -Wwrite-strings")
+AC_SUBST(WARNING_FLAGS)
+
+dnl Need to stop using e-passwords.h before we can restore
+dnl -DEDS_DISABLE_DEPRECATED
+
+dnl Other useful compiler warnings for test builds only.
+dnl These may produce warnings we have no control over,
+dnl or false positives we don't always want to see.
+dnl
+dnl -Wmissing-format-attribute
+dnl -Wshadow
+dnl -Wformat-nonliteral
+dnl -Wstrict-aliasing=2
+
+AM_CPPFLAGS="$WARNING_FLAGS -fno-strict-aliasing"
+
+dnl *******************************
+dnl Check for --enable-strict
+dnl *******************************
+AC_ARG_ENABLE([strict],
+ [AS_HELP_STRING([--enable-strict],
+ [enable strict building, like without deprecated symbols (default=auto); auto enables strict building only if .git subdirectory exists])],
+ [enable_strict=$enableval], [enable_strict=auto])
+
+AC_MSG_CHECKING([if strict building is enabled])
+if test "x$enable_strict" = xauto; then
+ dnl Be strict when compiling with .git subdirectory
+ if test -d .git ; then
+ enable_strict=yes
+ else
+ enable_strict=no
+ fi
+fi
+AC_MSG_RESULT([$enable_strict])
+
+if test "x$enable_strict" = xyes; then
+ AM_CPPFLAGS="$AM_CPPFLAGS -DG_DISABLE_DEPRECATED"
+fi
+
+dnl Warn about API usage that violates our minimum requirements.
+AM_CPPFLAGS="$AM_CPPFLAGS -DGLIB_VERSION_MAX_ALLOWED=glib_encoded_version"
+AM_CPPFLAGS="$AM_CPPFLAGS -DGDK_VERSION_MAX_ALLOWED=gdk_encoded_version"
+AM_CPPFLAGS="$AM_CPPFLAGS -DSOUP_VERSION_MAX_ALLOWED=soup_encoded_version"
+
+dnl These will suppress warnings about newly-deprecated symbols. Ideally
+dnl these settings should match our minimum requirements and we will clean
+dnl up any new deprecation warnings after bumping our minimum requirements.
+dnl But if the warnings get to be overwhelming, use fixed versions instead.
+AM_CPPFLAGS="$AM_CPPFLAGS -DGLIB_VERSION_MIN_REQUIRED=glib_encoded_version"
+AM_CPPFLAGS="$AM_CPPFLAGS -DGDK_VERSION_MIN_REQUIRED=GDK_VERSION_3_2"
+AM_CPPFLAGS="$AM_CPPFLAGS -DSOUP_VERSION_MIN_REQUIRED=soup_encoded_version"
+
+AC_SUBST(AM_CPPFLAGS)
+
+AC_CANONICAL_HOST
+AC_DEFINE_UNQUOTED(VERSION_COMMENT, "", [Define if you want a comment appended to the version number])
+
+dnl This must stay after AC_CANONICAL_HOST, which defines $host.
+case "$host" in
+*openbsd*|*freebsd*)
+ dnl Do not set '-Wl,--no-undefined' on freebsd/openbsd
+ ;;
+*)
+ LDFLAGS="$LDFLAGS -Wl,--no-undefined"
+ ;;
+esac
+
+
+dnl *************************************
+dnl Put the ACLOCAL flags in the Makefile
+dnl *************************************
+ACLOCAL="$ACLOCAL $ACLOCAL_FLAGS"
+
+dnl ******************************
+dnl Initialize maintainer mode
+dnl ******************************
+AM_MAINTAINER_MODE([enable])
+
+if test "$evo_version" != "$evo_stable_version"; then
+ AC_DEFINE(STABLE_VERSION, ["evo_stable_version"],
+ [Define to the latest stable version if this version is unstable])
+fi
+
+AC_SUBST([BASE_VERSION], [base_version])
+AC_DEFINE_UNQUOTED(BASE_VERSION, ["$BASE_VERSION"], [Base version (Major.Minor)])
+
+AC_SUBST([EVO_MAJOR_VERSION], [evo_major_version])
+AC_SUBST([EVO_MINOR_VERSION], [evo_minor_version])
+AC_SUBST([EVO_MICRO_VERSION], [evo_micro_version])
+
+AC_PROG_CC
+AC_C_INLINE
+AC_PROG_CPP
+AM_PROG_CC_C_O
+AC_PROG_INSTALL
+AC_PROG_LN_S
+AC_PROG_MAKE_SET
+AC_PROG_AWK
+AC_PATH_PROG([PERL], [perl])
+AC_SUBST(PERL)
+
+AC_ARG_PROGRAM
+
+dnl GCC 4.4 got more aggressive in its aliasing optimizations, changing
+dnl behavior that -- according to the C99 standard -- is supposed to be
+dnl undefined. We may still have aliasing abuses lying around that rely
+dnl on GCC's previous "undefined" behavior, so disable strict-aliasing
+dnl optimzation until we can find and fix all the abuses.
+dnl (AC_PROG_CC must run first to set the GCC variable.)
+dnl XXX This really belongs in AM_CFLAGS.
+if test "x${GCC}" = "xyes"; then
+ CFLAGS="$CFLAGS -fno-strict-aliasing"
+fi
+
+GLIB_GSETTINGS
+
+dnl ******************************
+dnl I18N stuff
+dnl ******************************
+IT_PROG_INTLTOOL([0.40.0])
+
+GETTEXT_PACKAGE=evolution-$BASE_VERSION
+AC_SUBST(GETTEXT_PACKAGE)
+AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE, "$GETTEXT_PACKAGE", [Package name for gettext])
+
+dnl ******************************
+dnl Initialize libtool
+dnl ******************************
+LT_PREREQ(2.2)
+LT_INIT(disable-static win32-dll)
+
+PKG_PROG_PKG_CONFIG
+
+dnl ********************************************
+dnl User / Developer Documentation
+dnl ********************************************
+YELP_HELP_INIT
+GTK_DOC_CHECK([1.14],[--flavour no-tmpl])
+
+dnl ******************************
+dnl Win32
+dnl ******************************
+AC_MSG_CHECKING([for Win32])
+case "$host" in
+*-mingw*)
+ os_win32=yes
+ NO_UNDEFINED='-no-undefined'
+ SOEXT='.dll'
+ DL_LIB=''
+ SOFTOKN3_LIB=''
+ CHAMPLAIN_REQUIREMENT=''
+ GEOCLUE_REQUIREMENT=''
+ ;;
+*openbsd*|*freebsd*)
+ os_win32=no
+ NO_UNDEFINED=''
+ SOEXT='.so'
+ SA_JUNK_PLUGIN=sa-junk-plugin
+ BF_JUNK_PLUGIN=bogo-junk-plugin
+ DL_LIB=''
+ SOFTOKN3_LIB='-lsoftokn3'
+ ;;
+*)
+ os_win32=no
+ NO_UNDEFINED='-no-undefined'
+ SOEXT='.so'
+ DL_LIB='-ldl'
+ SOFTOKN3_LIB='-lsoftokn3'
+ ;;
+esac
+AC_MSG_RESULT([$os_win32])
+AM_CONDITIONAL(OS_WIN32, [test $os_win32 = yes])
+AC_SUBST(NO_UNDEFINED)
+AC_SUBST(SOEXT)
+
+MATH_LIB="-lm"
+AC_SUBST(MATH_LIB)
+
+if test "$os_win32" = "yes"; then
+ AC_CHECK_TOOL(WINDRES, windres, :)
+else
+ WINDRES=":"
+fi
+
+AM_CONDITIONAL(HAVE_WINDRES, test "x$WINDRES" != "x:")
+
+AC_SUBST(WINDRES)
+
+dnl **********************************
+dnl Check for base dependencies early.
+dnl **********************************
+PKG_CHECK_MODULES([GNOME_PLATFORM],
+ [gio-2.0 >= glib_minimum_version
+ gmodule-2.0 >= glib_minimum_version
+ cairo-gobject
+ gtk+-3.0 >= gdk_minimum_version
+ gail-3.0 >= gdk_minimum_version
+ gdk-pixbuf-2.0 >= gdk_pixbuf_minimum_version
+ libxml-2.0 >= libxml_minimum_version
+ shared-mime-info >= shared_mime_info_minimum_version
+ gnome-desktop-3.0 >= gnome_desktop_minimum_version
+ gsettings-desktop-schemas >= gsettings_desktop_schemas_minimum_version
+ webkitgtk-3.0 >= webkitgtk_minimum_version
+ gnome-autoar])
+AC_SUBST(GNOME_PLATFORM_CFLAGS)
+AC_SUBST(GNOME_PLATFORM_LIBS)
+
+PKG_CHECK_MODULES([EVOLUTION_DATA_SERVER],
+ [camel-1.2 >= eds_minimum_version
+ libebook-1.2 >= eds_minimum_version
+ libecal-1.2 >= eds_minimum_version
+ libedataserver-1.2 >= eds_minimum_version
+ libebackend-1.2 >= eds_minimum_version])
+AC_SUBST(EVOLUTION_DATA_SERVER_CFLAGS)
+AC_SUBST(EVOLUTION_DATA_SERVER_LIBS)
+
+dnl ******************************
+dnl Canberra / Canberra-GTK Sound
+dnl ******************************
+AC_ARG_ENABLE([canberra],
+ [AS_HELP_STRING([--enable-canberra],
+ [Enable Canberra and Canberra-GTK sound @<:@default=yes@:>@])],
+ [enable_canberra="$enableval"], [enable_canberra=yes])
+
+if test $enable_canberra = yes; then
+ PKG_CHECK_MODULES(
+ [CANBERRA],
+ [libcanberra-gtk3 >= libcanberra_gtk_minimum_version],,
+ [AC_MSG_ERROR([
+
+ libcanberra-gtk3 not found (or version < libcanberra_gtk_minimum_version)
+
+ If you want to disable support for event sounds,
+ please append --disable-canberra to configure.
+
+ ])])
+
+ AC_DEFINE(HAVE_CANBERRA, 1, [Define if using Canberra and Canberra-GTK for sound])
+fi
+AC_SUBST(CANBERRA_CFLAGS)
+AC_SUBST(CANBERRA_LIBS)
+
+dnl ******************
+dnl User Documentation
+dnl ******************
+AC_MSG_CHECKING([whether to build user documentation])
+AC_ARG_WITH([help],
+ [AS_HELP_STRING([--with-help],
+ [Build user documentation [default=yes]])],
+ [with_help="$withval"],[with_help="yes"])
+AM_CONDITIONAL(WITH_HELP, test "x$with_help" != "xno")
+AC_MSG_RESULT([$with_help])
+
+dnl ******************************
+dnl iconv checking
+dnl ******************************
+have_iconv=no
+save_LIBS="$LIBS"
+LIBS="$LIBS -liconv"
+AC_CACHE_CHECK([for iconv in -liconv], [ac_cv_libiconv],
+ AC_LINK_IFELSE([AC_LANG_PROGRAM(
+ [[
+ #include <iconv.h>
+ #include <stdlib.h>
+ ]],
+ [[ iconv_t cd;
+ cd = iconv_open ("UTF-8", "ISO-8859-1");
+ ]]
+ )],[ac_cv_libiconv=yes],[ac_cv_libiconv=no]))
+
+if test $ac_cv_libiconv = yes; then
+ ICONV_LIBS="-liconv"
+ if test $os_win32 = yes; then
+ dnl Don't pointlessly auto-export the global symbols
+ dnl from a potentially static libiconv.a
+ ICONV_LIBS="$ICONV_LIBS -Wl,--exclude-libs=libiconv.a"
+ fi
+ have_iconv=yes
+else
+ LIBS="$save_LIBS"
+ AC_CHECK_FUNC(iconv, have_iconv=yes, have_iconv=no)
+fi
+
+if test $have_iconv = yes; then
+ if test $ac_cv_libiconv = no; then
+ AC_CHECK_FUNCS(gnu_get_libc_version)
+ fi
+AC_CACHE_CHECK([if iconv() handles UTF-8], [ac_cv_libiconv_utf8],
+ AC_RUN_IFELSE([AC_LANG_SOURCE([[
+ #include <iconv.h>
+ #include <stdlib.h>
+ #include <string.h>
+ #ifdef HAVE_GNU_GET_LIBC_VERSION
+ #include <gnu/libc-version.h>
+ #endif
+ int main() {
+ char *jp = "\x1B\x24\x42\x46\x7C\x4B\x5C\x38\x6C";
+ char *utf8 = "\xE6\x97\xA5\xE6\x9C\xAC\xE8\xAA\x9E";
+ char *transbuf = malloc (10), *trans = transbuf;
+ iconv_t cd;
+ size_t jp_len = strlen (jp), utf8_len = 10;
+ size_t utf8_real_len = strlen (utf8);
+
+ #ifdef HAVE_GNU_GET_LIBC_VERSION
+ /* glibc 2.1.2's iconv is broken in hard to test ways. */
+ if (!strcmp (gnu_get_libc_version (), "2.1.2"))
+ exit (1);
+ #endif
+
+ cd = iconv_open ("UTF-8", "ISO-2022-JP");
+ if (cd == (iconv_t) -1)
+ exit (1);
+ if (iconv (cd, &jp, &jp_len, &trans, &utf8_len) == -1 || jp_len != 0)
+ exit (1);
+ if (memcmp (utf8, transbuf, utf8_real_len) != 0)
+ exit (1);
+ return (0);}
+ ]])
+ ],[ac_cv_libiconv_utf8=yes],[ac_cv_libiconv_utf8=no; have_iconv=no],[ac_cv_libiconv_utf8=hopefully]))
+fi
+
+if test "$have_iconv" = no; then
+ AC_MSG_ERROR([You need to install a working iconv implementation, such as ftp://ftp.gnu.org/pub/gnu/libiconv])
+fi
+AC_SUBST(ICONV_LIBS)
+
+save_CFLAGS="$CFLAGS"
+CFLAGS="$CFLAGS -I$srcdir"
+
+AC_MSG_CHECKING([preferred charset name formats for system iconv])
+AC_RUN_IFELSE([AC_LANG_SOURCE([[
+ #define CONFIGURE_IN
+ #include "iconv-detect.c"
+ ]])],
+ [AC_MSG_RESULT([found])],
+ [AC_MSG_RESULT([not found])
+ AC_MSG_WARN([
+ *** The iconv-detect program was unable to determine the
+ *** preferred charset name formats recognized by your
+ *** iconv library. It is suggested that you install a
+ *** working iconv library such as the one found at
+ *** ftp://ftp.gnu.org/pub/gnu/libiconv
+ ])],
+ [if test x$os_win32 = xyes; then
+ AC_MSG_RESULT([using known win32 result])
+ echo '/* This is an auto-generated header, DO NOT EDIT! */' > iconv-detect.h
+ echo >>iconv-detect.h
+ echo '#define ICONV_ISO_D_FORMAT "iso-%d-%d"' >>iconv-detect.h
+ echo '#define ICONV_ISO_S_FORMAT "iso-%d-%s"' >>iconv-detect.h
+ echo '#define ICONV_10646 "UCS-4BE"' >>iconv-detect.h
+ else
+ AC_MSG_RESULT([unknown])
+ AC_MSG_WARN([
+ *** We can't determine the preferred charset name formats
+ *** recognized by your iconv library. You are
+ *** cross-compiling and supposed to know what you are doing.
+ *** Please construct the iconv-detect.h file manually.
+ ])
+ fi
+])
+
+CFLAGS="$save_CFLAGS"
+LIBS="$save_LIBS"
+
+dnl **************
+dnl waitpid() etc
+dnl **************
+AC_HEADER_SYS_WAIT
+
+dnl ***************
+dnl Purify support
+dnl ***************
+EVO_PURIFY_SUPPORT
+
+dnl ***************
+dnl Timezone checks
+dnl ***************
+AC_CACHE_CHECK(for tm_gmtoff in struct tm, [ac_cv_struct_tm_gmtoff],
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
+ [[ #include <time.h> ]],
+ [[
+ struct tm tm;
+ tm.tm_gmtoff = 1;
+ ]]
+ )],[ac_cv_struct_tm_gmtoff=yes],[ac_cv_struct_tm_gmtoff=no]))
+if test $ac_cv_struct_tm_gmtoff = yes; then
+ AC_DEFINE(HAVE_TM_GMTOFF, 1, [Define if struct tm has a tm_gmtoff member])
+else
+ AC_CACHE_CHECK(for timezone variable, [ac_cv_var_timezone],
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
+ [[ #include <time.h> ]],
+ [[ timezone = 1; ]]
+ )],[ac_cv_var_timezone=yes],[ac_cv_var_timezone=no]))
+ if test $ac_cv_var_timezone = yes; then
+ AC_DEFINE(HAVE_TIMEZONE, 1, [Define if libc defines a timezone variable])
+ AC_CACHE_CHECK(for altzone variable, [ac_cv_var_altzone],
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
+ [[ #include <time.h> ]],
+ [[ altzone = 1; ]]
+ )],[ac_cv_var_altzone=yes],[ac_cv_var_altzone=no]))
+ if test $ac_cv_var_altzone = yes; then
+ AC_DEFINE(HAVE_ALTZONE, 1, [Define if libc defines an altzone variable])
+ fi
+ else
+ AC_MSG_ERROR([unable to find a way to determine timezone])
+ fi
+fi
+
+
+AC_CHECK_FUNCS(mkdtemp)
+
+dnl **************************************************
+dnl Gnome Icon Theme
+dnl **************************************************
+PKG_CHECK_MODULES([GIT], [gnome-icon-theme >= gnome_icon_theme_minimum_version])
+
+dnl **************************************************
+dnl Accessibility support
+dnl **************************************************
+PKG_CHECK_MODULES([A11Y], [atk])
+AC_SUBST(A11Y_CFLAGS)
+AC_SUBST(A11Y_LIBS)
+
+dnl **************************************************
+dnl XF86 multimedia keys support
+dnl **************************************************
+have_xfree=no
+AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
+ [[ #include <X11/XF86keysym.h> ]],[[]])],
+ [have_xfree=yes]
+)
+AC_MSG_CHECKING([for X11 XFree86 headers])
+AC_MSG_RESULT([$have_xfree])
+if test x"$have_xfree" = "xyes" ; then
+ AC_DEFINE(HAVE_XFREE, 1, [defined if you have X11/XF86keysym.h])
+fi
+
+dnl **************************************************
+dnl LDAP support.
+dnl **************************************************
+if test "$os_win32" != yes; then
+ EVO_LDAP_CHECK(no)
+ case $with_openldap in
+ no)
+ msg_ldap=no
+ ;;
+ *)
+ case $with_static_ldap in
+ yes)
+ msg_ldap="yes (static)"
+ ;;
+ *)
+ msg_ldap="yes (dynamic)"
+ ;;
+ esac
+ esac
+
+ SAVE_CFLAGS="$CFLAGS"
+ SAVE_LIBS="$LIBS"
+ LDAP_CFLAGS="$LDAP_CFLAGS -DLDAP_DEPRECATED"
+ CFLAGS="$CFLAGS $LDAP_CFLAGS"
+ LIBS="$LIBS $LDAP_LIBS"
+ AC_CHECK_FUNCS(ldap_ntlm_bind)
+ CFLAGS="$SAVE_CFLAGS"
+ LIBS="$SAVE_LIBS"
+dnl Win32 support
+else
+ LDAP_CFLAGS="-DLDAP_DEPRECATED"
+ LDAP_LIBS="-lwldap32"
+ AC_SUBST(LDAP_CFLAGS)
+ AC_SUBST(LDAP_LIBS)
+ AC_DEFINE(HAVE_LDAP,1,[Define if you have LDAP support])
+ AM_CONDITIONAL(ENABLE_LDAP, true)
+ msg_ldap="yes"
+fi
+
+dnl **************************************************
+dnl SunLDAP support, but if OpenLDAP support, skip check SunLDAP.
+dnl **************************************************
+if test "$with_openldap" = no ; then
+ EVO_SUNLDAP_CHECK(no)
+ case $with_sunldap in
+ no)
+ msg_ldap=no
+ ;;
+ *)
+ case $with_static_sunldap in
+ yes)
+ msg_ldap="$with_sunldap (static)"
+ ;;
+ *)
+ msg_ldap="$with_sunldap (dynamic)"
+ ;;
+ esac
+ esac
+else
+ with_sunldap=no
+fi
+AM_CONDITIONAL(SUNLDAP, [test x$with_sunldap != xno])
+
+AC_DEFINE(HANDLE_LIBICAL_MEMORY, 1, [Define it once memory returned by libical is free'ed properly])
+
+dnl *************************
+dnl GTKHTML check
+dnl XXX Drop the version from the package name?
+dnl *************************
+PKG_CHECK_MODULES([GTKHTML],
+ [libgtkhtml-4.0 >= gtkhtml_minimum_version
+ gtkhtml-editor-4.0])
+AC_SUBST(GTKHTML_CFLAGS)
+AC_SUBST(GTKHTML_LIBS)
+
+dnl ************
+dnl Kerberos 5
+dnl ************
+EVO_KRB5_SUPPORT(no)
+
+dnl ********************************************************************************
+dnl security extension support (SSL and S/MIME)
+dnl
+dnl The following voodoo does detection of mozilla libraries (nspr and nss)
+dnl needed by Camel (SSL and S/MIME).
+dnl
+dnl The Evolution security extensions are only built if these libraries are found
+dnl ********************************************************************************
+msg_ssl="no"
+msg_smime="no"
+
+dnl these 2 enable's are inverses of each other
+
+AC_ARG_ENABLE([nss],
+ AS_HELP_STRING([--enable-nss=@<:@yes/no/static@:>@],
+ [Attempt to use Mozilla libnss for SSL support.]),
+ [enable_nss=$enableval],[enable_nss=yes])
+
+AC_ARG_ENABLE([smime],
+ AS_HELP_STRING([--enable-smime],
+ [Attempt to use Mozilla libnss for SMIME support (this requires --enable-nss)]),
+ [enable_smime=$enableval],[enable_smime=yes])
+
+AC_ARG_WITH([nspr-includes],
+ AS_HELP_STRING([--with-nspr-includes=PATH],
+ [Location of Mozilla nspr4 includes.]))
+
+AC_ARG_WITH([nspr-libs],
+ AS_HELP_STRING([--with-nspr-libs=PATH],
+ [Location of Mozilla nspr4 libs.]))
+
+AC_ARG_WITH([nss-includes],
+ AS_HELP_STRING([--with-nss-includes=PATH],
+ [Location of Mozilla nss3 includes.]))
+
+AC_ARG_WITH([nss-libs],
+ AS_HELP_STRING([--with-nss-libs=PATH],
+ [Location of Mozilla nss3 libs.]))
+
+if test "x${enable_nss}" = "xyes" || test "x${enable_nss}" = "xstatic"; then
+ if test -n "${with_nspr_includes}" || test -n "${with_nspr_libs}" || test -n "${with_nss_includes}" || test -n "${with_nss_libs}" || test "x${enable_nss}" = "xstatic"; then
+ check_manually="yes"
+ else
+ check_manually="no"
+ fi
+
+ if test "x${check_manually}" = "xno"; then
+ AC_MSG_CHECKING([Mozilla NSPR pkg-config module name])
+ mozilla_nspr_pcs="nspr mozilla-nspr firefox-nspr xulrunner-nspr seamonkey-nspr"
+ for pc in $mozilla_nspr_pcs; do
+ if $PKG_CONFIG --exists $pc; then
+ AC_MSG_RESULT([$pc])
+ mozilla_nspr=$pc
+ break;
+ fi
+ done
+
+ AC_MSG_CHECKING([Mozilla NSS pkg-config module name])
+ mozilla_nss_pcs="nss mozilla-nss firefox-nss xulrunner-nss seamonkey-nss"
+ for pc in $mozilla_nss_pcs; do
+ if $PKG_CONFIG --exists $pc; then
+ AC_MSG_RESULT([$pc])
+ mozilla_nss=$pc
+ break;
+ fi
+ done
+
+ if test -n "$mozilla_nspr" -a -n "$mozilla_nss"; then
+ msg_ssl="yes (Mozilla NSS)"
+ if test "x$enable_smime" = "xyes"; then
+ AC_DEFINE(ENABLE_SMIME,1,[Define if SMIME should be enabled])
+ msg_smime="yes (Mozilla NSS)"
+ fi
+ AC_DEFINE(HAVE_NSS,1,[Define if you have NSS])
+ AC_DEFINE(HAVE_SSL,1,[Define if you have a supported SSL library])
+ AC_DEFINE_UNQUOTED(MOZILLA_NSS_LIB_DIR,"`$PKG_CONFIG --variable=libdir $mozilla_nss`",[Define to the full path of mozilla nss library])
+ MANUAL_NSPR_CFLAGS=""
+ MANUAL_NSPR_LIBS=""
+ MANUAL_NSS_CFLAGS=""
+ MANUAL_NSS_LIBS=""
+ else
+ check_manually="yes"
+ mozilla_nspr=""
+ mozilla_nss=""
+ fi
+ fi
+
+ if test "x${check_manually}" = "xyes"; then
+ mozilla_nss=""
+ have_nspr_includes="no"
+ if test "x${with_nspr_includes}" != "xno"; then
+ CPPFLAGS_save="$CPPFLAGS"
+
+ AC_MSG_CHECKING([for Mozilla nspr4 includes in $with_nspr_includes])
+ AC_MSG_RESULT([""])
+
+ CPPFLAGS="$CPPFLAGS -I$with_nspr_includes"
+ AC_CHECK_HEADERS([nspr.h prio.h],[ moz_nspr_includes="yes" ],,
+ [[
+ #if HAVE_NSPR_H
+ #include <nspr.h>
+ #include <prio.h>
+ #endif
+ ]])
+ CPPFLAGS="$CPPFLAGS_save"
+
+ if test "x{$moz_nspr_includes}" != "xno" -a "x{$moz_nspr_includes}" != "x" ; then
+ have_nspr_includes="yes"
+ MANUAL_NSPR_CFLAGS="-I$with_nspr_includes"
+ fi
+ else
+ AC_MSG_CHECKING([for Mozilla nspr4 includes])
+ AC_MSG_RESULT([no])
+ fi
+
+ have_nspr_libs="no"
+ if test "x${with_nspr_libs}" != "xno" -a "x${have_nspr_includes}" != "xno"; then
+ CFLAGS_save="$CFLAGS"
+ LDFLAGS_save="$LDFLAGS"
+
+ if test "$enable_nss" = "static"; then
+ if test -z "${with_nspr_libs}"; then
+ AC_MSG_ERROR([Static linkage requested, but path to nspr libraries not set.]
+ [Please specify the path to libnspr4.a]
+ [Example: --with-nspr-libs=/usr/lib])
+ else
+ nsprlibs="$DL_LIB $with_nspr_libs/libplc4.a $with_nspr_libs/libplds4.a $with_nspr_libs/libnspr4.a"
+ fi
+ else
+ nsprlibs="$DL_LIB -lplc4 -lplds4 -lnspr4"
+ fi
+
+ AC_CACHE_CHECK([for Mozilla nspr libraries], [ac_cv_moz_nspr_libs],
+ [
+ LIBS_save="$LIBS"
+ CFLAGS="$CFLAGS $MANUAL_NSPR_CFLAGS"
+
+ if test "x${with_nspr_libs}" != "x"; then
+ LIBS="$nsprlibs"
+ LDFLAGS="$LDFLAGS -L$with_nspr_libs"
+ else
+ LIBS="$nsprlibs"
+ LDFLAGS="$LDFLAGS"
+ fi
+
+ AC_LINK_IFELSE([AC_LANG_CALL([], [PR_Init])],
+ [ac_cv_moz_nspr_libs="yes"], [ac_cv_moz_nspr_libs="no"])
+ CFLAGS="$CFLAGS_save"
+ LDFLAGS="$LDFLAGS_save"
+ LIBS="$LIBS_save"
+ ])
+ if test "x$ac_cv_moz_nspr_libs" != "xno"; then
+ have_nspr_libs="yes"
+ MANUAL_NSPR_LIBS="-L$with_nspr_libs $nsprlibs"
+ else
+ MANUAL_NSPR_CLFAGS=""
+ fi
+ else
+ AC_MSG_CHECKING([for Mozilla nspr4 libraries])
+ AC_MSG_RESULT([no])
+ fi
+
+ if test "x${with_nss_includes}" != "xno" -a "x${have_nspr_libs}" != "xno"; then
+ CPPFLAGS_save="$CPPFLAGS"
+
+ AC_MSG_CHECKING([for Mozilla nss3 includes in $with_nss_includes])
+ AC_MSG_RESULT([""])
+
+ if test "x${with_nspr_includes}" != "x"; then
+ CPPFLAGS="$CPPFLAGS -I$with_nspr_includes -I$with_nss_includes"
+ else
+ CPPFLAGS="$CPPFLAGS -I$with_nss_includes"
+ fi
+
+ AC_CHECK_HEADERS(nss.h ssl.h smime.h,
+ [ have_nss_includes="yes" ],
+ [ have_nss_includes="no" ],
+ [
+ #if HAVE_NSPR_H
+ #include <nss.h>
+ #include <ssl.h>
+ #include <smime.h>
+ #endif
+ ])
+
+ CPPFLAGS="$CPPFLAGS_save"
+
+ if test "x${have_nss_includes}" = "xyes"; then
+ have_nss_includes="yes"
+ MANUAL_NSS_CFLAGS="-I$with_nss_includes"
+ else
+ MANUAL_NSPR_CFLAGS=""
+ MANUAL_NSPR_LIBS=""
+ fi
+ else
+ AC_MSG_CHECKING([for Mozilla nss3 includes])
+ AC_MSG_RESULT([no])
+ fi
+
+ if test "x${with_nss_libs}" != "xno" -a "x${have_nss_includes}" != "xno"; then
+ LDFLAGS_save="$LDFLAGS"
+
+ if test "$enable_nss" = "static"; then
+ if test -z "${with_nss_libs}"; then
+ AC_MSG_ERROR([Static linkage requested, but path to nss libraries not set.]
+ [Please specify the path to libnss3.a]
+ [Example: --with-nspr-libs=/usr/lib/mozilla])
+ else
+ nsslibs="-ldb1 $with_nss_libs/libnssckfw.a $with_nss_libs/libasn1.a $with_nss_libs/libcrmf.a $with_nss_libs/libswfci.a $with_nss_libs/libjar.a $with_nss_libs/libpkcs12.a $with_nss_libs/libpkcs7.a $with_nss_libs/libpki1.a $with_nss_libs/libsmime.a $with_nss_libs/libssl.a $with_nss_libs/libnss.a $with_nss_libs/libpk11wrap.a $with_nss_libs/libsoftokn.a $with_nss_libs/libfreebl.a $with_nss_libs/libnsspki.a $with_nss_libs/libnssdev.a $with_nss_libs/libcryptohi.a $with_nss_libs/libcerthi.a $with_nss_libs/libcertdb.a $with_nss_libs/libsecutil.a $with_nss_libs/libnssb.a"
+ case "$host" in
+ *solaris*)
+ nsslibs="$nsslibs $with_nss_libs/libfreebl.a"
+ ;;
+ esac
+ fi
+ else
+ nsslibs="-lssl3 -lsmime3 -lnss3"
+ fi
+
+ AC_CACHE_CHECK([for Mozilla nss libraries], [ac_cv_moz_nss_libs],
+ [
+ LIBS_save="$LIBS"
+ LDFLAGS="$LDFLAGS -L$with_nspr_libs $nsprlibs -L$with_nss_libs $nsslibs"
+ LIBS="$nsslibs $nsprlibs"
+ AC_LINK_IFELSE([AC_LANG_CALL([], [NSS_Init])],
+ [ac_cv_moz_nss_libs="yes"], [ac_cv_moz_nss_libs="no"])
+ if test "$ac_cv_moz_nss_libs" = no; then
+ nsslibs="-lssl3 -lsmime3 -lnss3"
+ LDFLAGS="$LDFLAGS -L$with_nspr_libs $nsprlibs -L$with_nss_libs $nsslibs"
+ AC_LINK_IFELSE([AC_LANG_CALL([], [NSS_Init])],
+ [ac_cv_moz_nss_libs="yes"], [ac_cv_moz_nss_libs="no"])
+ fi
+ LDFLAGS="$LDFLAGS_save"
+ LIBS="$LIBS_save"
+ ])
+ if test "$ac_cv_moz_nss_libs" != no; then
+ AC_DEFINE(HAVE_NSS)
+ AC_DEFINE(HAVE_SSL)
+ AC_DEFINE_UNQUOTED(MOZILLA_NSS_LIB_DIR,"$with_nss_libs", [Define to the full path of mozilla nss library])
+ if test "$enable_nss" = "static"; then
+ msg_ssl="yes (Mozilla NSS:static)"
+ else
+ msg_ssl="yes (Mozilla NSS)"
+ fi
+ dnl static_nss
+ if test "$enable_smime" = "yes"; then
+ AC_DEFINE(ENABLE_SMIME,1,[Define if SMIME should be enabled])
+ msg_smime="yes (Mozilla NSS)"
+ fi
+ MANUAL_NSS_LIBS="-L$with_nss_libs $nsslibs"
+ else
+ MANUAL_NSS_CFLAGS=""
+ MANUAL_NSPR_CFLAGS=""
+ MANUAL_NSPR_LIBS=""
+ fi
+ else
+ AC_MSG_CHECKING([for Mozilla nss libraries])
+ AC_MSG_RESULT([no])
+ fi
+
+ MANUAL_NSS_CFLAGS="$MANUAL_NSPR_CFLAGS $MANUAL_NSS_CFLAGS"
+ MANUAL_NSS_LIBS="$MANUAL_NSPR_LIBS $MANUAL_NSS_LIBS"
+ fi
+fi
+
+AM_CONDITIONAL(ENABLE_SMIME, [test "x$msg_smime" != "xno"])
+
+AC_SUBST(MANUAL_NSPR_CFLAGS)
+AC_SUBST(MANUAL_NSPR_LIBS)
+AC_SUBST(MANUAL_NSS_CFLAGS)
+AC_SUBST(MANUAL_NSS_LIBS)
+
+dnl *****************
+dnl killall or pkill?
+dnl *****************
+
+case "$host" in
+*solaris*)
+ KILL_PROCESS_CMD="/usr/bin/pkill -x"
+ ;;
+*)
+ AC_PATH_PROGS(KILL_PROCESS_CMD, killall pkill)
+ ;;
+esac
+if test -z "$KILL_PROCESS_CMD"; then
+ AC_MSG_WARN([Could not find a command to kill a process by name])
+else
+ AC_DEFINE_UNQUOTED([KILL_PROCESS_CMD], "$KILL_PROCESS_CMD",
+ [Command to kill processes by name])
+fi
+
+dnl *******************
+dnl GObject marshalling
+dnl *******************
+AM_PATH_GLIB_2_0
+
+dnl *****************************************************************
+dnl Utility macro to set compiler flags for a specific lib.
+dnl EVO_SET_COMPILE_FLAGS(VAR-PREFIX, DEPS, EXTRA-CFLAGS, EXTRA-LIBS)
+dnl *****************************************************************
+AC_DEFUN([EVO_SET_COMPILE_FLAGS], [
+ PKG_CHECK_MODULES([$1], [$2])
+ $1_CFLAGS="[$]$1_CFLAGS $3"
+ $1_LIBS="[$]$1_LIBS $4"
+])
+
+dnl ******************************
+dnl TNEF implementation
+dnl ******************************
+AC_MSG_CHECKING([for yTNEF])
+AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
+ [[
+ #include <stdio.h>
+ #include <ytnef.h>
+ ]],
+ [[ TNEFStruct *tnef; ]]
+ )], [tnef_ok=yes], [tnef_ok=no])
+if test "$tnef_ok" = "yes"; then
+ AC_MSG_RESULT([yes])
+ TNEF_CFLAGS="-DHAVE_YTNEF_H"
+ AC_DEFINE(ENABLE_TNEF,1,[Define if TNEF attachments parser should be built])
+
+else
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
+ [[
+ #include <stdio.h>
+ #include <libytnef/ytnef.h>
+ ]],
+ [[ TNEFStruct *tnef; ]]
+ )], [tnef_ok=yes], [tnef_ok=no])
+ if test "$tnef_ok" = "yes"; then
+ AC_MSG_RESULT([yes])
+ TNEF_CFLAGS="-DHAVE_LIBYTNEF_YTNEF_H"
+ AC_DEFINE(ENABLE_TNEF,1,[Define if TNEF attachments parser should be built])
+ else
+ AC_MSG_RESULT([no])
+ TNEF_CFLAGS=""
+ fi
+fi
+AM_CONDITIONAL([ENABLE_TNEF], [test "$tnef_ok" = "yes"])
+AC_SUBST(TNEF_CFLAGS)
+
+if test "x$mozilla_nss" != "x"; then
+ EVO_SET_COMPILE_FLAGS(MOZILLA_NSS, $mozilla_nss)
+ MOZILLA_L_DIR=`${PKG_CONFIG} --libs-only-L $mozilla_nss`
+else
+ if test "x$MOZILLA_MANUAL_LIBS" != "x"; then
+ MOZILLA_L_DIR="-L$with_nss_lib"
+ fi
+fi
+
+dnl **********************************
+dnl Check for Bogofilter (spam filter)
+dnl **********************************
+AC_ARG_ENABLE([bogofilter],
+ [AS_HELP_STRING([--enable-bogofilter],
+ [enable spam filtering using Bogofilter (default=yes)])],
+ [enable_bogofilter=$enableval], [enable_bogofilter=yes])
+AC_MSG_CHECKING([if Bogofilter support is enabled])
+AC_MSG_RESULT([$enable_bogofilter])
+msg_bogofilter="$enable_bogofilter"
+if test "x$enable_bogofilter" = "xyes"; then
+ AC_ARG_VAR([BOGOFILTER], [Bogofilter spam filtering program])
+ AC_PATH_PROG([BOGOFILTER], [bogofilter])
+ if test "x$BOGOFILTER" == "x"; then
+ AC_MSG_ERROR([
+
+ Bogofilter spam filtering program not found.
+
+ If you want to disable spam filtering using Bogofilter,
+ please append --disable-bogofilter to configure.
+
+ ])
+ fi
+ AC_DEFINE_UNQUOTED(
+ BOGOFILTER_COMMAND, "$BOGOFILTER",
+ [Bogofilter spam filtering program])
+ msg_bogofilter="$msg_bogofilter ($BOGOFILTER)"
+fi
+AM_CONDITIONAL([ENABLE_BOGOFILTER], [test "x$enable_bogofilter" = "xyes"])
+
+dnl ************************************
+dnl Check for SpamAssassin (spam filter)
+dnl ************************************
+AC_ARG_ENABLE([spamassassin],
+ [AS_HELP_STRING([--enable-spamassassin],
+ [enable spam filtering using SpamAssassin (default=yes)])],
+ [enable spamassassin=$enableval], [enable_spamassassin=yes])
+AC_MSG_CHECKING([if SpamAssassin support is enabled])
+AC_MSG_RESULT([$enable_spamassassin])
+msg_spamassassin="$enable_spamassassin"
+if test "x$enable_spamassassin" = "xyes"; then
+ AC_ARG_VAR([SPAMASSASSIN], [SpamAssassin spam filtering program])
+ AC_PATH_PROG([SPAMASSASSIN], [spamassassin])
+ if test "x$SPAMASSASSIN" == "x"; then
+ AC_MSG_ERROR([
+
+ SpamAssassin spam filtering program not found.
+
+ If you want to disable spam filtering using SpamAssassin,
+ please append --disable-spamassassin to configure.
+
+ ])
+ fi
+ AC_DEFINE_UNQUOTED(
+ SPAMASSASSIN_COMMAND, "$SPAMASSASSIN",
+ [SpamAssassin spam filtering program])
+
+ AC_ARG_VAR([SA_LEARN], [SpamAssassin spam training program])
+ AC_PATH_PROG([SA_LEARN], [sa-learn])
+ if test "x$SA_LEARN" = "x"; then
+ AC_MSG_ERROR([
+
+ SpamAssassin training program (sa-learn) not found.
+
+ If you want to disable spam filtering using SpamAssassin,
+ please append --disable-spamassassin to configure.
+
+ ])
+ fi
+ AC_DEFINE_UNQUOTED(
+ SA_LEARN_COMMAND, "$SA_LEARN",
+ [SpamAssassin spam training program])
+
+ msg_spamassassin="$msg_spamassassin ($SPAMASSASSIN)"
+fi
+AM_CONDITIONAL([ENABLE_SPAMASSASSIN], [test "x$enable_spamassassin" = "xyes"])
+
+dnl ******************************
+dnl CERT_UI Flags
+dnl ******************************
+dnl
+dnl Here we want the Mozilla flags to go *before* the other ones,
+dnl especially the mozilla-nss -I flags to go before the gnutls ones
+dnl (which are dragged in through libedataserverui), as both
+dnl gnutls and mozilla-nss have a header called "pkcs12.h" which is
+dnl included in smime/lib/e-pkcs12.c. It wants the Mozilla NSS one.
+dnl
+CERT_UI_CFLAGS="$MANUAL_NSS_CFLAGS $MOZILLA_NSS_CFLAGS"
+CERT_UI_LIBS="$MOZILLA_L_DIR $MANUAL_NSS_LIBS $MOZILLA_NSS_LIBS"
+AC_SUBST(CERT_UI_CFLAGS)
+AC_SUBST(CERT_UI_LIBS)
+
+dnl ***************
+dnl Libnotify Flags
+dnl ***************
+LIBNOTIFY_CFLAGS=
+LIBNOTIFY_LIBS=
+PKG_CHECK_MODULES([LIBNOTIFY], [libnotify >= libnotify_minimum_version], [HAVE_LIBNOTIFY="yes"], [HAVE_LIBNOTIFY="no"])
+if test "x$HAVE_LIBNOTIFY" = "xyes"; then
+ AC_DEFINE(HAVE_LIBNOTIFY, 1, [Define if you have libnotify])
+ libnotify="libnotify"
+else
+ libnotify=""
+fi
+AC_SUBST(LIBNOTIFY_CFLAGS)
+AC_SUBST(LIBNOTIFY_LIBS)
+
+dnl **************
+dnl Calendar Flags
+dnl **************
+PKG_CHECK_MODULES([LIBSOUP], [libsoup-gnome-2.4 >= soup_minimum_version])
+AC_SUBST(LIBSOUP_CFLAGS)
+AC_SUBST(LIBSOUP_LIBS)
+
+PKG_CHECK_MODULES([GDATA], [libgdata >= libgdata_minimum_version])
+AC_SUBST(GDATA_CFLAGS)
+AC_SUBST(GDATA_LIBS)
+
+dnl ****************************
+dnl Check for ical_set_unknown_token_handling_setting function
+dnl ****************************
+AC_MSG_CHECKING([ical_set_unknown_token_handling_setting function])
+save_cflags=$CFLAGS; CFLAGS="$EVOLUTION_DATA_SERVER_CFLAGS"
+save_libs=$LIBS; LIBS="$EVOLUTION_DATA_SERVER_LIBS"
+AC_LINK_IFELSE([AC_LANG_PROGRAM(
+ [[#include <libical/ical.h>]],
+ [[ical_set_unknown_token_handling_setting (ICAL_DISCARD_TOKEN)]])],
+ [AC_DEFINE(HAVE_ICAL_UNKNOWN_TOKEN_HANDLING, 1, [libical provides ical_set_unknown_token_handling_setting function]) ac_cv_have_iuth=yes],[ac_cv_have_iuth=no])
+CFLAGS=$save_cflags
+LIBS=$save_libs
+AC_MSG_RESULT([$ac_cv_have_iuth])
+
+dnl *******************
+dnl Special directories
+dnl *******************
+
+dnl If you add something here, consider whether or not you also need to add it to one or more .pc.in
+dnl files (for Connector, etc)
+
+privlibdir='${libdir}'/evolution/$BASE_VERSION
+AC_SUBST(privlibdir)
+
+privlibexecdir='${libexecdir}'/evolution/$BASE_VERSION
+AC_SUBST(privlibexecdir)
+
+privdatadir='${datadir}'/evolution/$BASE_VERSION
+AC_SUBST(privdatadir)
+
+privincludedir='${includedir}'/evolution-$BASE_VERSION
+AC_SUBST(privincludedir)
+
+moduledir="$privlibdir/modules"
+AC_SUBST(moduledir)
+
+uidir="$privdatadir/ui"
+AC_SUBST(uidir)
+
+evolutionhelpdir="$privdatadir/help"
+AC_SUBST(evolutionhelpdir)
+
+icondir="$privdatadir/icons"
+AC_SUBST(icondir)
+
+imagesdir="$privdatadir/images"
+AC_SUBST(imagesdir)
+
+if test "$os_win32" = yes; then
+ dnl On Win32 there is no "rpath" mechanism. We install the private
+ dnl shared libraries in $libdir, meaning the DLLs will actually be in
+ dnl $bindir. This means just having $bindir in PATH will be enough. This
+ dnl also means gnome_win32_get_prefixes() will be able to deduce the
+ dnl installation folder correctly.
+ privsolibdir=$libdir
+else
+ privsolibdir=$privlibdir
+fi
+AC_SUBST(privsolibdir)
+
+soundsdir="$privdatadir/sounds"
+AC_SUBST(soundsdir)
+
+etspecdir="$privdatadir/etspec"
+AC_SUBST(etspecdir)
+
+viewsdir="$privdatadir/views"
+AC_SUBST(viewsdir)
+
+dnl For evolution-alarm-notify.desktop
+AS_AC_EXPAND(PRIVLIBEXECDIR, "$privlibexecdir")
+
+dnl ************************
+dnl Plugins
+dnl ************************
+
+plugindir="$privlibdir/plugins"
+AC_SUBST(plugindir)
+
+EVO_PLUGIN_RULE=$srcdir/plugin.mk
+AC_SUBST_FILE(EVO_PLUGIN_RULE)
+
+AC_ARG_ENABLE([plugins],
+ AS_HELP_STRING([--enable-plugins=[no/base/all]],
+ [Enable plugins.]),
+ [enable_plugins="$enableval"],[enable_plugins=all])
+
+dnl Add any new plugins here
+plugins_base_always="publish-calendar"
+
+plugins_base="$plugins_base_always"
+dist_plugins_base="$plugins_base_always"
+
+plugins_standard_always="bbdb save-calendar mail-to-task mailing-list-actions mail-notification attachment-reminder email-custom-header face templates dbx-import external-editor"
+
+plugins_standard="$plugins_standard_always"
+dist_plugins_standard="$plugins_standard image-inline pst-import"
+
+dnl ******************************************************************
+dnl The following plugins have additional library dependencies.
+dnl They must be explicitly disabled if the libraries are not present.
+dnl ******************************************************************
+
+dnl **************************************************
+dnl audio-inline plugin requires gstreamer-1.0 or 0.10
+dnl **************************************************
+AC_ARG_ENABLE([audio-inline],
+ [AS_HELP_STRING([--enable-audio-inline],
+ [Enable audio-inline plugin @<:@default=yes@:>@])],
+ [enable_audio_inline="$enableval"], [enable_audio_inline=yes])
+
+if test "x$enable_audio_inline" = "xyes"; then
+ PKG_CHECK_MODULES([GSTREAMER], [gstreamer-1.0], have_gst=yes,
+ [PKG_CHECK_MODULES([GSTREAMER], [gstreamer-0.10], have_gst=yes, have_gst=no)],
+ have_gst=no)
+ AC_SUBST(GSTREAMER_CFLAGS)
+ AC_SUBST(GSTREAMER_LIBS)
+
+ if test "x$have_gst" = "xyes"; then
+ AC_DEFINE(ENABLE_AUDIO_INLINE, 1, [Define to add support for inlining audio attachments])
+ else
+ AC_MSG_ERROR([
+
+ gstreamer-1.0 or 0.10 not found.
+
+ If you want to disable support for playing audio attachments,
+ please append --disable-audio-inline to configure.
+
+ ])
+ fi
+fi
+
+AM_CONDITIONAL([ENABLE_AUDIO_INLINE], [test "x$enable_audio_inline" = "xyes"])
+
+dnl **************************************************
+dnl text-highlight plugins requires highlight utility
+dnl **************************************************
+AC_ARG_ENABLE([text-highlight],
+ [AS_HELP_STRING([--enable-text-highlight],
+ [Enable text-highlight plugin (default=yes)])],
+ [enable_text_highlight="$enableval"], [enable_text_highlight=yes])
+AC_MSG_CHECKING([if source code highlighting support is enabled])
+AC_MSG_RESULT([$enable_text_highlight])
+msg_text_highlight="$enable_text_highlight"
+if test "x$enable_text_highlight" = "xyes"; then
+ AC_ARG_VAR([HIGHLIGHT], [Source code highlighting utility])
+ AC_PATH_PROG([HIGHLIGHT], [highlight])
+ if test "x$HIGHLIGHT" == "x"; then
+ AC_MSG_ERROR([
+
+ Highlight utility not found.
+
+ If you want to disable syntax highlighting in emails,
+ please append --disable-text-highlight to configure.
+
+ ])
+ fi
+ AC_DEFINE_UNQUOTED(
+ HIGHLIGHT_COMMAND, "$HIGHLIGHT",
+ [Source code highlighting utility])
+
+ msg_text_highlight="$msg_text_highlight ($HIGHLIGHT)"
+fi
+AM_CONDITIONAL([ENABLE_TEXT_HIGHLIGHT], [test "x$enable_text_highlight" = "xyes"])
+
+dnl **************************************
+dnl Weather calendars require gweather-3.0
+dnl **************************************
+AC_ARG_ENABLE([weather],
+ [AS_HELP_STRING([--enable-weather],
+ [Enable weather calendars @<:@default=yes@:>@])],
+ [enable_weather="$enableval"],[enable_weather=yes])
+
+if test "x$enable_weather" != "xno"; then
+ PKG_CHECK_MODULES(
+ [GWEATHER], [gweather-3.0 >= gweather_minimum_version],,
+ [AC_MSG_ERROR([
+
+ gweather-3.0 not found (or version < gweather_minimum_version)
+
+ If you want to disable weather calendar support,
+ please append --disable-weather to configure.
+
+ ])])
+fi
+AM_CONDITIONAL(ENABLE_WEATHER, [test "x$enable_weather" != "xno"])
+
+dnl ********************************************************************
+dnl maps in contacts preview requires champlain-gtk, geoclue and clutter
+dnl ********************************************************************
+AC_ARG_ENABLE([contact-maps],
+ [AS_HELP_STRING([--enable-contact-maps],
+ [Enable contact maps @<:@default=no@:>@])],
+ [enable_contact_maps="$enableval"], [enable_contact_maps="no"])
+
+if test "x$enable_contact_maps" = "xyes"; then
+ PKG_CHECK_MODULES(
+ [CHAMPLAIN],
+ [champlain-gtk-0.12 >= champlain_minimum_version],,
+ [AC_MSG_ERROR([
+
+ champlain-gtk-0.12 not found.
+
+ If you want to disable the contact maps feature,
+ please append --disable-contact-maps to configure.
+
+ ])])
+
+ dnl Restrict geocode-glib dependency to 0.99.0 so
+ dnl we don't have to chase subsequent API changes.
+ PKG_CHECK_MODULES(
+ [GEO],
+ [geoclue >= geoclue_minimum_version
+ geocode-glib = 0.99.0],,
+ [AC_MSG_ERROR([
+
+ geoclue and/or geocode-glib not found.
+
+ If you want to disable the contact maps feature,
+ please append --disable-contact-maps to configure.
+
+ ])])
+
+ PKG_CHECK_MODULES(
+ [CLUTTER_GTK],
+ [clutter-gtk-1.0 >= clutter_gtk_minimum_version],,
+ [AC_MSG_ERROR([
+
+ clutter-gtk-1.0 not found (or version < clutter_gtk_minimum_version)
+
+ If you want to disable the contact maps feature,
+ please append --disable-contact-maps to configure.
+
+ ])])
+
+ AC_DEFINE(WITH_CONTACT_MAPS, 1, [When defined contacts preview will contain maps])
+fi
+
+dnl *****************************************
+dnl image-inline plugin requires gtkimageview
+dnl *****************************************
+AC_ARG_ENABLE([image-inline],
+ [AS_HELP_STRING([--enable-image-inline],
+ [Enable image-inline plugin @<:@default=no@:>@])],
+ [enable_image_inline="$enableval"], [enable_image_inline=no])
+
+if test "x$enable_image_inline" = "xyes"; then
+ PKG_CHECK_MODULES(GTKIMAGEVIEW, gtkimageview >= gtkimageview_minimum_version, have_imageview=yes, have_imageview=no)
+ AC_SUBST(GTKIMAGEVIEW_CFLAGS)
+ AC_SUBST(GTKIMAGEVIEW_LIBS)
+
+ if test "x$have_imageview" = "xyes"; then
+ plugins_standard="$plugins_standard image-inline"
+ else
+ AC_MSG_ERROR([
+
+ gtkimageview not found (or version < gtkimageview_minimum_version)
+
+ If you want to disable the image-inline plugin,
+ please append --disable-image-inline to configure.
+
+ ])
+ fi
+fi
+
+dnl *********************************
+dnl pst-import plugin requires libpst
+dnl *********************************
+AC_ARG_ENABLE([pst-import],
+ [AS_HELP_STRING([--enable-pst-import],
+ [Enable pst-import plugin @<:@default=yes@:>@])],
+ [enable_pst="$enableval"], [enable_pst=yes])
+
+if test "x$enable_pst" = "xyes"; then
+ PKG_CHECK_MODULES(LIBPST, libpst >= libpst_minimum_version, have_pst=yes, have_pst=no)
+ AC_SUBST(LIBPST_CFLAGS)
+ AC_SUBST(LIBPST_LIBS)
+
+ if test "x$have_pst" = "xyes"; then
+ plugins_standard="$plugins_standard pst-import"
+ else
+ AC_MSG_ERROR([
+
+ libpst not found (or version < libpst_minimum_version)
+
+ If you want to disable PST importing support,
+ please append --disable-pst-import to configure.
+
+ ])
+ fi
+fi
+
+case x"$enable_plugins" in
+xno)
+ plugins_enabled=""
+ msg_plugins="no (some core functionality will not be available)"
+ ;;
+xall | x | xyes)
+ plugins_enabled="$plugins_base $plugins_standard"
+ msg_plugins="yes (all)"
+ ;;
+xbase)
+ plugins_enabled="$plugins_base"
+ msg_plugins="yes ($plugins_base)"
+ ;;
+*)
+ AC_MSG_ERROR([Invalid value for --enable-plugins.
+ Please specify either "no", "base", or "all" (default=all)])
+ ;;
+esac
+
+AC_SUBST(plugins_enabled)
+AC_SUBST(dist_plugins_base)
+AC_SUBST(dist_plugins_standard)
+
+dnl ******************
+dnl Sub-version number
+dnl ******************
+AC_ARG_WITH([sub-version],
+ AS_HELP_STRING([--with-sub-version=VERSION],
+ [Specify a sub-version string]))
+
+AC_DEFINE_UNQUOTED(SUB_VERSION, "$with_sub_version", [Version substring, for packagers])
+
+dnl ********************************************
+dnl Glade 3 catalog files (for maintainers only)
+dnl ********************************************
+AC_ARG_WITH([glade-catalog],
+ [AS_HELP_STRING([--with-glade-catalog],
+ [Install the catalog files for Glade 3 ]
+ [(for maintainers only) [default=no]])],
+ [with_catalog="$withval"], [with_catalog="no"])
+if test "$with_catalog" = "yes"; then
+ PKG_CHECK_MODULES(GLADEUI, [gladeui-2.0 >= gladeui_minimum_version])
+fi
+AM_CONDITIONAL(GLADE_CATALOG, test "x$with_catalog" != "xno")
+
+dnl ******************************
+dnl Makefiles
+dnl ******************************
+
+export privlibdir
+export privincludedir
+export privdatadir
+export plugindir
+
+EVOLUTION_DIR=`(cd $srcdir; pwd)`
+AC_SUBST(EVOLUTION_DIR)
+
+AC_CONFIG_FILES([ po/Makefile.in
+Makefile
+addressbook/Makefile
+addressbook/gui/Makefile
+addressbook/gui/contact-editor/Makefile
+addressbook/gui/contact-list-editor/Makefile
+addressbook/gui/merging/Makefile
+addressbook/gui/widgets/Makefile
+addressbook/importers/Makefile
+addressbook/printing/Makefile
+addressbook/tools/Makefile
+addressbook/tools/csv2vcard
+addressbook/util/Makefile
+art/Makefile
+data/Makefile
+data/evolution.desktop.in
+data/evolution-alarm-notify.desktop.in
+data/icons/Makefile
+doc/Makefile
+doc/reference/Makefile
+doc/reference/evolution-mail-composer/Makefile
+doc/reference/evolution-mail-formatter/Makefile
+doc/reference/evolution-shell/Makefile
+doc/reference/evolution-util/Makefile
+e-util/Makefile
+em-format/Makefile
+help/Makefile
+help/quickref/Makefile
+help/quickref/C/Makefile
+help/quickref/ca/Makefile
+help/quickref/cs/Makefile
+help/quickref/de/Makefile
+help/quickref/es/Makefile
+help/quickref/hu/Makefile
+help/quickref/it/Makefile
+help/quickref/fr/Makefile
+help/quickref/oc/Makefile
+help/quickref/pl/Makefile
+help/quickref/pt/Makefile
+help/quickref/sv/Makefile
+help/quickref/sq/Makefile
+libemail-engine/Makefile
+libemail-engine/libemail-engine.pc
+libgnomecanvas/Makefile
+shell/Makefile
+shell/evo-version.h
+ui/Makefile
+views/Makefile
+views/addressbook/Makefile
+views/calendar/Makefile
+views/mail/Makefile
+views/tasks/Makefile
+views/memos/Makefile
+calendar/Makefile
+calendar/alarm-notify/Makefile
+calendar/importers/Makefile
+calendar/gui/Makefile
+calendar/gui/dialogs/Makefile
+composer/Makefile
+m4/Makefile
+mail/Makefile
+mail/default/Makefile
+mail/default/C/Makefile
+mail/default/ca/Makefile
+mail/default/cs/Makefile
+mail/default/de/Makefile
+mail/default/es/Makefile
+mail/default/fi/Makefile
+mail/default/fr/Makefile
+mail/default/hu/Makefile
+mail/default/id/Makefile
+mail/default/it/Makefile
+mail/default/ja/Makefile
+mail/default/ko/Makefile
+mail/default/lt/Makefile
+mail/default/mk/Makefile
+mail/default/nl/Makefile
+mail/default/pl/Makefile
+mail/default/pt/Makefile
+mail/default/ro/Makefile
+mail/default/sr/Makefile
+mail/default/sr@latin/Makefile
+mail/default/sv/Makefile
+mail/default/zh_CN/Makefile
+mail/importers/Makefile
+maint/Makefile
+modules/Makefile
+modules/addressbook/Makefile
+modules/audio-inline/Makefile
+modules/backup-restore/Makefile
+modules/bogofilter/Makefile
+modules/book-config-google/Makefile
+modules/book-config-ldap/Makefile
+modules/book-config-local/Makefile
+modules/book-config-webdav/Makefile
+modules/cal-config-caldav/Makefile
+modules/cal-config-contacts/Makefile
+modules/cal-config-google/Makefile
+modules/cal-config-local/Makefile
+modules/cal-config-weather/Makefile
+modules/cal-config-webcal/Makefile
+modules/calendar/Makefile
+modules/composer-autosave/Makefile
+modules/contact-photos/Makefile
+modules/gravatar/Makefile
+modules/itip-formatter/Makefile
+modules/itip-formatter/plugin/Makefile
+modules/mail-config/Makefile
+modules/mail/Makefile
+modules/mailto-handler/Makefile
+modules/mdn/Makefile
+modules/offline-alert/Makefile
+modules/plugin-lib/Makefile
+modules/plugin-manager/Makefile
+modules/prefer-plain/Makefile
+modules/prefer-plain/plugin/Makefile
+modules/settings/Makefile
+modules/spamassassin/Makefile
+modules/startup-wizard/Makefile
+modules/text-highlight/Makefile
+modules/tnef-attachment/Makefile
+modules/vcard-inline/Makefile
+modules/web-inspector/Makefile
+plugins/Makefile
+plugins/attachment-reminder/Makefile
+plugins/bbdb/Makefile
+plugins/dbx-import/Makefile
+plugins/email-custom-header/Makefile
+plugins/external-editor/Makefile
+plugins/face/Makefile
+plugins/image-inline/Makefile
+plugins/mail-notification/Makefile
+plugins/mail-to-task/Makefile
+plugins/mailing-list-actions/Makefile
+plugins/pst-import/Makefile
+plugins/publish-calendar/Makefile
+plugins/save-calendar/Makefile
+plugins/templates/Makefile
+smime/Makefile
+smime/lib/Makefile
+smime/gui/Makefile
+sounds/Makefile
+evolution-zip
+evolution-calendar.pc
+evolution-mail.pc
+evolution-shell.pc
+evolution-plugin.pc
+])
+
+AC_OUTPUT
+
+if test "x$with_sub_version" != "x"; then
+echo "
+ Evolution ($with_sub_version) has been configured as follows: "
+else
+echo "
+ Evolution has been configured as follows: "
+fi
+
+echo "
+ LDAP support: $msg_ldap
+ Contact Maps: $enable_contact_maps
+ Libnotify: $HAVE_LIBNOTIFY
+ Kerberos 5: $msg_krb5
+ SSL support: $msg_ssl
+ SMIME support: $msg_smime
+ Bogofilter support: $msg_bogofilter
+ SpamAssassin support: $msg_spamassassin
+ Highlight support: $msg_text_highlight
+ Plugins: $msg_plugins
+ User documentation: $with_help
+ Strict building: $enable_strict
+"