mirror of https://git.code.sf.net/p/isync/isync
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
288 lines
7.6 KiB
288 lines
7.6 KiB
# SPDX-FileCopyrightText: 2000-2002 Michael R. Elkins <me@mutt.org> |
|
# SPDX-FileCopyrightText: 2002-2022 Oswald Buddenhagen <ossi@users.sf.net> |
|
dnl SPDX-License-Identifier: GPL-2.0-or-later |
|
|
|
m4_syscmd([./version.sh]) |
|
AC_INIT([isync], m4_include([VERSION])) |
|
AC_CONFIG_HEADERS([autodefs.h]) |
|
|
|
AC_CANONICAL_TARGET |
|
|
|
AM_INIT_AUTOMAKE |
|
AM_MAINTAINER_MODE |
|
|
|
AC_PROG_CC |
|
if test "$GCC" = yes; then |
|
warnings=" |
|
-Wall -Wextra |
|
-Wshadow |
|
-Wcast-qual |
|
-Wformat=2 -Wformat-signedness -Wformat-nonliteral |
|
-Wstrict-prototypes |
|
|
|
-Wno-overlength-strings |
|
" |
|
CFLAGS="$CFLAGS -pipe -std=c11 -pedantic $(echo $warnings)" |
|
fi |
|
|
|
AC_COMPILE_IFELSE([AC_LANG_SOURCE([ |
|
void fkt(void) |
|
{ |
|
int a = 42; // c99 comment |
|
|
|
for (int i = 0; i < a; i++) {} // declaration inside for() |
|
int b; // declaration after code |
|
} |
|
|
|
// c11 anonymous structs/unions |
|
struct base { |
|
int a; |
|
}; |
|
union deriv { |
|
struct base gen; |
|
struct { |
|
int a; |
|
int b; |
|
}; |
|
}; |
|
])], , [AC_MSG_ERROR([compiler does not support required C11 features])]) |
|
|
|
CPPFLAGS="$CPPFLAGS -D_GNU_SOURCE" |
|
|
|
AC_CHECK_PROG(PERL, perl, perl) |
|
if test "x$PERL" = "x"; then |
|
AC_MSG_ERROR([perl not found]) |
|
fi |
|
|
|
need_perl=5.14 |
|
AC_CACHE_CHECK([whether perl is recent enough], ob_cv_perl_ver, [ |
|
if $PERL -e "use v$need_perl;" 2> /dev/null; then |
|
ob_cv_perl_ver=yes |
|
else |
|
ob_cv_perl_ver=no |
|
fi |
|
]) |
|
if test "x$ob_cv_perl_ver" = "xno"; then |
|
AC_MSG_ERROR([perl is too old, need v$need_perl]) |
|
fi |
|
|
|
AC_CACHE_CHECK([whether strftime supports %z], ob_cv_strftime_z, |
|
[AC_RUN_IFELSE([AC_LANG_SOURCE([[ |
|
#include <time.h> |
|
#include <string.h> |
|
|
|
int main(void) |
|
{ |
|
time_t t = 0; |
|
char buf[32]; |
|
strftime(buf, sizeof(buf), "%z", localtime(&t)); |
|
return !(buf[0] == '+' || buf[0] == '-'); |
|
} |
|
]])], [ob_cv_strftime_z=yes], [ob_cv_strftime_z=no], [ob_cv_strftime_z="yes (assumed)"])]) |
|
if test "x$ob_cv_strftime_z" = x"no"; then |
|
AC_MSG_ERROR([libc lacks necessary feature]) |
|
fi |
|
|
|
AC_CHECK_HEADERS(poll.h sys/select.h) |
|
AC_CHECK_FUNCS(vasprintf strnlen memrchr timegm fwrite_unlocked) |
|
|
|
AC_CHECK_LIB(socket, socket, [SOCK_LIBS="-lsocket"]) |
|
AC_CHECK_LIB(nsl, inet_ntoa, [SOCK_LIBS="$SOCK_LIBS -lnsl"]) |
|
AC_SUBST(SOCK_LIBS) |
|
|
|
have_ipv6=true |
|
sav_LIBS=$LIBS |
|
LIBS="$LIBS $SOCK_LIBS" |
|
AC_CHECK_FUNCS(getaddrinfo inet_ntop, , [have_ipv6=false]) |
|
LIBS=$sav_LIBS |
|
if $have_ipv6; then |
|
AC_DEFINE(HAVE_IPV6, 1, [if your libc has IPv6 support]) |
|
fi |
|
|
|
have_ssl_paths= |
|
AC_ARG_WITH(ssl, |
|
AS_HELP_STRING([--with-ssl[=PATH]], [where to look for SSL [detect]]), |
|
[ob_cv_with_ssl=$withval]) |
|
if test "x$ob_cv_with_ssl" != xno; then |
|
case $ob_cv_with_ssl in |
|
""|yes) |
|
dnl Detect the pkg-config tool, as it may have extra info about the openssl |
|
dnl installation we can use. I *believe* this is what we are expected to do |
|
dnl on really recent Redhat Linux hosts. |
|
PKG_PROG_PKG_CONFIG |
|
if test "x$PKG_CONFIG" != "x" ; then |
|
AC_MSG_CHECKING([OpenSSL presence with pkg-config]) |
|
if $PKG_CONFIG --exists openssl; then |
|
SSL_LIBS=`$PKG_CONFIG --libs-only-l openssl` |
|
SSL_LDFLAGS=`$PKG_CONFIG --libs-only-L openssl` |
|
SSL_CPPFLAGS=`$PKG_CONFIG --cflags-only-I openssl` |
|
have_ssl_paths=yes |
|
AC_MSG_RESULT([found]) |
|
else |
|
AC_MSG_RESULT([not found]) |
|
fi |
|
fi |
|
;; |
|
*) |
|
SSL_LDFLAGS=-L$ob_cv_with_ssl/lib$libsuff |
|
SSL_CPPFLAGS=-I$ob_cv_with_ssl/include |
|
;; |
|
esac |
|
if test -z "$have_ssl_paths"; then |
|
sav_LDFLAGS=$LDFLAGS |
|
LDFLAGS="$LDFLAGS $SSL_LDFLAGS" |
|
AC_CHECK_LIB(dl, dlopen, [LIBDL=-ldl]) |
|
AC_CHECK_LIB(crypto, X509_cmp, [LIBCRYPTO=-lcrypto]) |
|
AC_CHECK_LIB(ssl, SSL_connect, |
|
[SSL_LIBS="-lssl $LIBCRYPTO $LIBDL" have_ssl_paths=yes]) |
|
LDFLAGS=$sav_LDFLAGS |
|
fi |
|
|
|
sav_CPPFLAGS=$CPPFLAGS |
|
CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS" |
|
AC_CHECK_HEADER(openssl/ssl.h, , [have_ssl_paths=]) |
|
CPPFLAGS=$sav_CPPFLAGS |
|
|
|
if test -z "$have_ssl_paths"; then |
|
if test -n "$ob_cv_with_ssl"; then |
|
AC_MSG_ERROR([OpenSSL libs and/or includes were not found where specified]) |
|
fi |
|
else |
|
AC_DEFINE(HAVE_LIBSSL, 1, [if you have the OpenSSL libraries]) |
|
CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS" |
|
LDFLAGS="$LDFLAGS $SSL_LDFLAGS" |
|
fi |
|
fi |
|
AC_SUBST(SSL_LIBS) |
|
|
|
have_sasl_paths= |
|
AC_ARG_WITH(sasl, |
|
AS_HELP_STRING([--with-sasl[=PATH]], [where to look for SASL [detect]]), |
|
[ob_cv_with_sasl=$withval]) |
|
if test "x$ob_cv_with_sasl" != xno; then |
|
case $ob_cv_with_sasl in |
|
""|yes) |
|
dnl FIXME: Try various possible paths here... |
|
;; |
|
*) |
|
SASL_LDFLAGS=-L$ob_cv_with_sasl/lib$libsuff |
|
SASL_CPPFLAGS=-I$ob_cv_with_sasl/include |
|
;; |
|
esac |
|
if test -z "$have_sasl_paths"; then |
|
sav_LDFLAGS=$LDFLAGS |
|
LDFLAGS="$LDFLAGS $SASL_LDFLAGS" |
|
AC_CHECK_LIB(sasl2, sasl_client_init, |
|
[SASL_LIBS="-lsasl2" have_sasl_paths=yes]) |
|
LDFLAGS=$sav_LDFLAGS |
|
fi |
|
|
|
sav_CPPFLAGS=$CPPFLAGS |
|
CPPFLAGS="$CPPFLAGS $SASL_CPPFLAGS" |
|
AC_CHECK_HEADER(sasl/sasl.h, , [have_sasl_paths=]) |
|
CPPFLAGS=$sav_CPPFLAGS |
|
|
|
if test -z "$have_sasl_paths"; then |
|
if test -n "$ob_cv_with_sasl"; then |
|
AC_MSG_ERROR([SASL libs and/or includes were not found where specified]) |
|
fi |
|
else |
|
AC_DEFINE(HAVE_LIBSASL, 1, [if you have the SASL libraries]) |
|
CPPFLAGS="$CPPFLAGS $SASL_CPPFLAGS" |
|
LDFLAGS="$LDFLAGS $SASL_LDFLAGS" |
|
fi |
|
fi |
|
AC_SUBST(SASL_LIBS) |
|
|
|
AC_CACHE_CHECK([for Berkeley DB >= 4.1], ac_cv_berkdb4, |
|
[ac_cv_berkdb4=no |
|
sav_LIBS=$LIBS |
|
LIBS="$LIBS -ldb" |
|
AC_LINK_IFELSE([AC_LANG_PROGRAM( |
|
[#include <db.h>], |
|
[DB *db; |
|
db_create(&db, 0, 0); |
|
db->truncate(db, 0, 0, 0); |
|
db->open(db, 0, "foo", "foo", DB_HASH, DB_CREATE, 0); |
|
])], [ac_cv_berkdb4=yes], []) |
|
LIBS=$sav_LIBS |
|
]) |
|
if test "x$ac_cv_berkdb4" = xyes; then |
|
AC_SUBST([DB_LIBS], ["-ldb"]) |
|
AC_DEFINE(USE_DB, 1, [if Berkeley DB should be used]) |
|
fi |
|
|
|
have_zlib= |
|
AC_ARG_WITH(zlib, |
|
AS_HELP_STRING([--with-zlib], [use zlib [detect]]), |
|
[ob_cv_with_zlib=$withval]) |
|
if test "x$ob_cv_with_zlib" != xno; then |
|
AC_CHECK_LIB([z], [deflate], |
|
[AC_CHECK_HEADER(zlib.h, |
|
[have_zlib=1 |
|
AC_SUBST([Z_LIBS], ["-lz"]) |
|
AC_DEFINE([HAVE_LIBZ], 1, [if you have the zlib library])] |
|
)] |
|
) |
|
fi |
|
|
|
AM_CONDITIONAL(with_mdconvert, test "x$ac_cv_berkdb4" = xyes) |
|
|
|
case $target_os in |
|
darwin*) |
|
darwin=yes |
|
;; |
|
*) |
|
darwin=no |
|
;; |
|
esac |
|
|
|
AC_ARG_WITH( |
|
macos-keychain, |
|
[AS_HELP_STRING([--with-macos-keychain], [Support macOS keychain])], |
|
[have_macos_keychain=$withval], |
|
[have_macos_keychain=$darwin]) |
|
if test "x$have_macos_keychain" != xno; then |
|
if test $darwin = no; then |
|
AC_MSG_ERROR([Cannot use macOS Keychain outside macOS.]) |
|
fi |
|
have_macos_keychain=yes |
|
AC_DEFINE(HAVE_MACOS_KEYCHAIN, 1, [Define to 1 if you have the macOS Keychain Services API.]) |
|
AC_SUBST(KEYCHAIN_LIBS, ["-Wl,-framework,Security,-framework,CoreFoundation"]) |
|
fi |
|
|
|
RELEASE_DATE=`date -r $0 +%F` |
|
AC_SUBST(RELEASE_DATE) |
|
|
|
AC_CONFIG_FILES([Makefile src/Makefile src/mbsync.1 src/mdconvert.1 isync.spec]) |
|
AC_OUTPUT |
|
|
|
AC_MSG_RESULT() |
|
if test -n "$have_ssl_paths"; then |
|
AC_MSG_RESULT([Using SSL]) |
|
else |
|
AC_MSG_RESULT([Not using SSL]) |
|
fi |
|
if test -n "$have_sasl_paths"; then |
|
AC_MSG_RESULT([Using SASL]) |
|
else |
|
AC_MSG_RESULT([Not using SASL]) |
|
fi |
|
if test -n "$have_zlib"; then |
|
AC_MSG_RESULT([Using zlib]) |
|
else |
|
AC_MSG_RESULT([Not using zlib]) |
|
fi |
|
if test "x$ac_cv_berkdb4" = xyes; then |
|
AC_MSG_RESULT([Using Berkeley DB]) |
|
else |
|
AC_MSG_RESULT([Not using Berkeley DB]) |
|
fi |
|
if test $darwin = yes; then |
|
if test "x$have_macos_keychain" = xyes; then |
|
AC_MSG_RESULT([Using macOS Keychain]) |
|
else |
|
AC_MSG_RESULT([Not using macOS Keychain]) |
|
fi |
|
fi |
|
AC_MSG_RESULT()
|
|
|