diff options
Diffstat (limited to 'configure.ac')
| -rw-r--r-- | configure.ac | 117 | 
1 files changed, 80 insertions, 37 deletions
| diff --git a/configure.ac b/configure.ac index 503051f..055fe04 100644 --- a/configure.ac +++ b/configure.ac @@ -15,7 +15,7 @@ dnl libtool versioning  #                 changes to the signature and the semantic)  #  ? :+1 : ?   == just internal changes  # CURRENT : REVISION : AGE -LIBIMOBILEDEVICE_SO_VERSION=6:0:0 +LIBIMOBILEDEVICE_SO_VERSION=7:0:1  AC_SUBST(LIBIMOBILEDEVICE_SO_VERSION) @@ -26,8 +26,9 @@ fi  dnl Minimum package versions  LIBUSBMUXD_VERSION=2.0.2 -LIBPLIST_VERSION=2.2.0 -LIMD_GLUE_VERSION=1.0.0 +LIBPLIST_VERSION=2.3.0 +LIMD_GLUE_VERSION=1.3.0 +LIBTATSU_VERSION=1.0.3  AC_SUBST(LIBUSBMUXD_VERSION)  AC_SUBST(LIBPLIST_VERSION) @@ -43,6 +44,19 @@ LT_INIT  PKG_CHECK_MODULES(libusbmuxd, libusbmuxd-2.0 >= $LIBUSBMUXD_VERSION)  PKG_CHECK_MODULES(libplist, libplist-2.0 >= $LIBPLIST_VERSION)  PKG_CHECK_MODULES(limd_glue, libimobiledevice-glue-1.0 >= $LIMD_GLUE_VERSION) +PKG_CHECK_MODULES(libtatsu, libtatsu-1.0 >= $LIBTATSU_VERSION) +AC_ARG_WITH([readline], +            [AS_HELP_STRING([--without-readline], +            [build without support for libreadline (default is yes)])], +            [check_libreadline=false], +            [check_libreadline=true]) +if test "$check_libreadline" = "true"; then +  PKG_CHECK_MODULES(readline, readline >= 1.0, have_readline=yes, have_readline=no) +  if test "x$have_readline" = "xyes"; then +    AC_DEFINE(HAVE_READLINE, 1, [Define if readline library is available]) +  fi +fi +AM_CONDITIONAL([HAVE_READLINE],[test "x$have_readline" = "xyes"])  # Checks for header files.  AC_CHECK_HEADERS([stdint.h stdlib.h string.h sys/time.h]) @@ -56,7 +70,7 @@ AC_TYPE_UINT32_T  AC_TYPE_UINT8_T  # Checks for library functions. -AC_CHECK_FUNCS([asprintf strcasecmp strdup strerror strndup stpcpy vasprintf getifaddrs]) +AC_CHECK_FUNCS([asprintf strcasecmp strdup strerror strndup stpcpy vasprintf getifaddrs gettimeofday localtime_r])  AC_CHECK_HEADER(endian.h, [ac_cv_have_endian_h="yes"], [ac_cv_have_endian_h="no"])  if test "x$ac_cv_have_endian_h" = "xno"; then @@ -70,8 +84,24 @@ if test "x$ac_cv_have_endian_h" = "xno"; then    fi  fi +CACHED_CFLAGS="$CFLAGS" +CFLAGS+=" $libplist_CFLAGS -Werror" +  AC_CHECK_DECL([plist_from_json], [AC_DEFINE([HAVE_PLIST_JSON], [1], [Define if libplist has JSON support])], [], [[#include <plist/plist.h>]]) +# check if libplist has plist_new_unix_date() +AC_CACHE_CHECK(for plist_new_unix_date, ac_cv_plist_unix_date, +	AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ +		#include <plist/plist.h> +		]], [[ +			return plist_new_unix_date(0) ? 0 : 1 +		]])],[ac_cv_plist_unix_date=yes],[ac_cv_plist_unix_date=no])) +if test "$ac_cv_plist_unix_date" = "yes"; then +	AC_DEFINE(HAVE_PLIST_UNIX_DATE, 1, [Define if libplist has new unix date API (>= 2.7.0)]) +fi + +CFLAGS="$CACHED_CFLAGS" +  # Check for operating system  AC_MSG_CHECKING([for platform-specific build settings])  case ${host_os} in @@ -79,6 +109,7 @@ case ${host_os} in      AC_MSG_RESULT([${host_os}])      win32=true      AC_DEFINE(WINVER, 0x0501, [minimum Windows version]) +    deplibs_check_method='pass_all'      ;;    darwin*)      AC_MSG_RESULT([${host_os}]) @@ -93,24 +124,6 @@ esac  AM_CONDITIONAL(WIN32, test x$win32 = xtrue)  AM_CONDITIONAL(DARWIN, test x$darwin = xtrue) -# Check if the C compiler supports __attribute__((constructor)) -AC_CACHE_CHECK([wether the C compiler supports constructor/destructor attributes], -  ac_cv_attribute_constructor, [ -  ac_cv_attribute_constructor=no -  AC_COMPILE_IFELSE([AC_LANG_PROGRAM( -    [[ -      static void __attribute__((constructor)) test_constructor(void) { -      } -      static void __attribute__((destructor)) test_destructor(void) { -      } -    ]], [])], -    [ac_cv_attribute_constructor=yes] -  )] -) -if test "$ac_cv_attribute_constructor" = "yes"; then -  AC_DEFINE(HAVE_ATTRIBUTE_CONSTRUCTOR, 1, [Define if the C compiler supports constructor/destructor attributes]) -fi -  AC_CHECK_MEMBER(struct dirent.d_type, AC_DEFINE(HAVE_DIRENT_D_TYPE, 1, [define if struct dirent has member d_type]),, [#include <dirent.h>])  # Cython Python Bindings @@ -120,9 +133,9 @@ AC_ARG_WITH([cython],              [build_cython=false],              [build_cython=true])  if test "$build_cython" = "true"; then -            AC_PROG_CYTHON([0.17.0]) +            AC_PROG_CYTHON([3.0.0])              if [test "x$CYTHON" != "xfalse"]; then -              AM_PATH_PYTHON([2.3], [ +              AM_PATH_PYTHON([3.0], [                  CYTHON_PYTHON                  AS_COMPILER_FLAG([-Wno-cast-function-type -Werror], [                    CYTHON_CFLAGS+=" -Wno-cast-function-type" @@ -165,7 +178,7 @@ AC_ARG_WITH([mbedtls],              [Do not look for mbedtls])],              [use_mbedtls=$withval],              [use_mbedtls=no]) -if test "x$use_mbedtls" == "xyes"; then +if test "x$use_mbedtls" = "xyes"; then    default_openssl=no  fi  AC_ARG_WITH([gnutls], @@ -173,7 +186,7 @@ AC_ARG_WITH([gnutls],              [Do not look for GnuTLS])],              [use_gnutls=$withval],              [use_gnutls=no]) -if test "x$use_gnutls" == "xyes"; then +if test "x$use_gnutls" = "xyes"; then    default_openssl=no  fi  AC_ARG_WITH([openssl], @@ -182,7 +195,7 @@ AC_ARG_WITH([openssl],              [use_openssl=$withval],              [use_openssl=$default_openssl]) -if test "x$use_mbedtls" == "xyes"; then +if test "x$use_mbedtls" = "xyes"; then    CACHED_CFLAGS="$CFLAGS"    conf_mbedtls_CFLAGS=""    if test -n "$mbedtls_INCLUDES"; then @@ -209,7 +222,7 @@ if test "x$use_mbedtls" == "xyes"; then    ssl_requires=""    AC_SUBST(ssl_requires)  else -  if test "x$use_openssl" == "xyes"; then +  if test "x$use_openssl" = "xyes"; then      pkg_req_openssl="openssl >= 0.9.8"      PKG_CHECK_MODULES(openssl, $pkg_req_openssl, have_openssl=yes, have_openssl=no)      if test "x$have_openssl" != "xyes"; then @@ -222,10 +235,40 @@ else        AC_SUBST(ssl_lib_LIBS)        ssl_provider="OpenSSL";        ssl_requires="$pkg_req_openssl" +      # test if we have LibreSSL +      CACHED_CFLAGS="$CFLAGS" +      CFLAGS="$openssl_CFLAGS" +      ac_cv_is_libressl=no +      AC_COMPILE_IFELSE([AC_LANG_PROGRAM( +        [[ +          #include <openssl/opensslv.h> +        ]], [ +          #ifndef LIBRESSL_VERSION_NUMBER +          #error No LibreSSL +          #endif +        ])], +        [ +          ac_cv_is_libressl=yes +        ], +      ) +      CFLAGS="$CACHED_CFLAGS" +      if test "x$ac_cv_is_libressl" = "xyes"; then +        ssl_provider="LibreSSL" +        case ${host_os} in +          darwin*) +            case ${openssl_LIBS} in +              *.tbd*) +                # using system LibreSSL on Darwin +                ssl_requires="" +                ;; +            esac +            ;; +        esac +      fi        AC_SUBST(ssl_requires)      fi    else -    if test "x$use_gnutls" == "xyes"; then +    if test "x$use_gnutls" = "xyes"; then        pkg_req_gnutls="gnutls >= 2.2.0"        pkg_req_libtasn1="libtasn1 >= 1.1"        PKG_CHECK_MODULES(libgnutls, $pkg_req_gnutls) @@ -246,9 +289,9 @@ else      fi    fi  fi -AM_CONDITIONAL(HAVE_MBEDTLS, test "x$use_mbedtls" == "xyes") -AM_CONDITIONAL(HAVE_OPENSSL, test "x$use_openssl" == "xyes") -AM_CONDITIONAL(HAVE_GCRYPT, test "x$use_gnutls" == "xyes") +AM_CONDITIONAL(HAVE_MBEDTLS, test "x$use_mbedtls" = "xyes") +AM_CONDITIONAL(HAVE_OPENSSL, test "x$use_openssl" = "xyes") +AM_CONDITIONAL(HAVE_GCRYPT, test "x$use_gnutls" = "xyes")  AC_ARG_ENABLE([wireless-pairing],              [AS_HELP_STRING([--disable-wireless-pairing], @@ -271,12 +314,12 @@ else  fi  AS_COMPILER_FLAGS(GLOBAL_CFLAGS, "-Wall -Wextra -Wmissing-declarations -Wredundant-decls -Wshadow -Wpointer-arith -Wwrite-strings -Wswitch-default -Wno-unused-parameter -fsigned-char -fvisibility=hidden") -AC_SUBST(GLOBAL_CFLAGS) -case "$GLOBAL_CFLAGS" in -  *-fvisibility=hidden*) -    AC_DEFINE([HAVE_FVISIBILITY], [1], [Define if compiled with -fvisibility=hidden]) -esac +if test "x$enable_static" = "xyes" -a "x$enable_shared" = "xno"; then +  GLOBAL_CFLAGS+=" -DLIBIMOBILEDEVICE_STATIC" +fi + +AC_SUBST(GLOBAL_CFLAGS)  # check for large file support  AC_SYS_LARGEFILE | 
