##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
m4_define([v_maj], [1])
-m4_define([v_min], [1])
-m4_define([v_mic], [0])
-m4_define([v_rev], m4_esyscmd([(svnversion "${SVN_REPO_PATH:-.}" | grep -v export || echo 0) | awk -F : '{printf("%s\n", $1);}' | tr -d ' :MSP\n']))
+m4_define([v_min], [2])
+m4_define([v_mic], [99])
+m4_define([v_rev], m4_esyscmd([(svnversion "${SVN_REPO_PATH:-.}" | grep -v '\(export\|Unversioned directory\)' || echo 0) | awk -F : '{printf("%s\n", $1);}' | tr -d ' :MSP\n']))
m4_if(v_rev, [0], [m4_define([v_rev], m4_esyscmd([git log 2> /dev/null | (grep -m1 git-svn-id || echo 0) | sed -e 's/.*@\([0-9]*\).*/\1/' | tr -d '\n']))])
##-- When released, remove the dnl on the below line
-m4_undefine([v_rev])
+dnl m4_undefine([v_rev])
##-- When doing snapshots - change soname. remove dnl on below line
dnl m4_define([relname], [ver-pre-svn-07])
dnl m4_define([v_rel], [-release relname])
EFL_CHECK_CPU_SSE2([have_sse2="yes"], [have_sse2="no"])
EFL_CHECK_CPU_ALTIVEC([have_altivec="yes"], [have_altivec="no"])
-EFL_CHECK_THREADS(
- [
- if test "x${_efl_have_posix_threads}" = "xyes" ; then
- have_threads="POSIX"
- else
- if test "x${_efl_have_win32_threads}" = "xyes" ; then
- have_threads="Win32"
- else
- have_threads="no"
- fi
- fi
- ],
- [have_threads="no"])
-EFL_CHECK_SPINLOCK([have_posix_threads_spinlock="yes"], [have_posix_threads_spinlock="no"])
+EFL_CHECK_THREADS
-if ! test "x${have_threads}" = "xno" ; then
+if ! test "x${efl_have_threads}" = "xno" ; then
EINA_CONFIGURE_HAVE_THREADS="#define EINA_HAVE_THREADS"
fi
AC_SUBST(EINA_CONFIGURE_HAVE_THREADS)
-AM_CONDITIONAL([EINA_HAVE_THREADS], [! test "x${have_threads}" = "xno"])
+AM_CONDITIONAL([EINA_HAVE_THREADS], [! test "x${efl_have_threads}" = "xno"])
-if ! test "x${have_debug_threads}" = "xno"; then
+if test "x${efl_have_debug_threads}" = "xyes"; then
EINA_CONFIGURE_HAVE_DEBUG_THREADS="#define EINA_HAVE_DEBUG_THREADS"
fi
AC_SUBST(EINA_CONFIGURE_HAVE_DEBUG_THREADS)
-AM_CONDITIONAL([EINA_DEBUG_THREADS], [! test "x${have_debug_threads}" = "xno"])
+AM_CONDITIONAL([EINA_DEBUG_THREADS], [test "x${efl_have_debug_threads}" = "xyes"])
-if ! test "x${have_on_off_threads}" = "xno"; then
+if ! test "x${efl_have_on_off_threads}" = "xno"; then
EINA_CONFIGURE_HAVE_ON_OFF_THREADS="#define EINA_HAVE_ON_OFF_THREADS"
fi
AC_SUBST(EINA_CONFIGURE_HAVE_ON_OFF_THREADS)
-AM_CONDITIONAL([EINA_ON_OFF_THREADS], [! test "x${have_on_off_threads}" = "xno"])
+AM_CONDITIONAL([EINA_ON_OFF_THREADS], [! test "x${efl_have_on_off_threads}" = "xno"])
### Additional options to configure
### Checks for programs
AC_PROG_CC
+#for src/tests...
AC_PROG_CXX
# pkg-config
fi
-# Evil library for compilation on Windows CE
+# Evil library for compilation on Windows
EFL_EINA_BUILD=""
case "$host_os" in
mingw*)
PKG_CHECK_MODULES([EVIL], [evil >= 1.0.0])
AC_DEFINE([HAVE_EVIL], [1], [Set to 1 if evil package is installed])
- requirement_eina="evil"
+ requirement_eina="${requirement_eina} evil"
EFL_EINA_BUILD="-DEFL_EINA_BUILD"
;;
esac
AC_SUBST([EFL_EINA_BUILD])
+# Checks for portability layer
+
+PKG_CHECK_MODULES([EXOTIC],
+ [exotic],
+ [enable_exotic="yes"],
+ [enable_exotic="no"])
+
+if test "x${enable_exotic}" = "xyes"; then
+ requirement_eina="exotic ${requirement_eina}"
+ EINA_CFLAGS="${EINA_CFLAGS} ${EXOTIC_CFLAGS}"
+ EINA_LIBS="${EXOTIC_LIBS}"
+
+ EINA_CONFIGURE_HAVE_EXOTIC="#define EINA_HAVE_EXOTIC"
+ AC_DEFINE([HAVE_EXOTIC_H], [1], [Define to 1 if you have Exotic.])
+fi
+AM_CONDITIONAL([EINA_HAVE_EXOTIC], [test "x${enable_exotic}" = "xyes"])
+AC_SUBST([EINA_CONFIGURE_HAVE_EXOTIC])
+
+case "$host_vendor" in
+ ps3*)
+ PKG_CHECK_MODULES([ESCAPE], [escape])
+ AC_DEFINE(HAVE_ESCAPE, 1, [Set to 1 if Escape package is installed])
+ requirement_eina="${requirement_eina} escape"
+ EINA_CFLAGS="${ESCAPE_CFLAGS} ${EINA_CFLAGS}"
+ ;;
+esac
+
+AC_SUBST([EINA_CFLAGS])
+
# Check ememoa memory pool library
AC_ARG_ENABLE([ememoa],
AM_CONDITIONAL([BUILD_TILER_EXAMPLE], [test "x${build_tiler_example}" = "xyes"])
-
### Checks for header files
AC_HEADER_ASSERT
-AC_HEADER_DIRENT
AC_HEADER_TIME
-EFL_CHECK_PATH_MAX
-AC_CHECK_HEADERS([unistd.h libgen.h inttypes.h stdint.h sys/types.h siginfo.h])
+AC_HEADER_DIRENT
+
+AC_CHECK_HEADERS([unistd.h libgen.h inttypes.h stdint.h sys/types.h siginfo.h strings.h sys/mman.h execinfo.h mcheck.h])
if test "x${ac_cv_header_inttypes_h}" = "xyes" ; then
EINA_CONFIGURE_HAVE_INTTYPES_H="#define EINA_HAVE_INTTYPES_H"
### Checks for types
+# wchar_t
+
AC_CHECK_SIZEOF([wchar_t])
EINA_SIZEOF_WCHAR_T=$ac_cv_sizeof_wchar_t
AC_SUBST([EINA_SIZEOF_WCHAR_T])
AC_CHECK_TYPES([siginfo_t], [], [],
- [[#include <signal.h>
- #if HAVE_SIGINFO_H
- # include <siginfo.h>
- #endif
+ [[
+#include <signal.h>
+#if HAVE_SIGINFO_H
+# include <siginfo.h>
+#endif
]])
-### Checks for structures
+# struct dirent
+
+AC_CHECK_TYPES([struct dirent], [have_dirent="yes"], [have_dirent="no"],
+ [[
+#include <dirent.h>
+ ]])
+if test "x${have_dirent}" = "xyes" ; then
+ EINA_CONFIGURE_HAVE_DIRENT_H="#define EINA_HAVE_DIRENT_H"
+ AC_DEFINE([HAVE_DIRENT_H], [1], [Define to 1 if you have a valid <dirent.h> header file.])
+fi
+AC_SUBST([EINA_CONFIGURE_HAVE_DIRENT_H])
+
+### Checks for structures
### Checks for compiler characteristics
-AC_C_CONST
AC_C_BIGENDIAN
AC_C_INLINE
AC_PROG_CC_STDC
have_wince="no"
have_win32="no"
-EINA_CPPFLAGS=""
-EINA_CFLAGS=""
case "$host_os" in
mingw32ce*)
- EINA_CPPFLAGS="-D_WIN32_WCE=0x0420"
EINA_CFLAGS="${EVIL_CFLAGS}"
have_win32="yes"
have_wince="yes"
;;
mingw*)
- EINA_CPPFLAGS="-D_WIN32_WINNT=0x0501"
EINA_CFLAGS="${EVIL_CFLAGS}"
have_win32="yes"
;;
EFL_COMPILER_FLAG([-Wshadow])
-AC_SUBST([EINA_CPPFLAGS])
-AC_SUBST([EINA_CFLAGS])
-
+EFL_CHECK_PATH_MAX
### Checks for linker characteristics
EINA_LIBS=
lt_enable_auto_import=""
case "${host_os}" in
mingw*)
- EINA_LIBS="-ldl ${EVIL_LIBS} -lm"
+ EINA_LIBS="${EINA_LIBS} ${EVIL_LIBS}"
lt_enable_auto_import="-Wl,--enable-auto-import"
;;
- dragonfly*|openbsd*)
- EINA_LIBS="-lm"
- ;;
- freebsd*|netbsd*)
- EINA_LIBS="-lrt -lm"
- ;;
- darwin*)
- EINA_LIBS="-lm"
- ;;
- cygwin*)
- EINA_LIBS="-ldl -lm"
- ;;
- *)
- EINA_LIBS="-ldl -lrt -lm"
- ;;
esac
-AC_SUBST([EINA_LIBS])
-AC_SUBST([lt_enable_auto_import])
-
case "$host_vendor" in
ps3*)
- PKG_CHECK_MODULES([ESCAPE], [escape])
- AC_DEFINE(HAVE_ESCAPE, 1, [Set to 1 if evil package is installed])
- requirement_eina="escape"
+ # Escape had already been checked to exist
EINA_LIBS="${ESCAPE_LIBS}"
- EINA_CFLAGS="${ESCAPE_CFLAGS} ${EINA_CFLAGS}"
;;
esac
+AC_SUBST([EINA_LIBS])
+AC_SUBST([lt_enable_auto_import])
EFL_LINKER_FLAG([-fno-strict-aliasing])
-
### Checks for library functions
-AC_ISC_POSIX
AC_FUNC_ALLOCA
-AC_CHECK_FUNCS([strlcpy dirfd openat fstatat fpathconf execvp])
+AC_CHECK_FUNCS([strlcpy openat fstatat fpathconf execvp backtrace backtrace_symbols malloc_usable_size mtrace])
+
+AC_MSG_CHECKING([for dirfd])
+AC_LINK_IFELSE(
+ [
+ AC_LANG_PROGRAM(
+ [[
+#ifdef HAVE_DIRENT_H
+# include <dirent.h>
+#endif
+ ]],
+ [[
+int main(void)
+{
+ DIR *dirp;
+ return dirfd(dirp);
+}
+ ]])
+ ],
+ [have_dirfd="yes"],
+ [have_dirfd="no"])
+
+AC_MSG_RESULT([${have_dirfd}])
+
+if test "x${have_dirfd}" = "xyes" ; then
+ AC_DEFINE([HAVE_DIRFD], [1], [ Define to 1 if you have the `dirfd' function or macro.])
+fi
+
+want_debug_malloc="no"
+AC_ARG_ENABLE([debug-malloc],
+ [AC_HELP_STRING([--enable-debug-malloc], [enable debugging of malloc usage overhead in our allocator @<:@default=enabled@:>@])],
+ [
+ if test "x${enableval}" = "xyes" ; then
+ want_debug_malloc="yes"
+ else
+ want_debug_malloc="no"
+ fi
+ ], [want_debug_malloc="no"])
+
+if test "x${ac_cv_func_malloc_usable_size}" = "xyes" && test "x${want_debug_malloc}" = "xyes"; then
+ AC_DEFINE([EINA_DEBUG_MALLOC], [1], [Turn on debugging overhead in mempool])
+fi
# dlopen and dladdr
-dlopen_libs=""
-case "$host_os" in
- mingw*)
-# managed by evil
- AC_DEFINE([HAVE_DLADDR])
- AC_DEFINE([HAVE_DLOPEN])
- ;;
- *)
- AC_CHECK_FUNCS([dlopen], [res="yes"], [res="no"])
- if test "x${res}" = "xyes" ; then
- AC_CHECK_FUNCS([dladdr], [AC_DEFINE([HAVE_DLADDR])])
- AC_DEFINE([HAVE_DLOPEN])
- else
- AC_CHECK_LIB([dl], [dlopen], [res="yes"], [res="no"])
- if test "x${res}" = "xyes" ; then
- AC_CHECK_LIB([dl], [dladdr], [AC_DEFINE([HAVE_DLADDR])])
- AC_DEFINE(HAVE_DLOPEN)
- dlopen_libs="-ldl"
- fi
- fi
- ;;
-esac
-AC_SUBST([dlopen_libs])
+EFL_CHECK_DLOPEN
+EFL_CHECK_DLADDR
+
+have_log="yes"
+EFL_CHECK_FNMATCH([have_log="yes"], [have_log="no"])
-EFL_CHECK_FNMATCH([], [AC_MSG_ERROR([Cannot find fnmatch()])])
+want_log="yes"
+AC_ARG_ENABLE([log],
+ [AC_HELP_STRING([--disable-log], [disable Eina_Log infrastructure completly @<:@default=enabled@:>@])],
+ [
+ if test "x${enableval}" = "xyes" ; then
+ want_log="yes"
+ else
+ want_log="no"
+ fi
+ ],
+ [want_log="yes"])
+
+enable_log="no"
+if test "x${have_log}" = xyes -a "x${want_log}" = xyes; then
+ enable_log="yes"
+fi
+
+AC_MSG_CHECKING([wether to build Eina_Log infrastructure])
+AC_MSG_RESULT([${enable_log}])
+
+if test "x${enable_log}" = "xyes"; then
+ EINA_CONFIGURE_ENABLE_LOG="#define EINA_ENABLE_LOG"
+ AC_DEFINE([HAVE_LOG], [1], [Define to 1 if we log support is on])
+fi
+AC_SUBST([EINA_CONFIGURE_ENABLE_LOG])
-AC_CHECK_HEADERS([mcheck.h], [AC_DEFINE([HAVE_MCHECK], [1], [Have mcheck.h])])
-AC_CHECK_FUNCS([mtrace], [AC_DEFINE([HAVE_MTRACE], [1], [Have mtrace])])
# iconv library
have_iconv="no"
AC_DEFINE([HAVE_ICONV], [1], [Set to 1 if iconv library is installed])
fi
-# shmopen
-have_shmopen=no
-AC_MSG_CHECKING([for shm_open availability])
-
-LIBS_save="${LIBS}"
-LIBS="${LIBS} -lrt"
-AC_LINK_IFELSE(
- [AC_LANG_PROGRAM(
- [[
-#include <sys/mman.h>
-#include <sys/stat.h> /* For mode constants */
-#include <fcntl.h> /* For O_* constants */
- ]],
- [[
-int fd;
-
-fd = shm_open("/dev/null", O_RDONLY, S_IRWXU | S_IRWXG | S_IRWXO);
- ]])],
- [have_shmopen="yes"],
- [have_shmopen="no"])
-
-LIBS="${LIBS_save}"
-
-AC_MSG_RESULT([${have_shmopen}])
-
-if test "x${have_shmopen}" = "xyes"; then
- AC_DEFINE([HAVE_SHMOPEN], [1], [Define to 1 if you have the `shm_open' function.])
- rt_libs="-lrt"
-fi
-
-AC_SUBST([rt_libs])
+# shm_open
+EFL_CHECK_SHM_OPEN([have_shm_open="yes"], [have_shm_open="no"])
# extended attribute
fi
AM_CONDITIONAL([CITYHASH_BENCH], [test -n "$CXX" && test "x$enable_benchmark" = "xyes"])
-AC_SUBST(requirement_eina)
+AC_SUBST([requirement_eina])
### Build and install examples
EFL_CHECK_BUILD_EXAMPLES([enable_build_examples="yes"], [enable_build_examples="no"])
echo " Report string usage..: ${have_stringshare_usage}"
echo " Valgrind support.....: ${have_valgrind}"
echo " Default mempool......: ${have_default_mempool}"
-echo " Thread Support.......: ${have_threads}"
-if test "${have_threads}" = "POSIX" ; then
-echo " spinlock...........: ${have_posix_threads_spinlock}"
-echo " debug usage........: ${have_debug_threads}"
-echo " on/off support.....: ${have_on_off_threads}"
+echo " Log support..........: ${enable_log}"
+echo " Thread Support.......: ${efl_have_threads}"
+if test "${efl_have_threads}" = "POSIX" ; then
+echo " spinlock...........: ${efl_have_posix_threads_spinlock}"
+echo " debug usage........: ${efl_have_debug_threads}"
+echo " on/off support.....: ${efl_have_on_off_threads}"
fi
echo " Amalgamation.........: ${do_amalgamation}"
echo " Iconv support........: ${have_iconv}"
-echo " File dirfd...........: ${ac_cv_func_dirfd}"
+echo " File dirfd...........: ${have_dirfd}"
echo " File xattr...........: ${have_xattr}"
+echo " shm_open.............: ${have_shm_open}"
echo
echo " Documentation........: ${build_doc}"
echo " Tests................: ${enable_tests}"