X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/19c905b4e2593c2a97705ced49f4f017571dbd56..51ac63c5d3635ca302ead91b42a7df4c0340428a:/configure.ac diff --git a/configure.ac b/configure.ac index a57a830..619f23e 100644 --- a/configure.ac +++ b/configure.ac @@ -19,7 +19,7 @@ AC_DEFUN([CY_CHECK_PROGS_VERSION], [ ac_cv_path_]$1[=$ac_path_]$1[ ) , - AC_MSG_RESULT(not found) + AC_MSG_RESULT(no) AC_MSG_ERROR(You need ]$2[ ]$5[ or greater) ) AC_SUBST(]$1[, $ac_cv_path_]$1[) @@ -35,10 +35,14 @@ AC_ARG_VAR([GPERF], [perfect hash function generator]) CY_CHECK_PROGS_VERSION([GPERF], [gperf], [gperf], [--version | $SED -e '1 s/^.* \(@<:@0-9.@:>@*\)$/\1/p;d'], [3.0.3]) AC_PROG_INSTALL -AC_MSG_CHECKING([for GNU tar]) +AC_MSG_CHECKING([for GNU tar >=1.19]) AC_PATH_PROGS_FEATURE_CHECK([GNUTAR], [tar gtar gnutar], [ AS_IF([test "x`$ac_path_GNUTAR --version | $SED -e '1 s/^tar (GNU tar)/&/p;d'`" != x], [ - ac_cv_path_GNUTAR=$ac_path_GNUTAR + AS_VERSION_COMPARE([`$ac_path_GNUTAR --version | $SED -e '1 s/^tar (GNU tar) \(.*\)$/\1/p;d'`], [1.19], , [ + ac_cv_path_GNUTAR=$ac_path_GNUTAR + ], [ + ac_cv_path_GNUTAR=$ac_path_GNUTAR + ]) ]) ]) AS_IF([test "x$ac_cv_path_GNUTAR" != x], [ @@ -46,7 +50,7 @@ AS_IF([test "x$ac_cv_path_GNUTAR" != x], [ AC_MSG_RESULT([$GNUTAR]) ], [ AC_SUBST([GNUTAR], [:]) - AC_MSG_RESULT([not found]) + AC_MSG_RESULT([no]) ]) AC_CHECK_PROGS([SVN], [svn]) AC_CHECK_PROGS([SVNVERSION], [svnversion]) @@ -68,12 +72,6 @@ AS_CASE([$apr_found], [yes], [ AC_LIB_APPENDTOVAR([CPPFLAGS], [`$apr_config --includes`]) AC_SUBST([LTLIBAPR], [`$apr_config --link-libtool`]) ], [AC_MSG_ERROR([You need apr])]) -VL_LIB_READLINE -AS_CASE([$vl_cv_lib_readline], [no], [AC_MSG_ERROR([You need readline])]) -AC_LANG_PUSH([C]) -AM_ICONV -AC_LANG_POP([C]) -AS_CASE([$am_cv_func_iconv], [yes], [], [AC_MSG_ERROR([You need iconv])]) AC_DEFUN([CY_CHECK_JAVASCRIPTCORE], [ PKG_CHECK_MODULES([WEBKIT], [webkit-1.0], [ CY_EXECUTE=1 @@ -104,20 +102,22 @@ AC_ARG_ENABLE([javascript], [AS_HELP_STRING( CY_CHECK_JAVASCRIPTCORE ], [AC_MSG_ERROR([Unknown JavaScript engine: $enableval])]) ], [CY_CHECK_JAVASCRIPT]) -AS_CASE([$CY_EXECUTE], [1], [ - AC_SUBST([CY_EXECUTE]) +AC_DEFUN([CY_CHECK_PKG_CONFIG_LIBFFI], [ PKG_CHECK_MODULES([LIBFFI], [libffi], [ AC_LIB_APPENDTOVAR([CXXFLAGS], [`$PKG_CONFIG --cflags libffi`]) AC_LIB_APPENDTOVAR([LIBS], [`$PKG_CONFIG --libs libffi`]) ], [ - AC_CHECK_HEADERS([ffi.h ffi/ffi.h], [break]) - AS_IF([test "x$ac_cv_header_ffi_h" = xno && test "x$ac_cv_header_ffi_ffi_h" = xno], [ - AC_MSG_ERROR([You need libffi]) - ]) + AC_MSG_ERROR([You need libffi]) + ]) +]) +AS_CASE([$CY_EXECUTE], [1], [ + AC_SUBST([CY_EXECUTE]) + AC_CHECK_HEADERS([ffi.h ffi/ffi.h], [break]) + AS_IF([test "x$ac_cv_header_ffi_h" = xno && test "x$ac_cv_header_ffi_ffi_h" = xno], [ + CY_CHECK_PKG_CONFIG_LIBFFI + ], [ AC_SEARCH_LIBS([ffi_call], [ffi]) - AS_CASE([$ac_cv_search_ffi_call], [no], [ - AC_MSG_ERROR([You need libffi]) - ]) + AS_CASE([$ac_cv_search_ffi_call], [no], [CY_CHECK_PKG_CONFIG_LIBFFI]) ]) AC_LANG_PUSH([Objective C++]) AC_MSG_CHECKING([if we really have Objective C++]) @@ -150,6 +150,26 @@ AS_CASE([$CY_EXECUTE], [1], [ ]) AC_LANG_POP([Objective C++]) ]) +VL_LIB_READLINE +AS_CASE([$vl_cv_lib_readline], [no], [AC_MSG_ERROR([You need readline])]) +AC_LANG_PUSH([C]) +AM_ICONV +AS_CASE([$am_cv_func_iconv], [yes], [], [ + for cy_iconv_prefix_arg in $CFLAGS $CXXFLAGS $OBJCXXFLAGS $LDFLAGS $LIBS; do + AS_CASE([$cy_iconv_prefix_arg], [-I*], [ + AC_LIB_APPENDTOVAR([cy_iconv_prefixes], [`echo $cy_iconv_prefix_arg | sed -e 's/^-I//;s|/include$||'`]) + ], [-L*], [ + AC_LIB_APPENDTOVAR([cy_iconv_prefixes], [`echo $cy_iconv_prefix_arg | sed -e 's/^-L//;s|/lib$||'`]) + ]) + done + for with_libiconv_prefix in $cy_iconv_prefixes; do + AS_UNSET([am_cv_func_iconv]) + AM_ICONV_LINKFLAGS_BODY + AM_ICONV + done +]) +AS_CASE([$am_cv_func_iconv], [yes], [], [AC_MSG_ERROR([You need iconv])]) +AC_LANG_POP([C]) AS_IF([test "x$CY_OBJECTIVEC" = x1], [ AC_CHECK_HEADER([mach/mach.h], [ AS_CASE([$OTOOL], [:], [AC_MSG_WARN([Missing otool?])], [AC_SUBST([CY_OBJECTIVEC_MACH], [1])])