dnl Cycript - Optimizing JavaScript Compiler/Runtime
-dnl Copyright (C) 2009-2014 Jay Freeman (saurik)
+dnl Copyright (C) 2009-2015 Jay Freeman (saurik)
dnl GNU Affero General Public License, Version 3 {{{
dnl
AC_PREREQ([2.65])
AC_INIT([Cycript], [0.9], [saurik@saurik.com], [cycript], [http://www.cycript.org/])
-AC_COPYRIGHT([Copyright (C) 2009-2014 Jay Freeman (saurik)])
+AC_COPYRIGHT([Copyright (C) 2009-2015 Jay Freeman (saurik)])
AC_CONFIG_SRCDIR([Console.cpp])
AC_CONFIG_AUX_DIR([.])
AS_IF([test "x$cy_good" = x1], ]$4[, ]$5[)
]) dnl }}}
+AC_ARG_VAR([LFLAGS], [flex flags])
+AS_IF([test "x$LFLAGS" = x], [LFLAGS="--full --ecs"])
+
AC_DEFUN([CY_TEST_FLAG_], [
AC_LANG_PUSH(]$2[)
AC_MSG_CHECKING([for ]]$4[[ ]]$1[)
CY_TEST_FLAG([-Wno-deprecated-declarations])
CY_TEST_FLAG([-Wno-dangling-else])
+CY_TEST_FLAG([-Wno-empty-body])
CY_TEST_FLAG([-Wno-overloaded-virtual])
CY_TEST_FLAG([-Wno-parentheses])
+CY_TEST_FLAG([-Wno-tautological-undefined-compare])
CY_TEST_FLAG([-Wno-unneeded-internal-declaration])
AX_PTHREAD
AC_SUBST(]$1[)
])
-dnl -arch * {{{
-for cy_arch in ppc ppc64 i386 x86_64 armv6 arm64; do
- AC_MSG_CHECKING([for -arch $cy_arch])
- CY_TRY([CXXFLAGS], ["-arch $cy_arch"], [
- AC_TRY_LINK([], [], [CY_SUCCESS], [CY_FAILURE])
- ], [
- AC_MSG_RESULT([yes])
- AC_LIB_APPENDTOVAR([CY_ARCH], ["-arch $cy_arch"])
- ], [AC_MSG_RESULT([no])])
-done
-AC_SUBST([CY_ARCH])
-dnl }}}
-
dnl --enable-javascript {{{
AC_DEFUN([CY_CHECK_JAVASCRIPTCORE], [
CY_LT_LIB([LTJAVASCRIPTCORE], [AC_SEARCH_LIBS([JSEvaluateScript], [JavaScriptCore], [
], [
AC_SUBST([CY_EXECUTE], [1])
], [
- for cy_webkit_pkg in "webkit-1.0" "WebKitGtk"; do
+ for cy_webkit_pkg in "javascriptcoregtk-4.0"; do
PKG_CHECK_MODULES([WEBKIT], [$cy_webkit_pkg], [
AC_SUBST([CY_EXECUTE], [1])
AC_LIB_APPENDTOVAR([CPPFLAGS], [`$PKG_CONFIG --cflags $cy_webkit_pkg`])
AC_ARG_ENABLE([console], AS_HELP_STRING([--disable-console], [disable console]))
AM_CONDITIONAL([CY_CONSOLE], [test "x$enable_console" != "xno"])
+AC_ARG_ENABLE([attach], AS_HELP_STRING([--disable-attach], [disable attach]))
+AM_CONDITIONAL([CY_ATTACH], [test "x$enable_attach" != "xno" -a "x$CY_EXECUTE" = x1])
+
AC_DEFUN([CY_CHECK_PKG_CONFIG_LIBFFI], [
PKG_CHECK_MODULES([LIBFFI], [libffi], [
AC_LIB_APPENDTOVAR([CPPFLAGS], [`$PKG_CONFIG --cflags libffi`])
AM_CONDITIONAL([CY_EXECUTE], [test "x$CY_EXECUTE" = x1])
AS_CASE([$CY_EXECUTE], [1], [
+ CY_LT_LIB([LTLIBUV], [AC_CHECK_HEADERS([uv.h], [
+ AC_SEARCH_LIBS([uv_loop_init], [uv])
+ ])])
+
AC_CHECK_HEADERS([ffi.h ffi/ffi.h], [break])
CY_LT_LIB([LTLIBFFI], AS_IF([test "x$ac_cv_header_ffi_h" = xno && test "x$ac_cv_header_ffi_ffi_h" = xno], [
AS_CASE([$ac_cv_search_ffi_call], [no], [CY_CHECK_PKG_CONFIG_LIBFFI])
]))
- AC_CHECK_HEADER([jni.h], [
+ AC_CHECK_FRAMEWORK([JavaVM], [
+ #include <JavaVM/jni.h>
+ ], [JNI_GetCreatedJavaVMs(NULL, 0, NULL);], [
+ AC_SUBST([CY_JAVA], [1])
+ ], [AC_CHECK_HEADER([jni.h], [
AC_SUBST([CY_JAVA], [1])
CY_LT_LIB([LTJAVA], [AC_SEARCH_LIBS([JNI_GetCreatedJavaVMs], [dvm], [
])])
], [
AC_SUBST([CY_JAVA], [0])
- ])
+ ])])
AC_LANG_PUSH([Objective C++])
AC_SUBST([LTFLAGS])
AC_SUBST([SO], [$acl_shlibext])
-AS_IF([test "x$CY_EXECUTE" = x1], [
- AC_CHECK_HEADER([mach/mach.h], [
- AC_CHECK_TOOLS([_LIPO], [lipo], [AC_MSG_ERROR([missing "lipo"])])
- AC_CHECK_TOOLS([_NM], [nm], [AC_MSG_ERROR([missing "nm"])])
- AC_CHECK_TOOLS([_OTOOL], [otool], [AC_MSG_ERROR([missing "otool"])])
- AC_SUBST([CY_ATTACH_GROUP], [procmod])
- AC_SUBST([CY_MACH], [1])])])
-AM_CONDITIONAL([CY_MACH], [test "x$CY_MACH" = x1])
-
AC_CONFIG_FILES([Makefile])
AC_OUTPUT