* AC_C_ATTRIBUTE: check for __attribute__ (required at least by mipspro)
[cacao.git] / configure.in
index 6e9fd976a470e98e54ef484ae6a243432c5878e0..6a6f3af2f2b391a5a8c8ab59a6507b093e1a4947 100644 (file)
@@ -14,31 +14,29 @@ AC_PREFIX_DEFAULT(/usr/local/cacao)
 
 dnl system type
 case "$host_cpu" in
-alpha | alphaev56 )
+alpha | alphaev56 | alphapca56 )
        ARCH_DIR="alpha"
-        STATIC_CLASSPATH="1"
        CFLAGS="-mieee -D__ALPHA__"
        ;;
 
 arm )
        ARCH_DIR="arm"
-       STATIC_CLASSPATH="1"
+       ENABLE_STATICVM="1"
        CFLAGS="-D__ARM__"
        ;;
 
 i386 | i486 | i586 | i686 )
        ARCH_DIR="i386"
-        STATIC_CLASSPATH="0"
        CFLAGS="-D__I386__ $CFLAGS"
        ;;
 
 mips )
        ARCH_DIR="mips"
-        STATIC_CLASSPATH="1"
 
 dnl for MIPSPro Compiler
 dnl    CFLAGS="-64 -OPT:Olimit=0 -woff 1110,1164,1515 -D__MIPS__ -D__MIPSEB__"
        CFLAGS="-64 -OPT:Olimit=0 -D__MIPS__ -D__MIPSEB__"
+dnl    CFLAGS="-D__MIPS__ -D__MIPSEB__"
 
 dnl for GCC
 dnl    CFLAGS="-mabi=64 -D__MIPS__ -D__MIPSEB__"
@@ -47,19 +45,17 @@ dnl LDFLAGS="-mabi=64"
 
 powerpc )
        ARCH_DIR="powerpc"
-        STATIC_CLASSPATH="1"
        CFLAGS="-D__POWERPC__"
        ;;
 
 x86_64 )
        ARCH_DIR="x86_64"
-        STATIC_CLASSPATH="0"
        CFLAGS="-D__X86_64__"
        ;;
 
 xdspcore )
        ARCH_DIR="xdspcore"
-       STATIC_CLASSPATH="1"
+       ENABLE_STATICVM="1"
        CFLAGS="-D__XDSPCORE__"
        USE_SCHEDULER="1"
        ;;
@@ -84,7 +80,7 @@ case "$host_os" in
         ;;
 *freebsd* )
        OS_DIR="freebsd"
-       CFLAGS="-ansi -pedantic -Wall -Wno-long-long $CFLAGS -D__FREEBSD__ -D_POSIX_C_SOURCE=199506L -D_XOPEN_SOURCE=500 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE"
+       CFLAGS="-ansi -pedantic -Wall -Wno-long-long $CFLAGS -D__FREEBSD__ -D_XOPEN_SOURCE_EXTENDED"
        ;;
 *irix* )
        OS_DIR="irix"
@@ -102,19 +98,11 @@ AC_SUBST(OS_DIR)
 AC_SUBST(USE_SCHEDULER)
 
 
-dnl define install prefix
-if test "x$prefix" = xNONE; then
-       CACAO_INSTALL_PREFIX=$ac_default_prefix
-else
-       CACAO_INSTALL_PREFIX=$prefix
-fi
-AC_DEFINE_UNQUOTED([CACAO_INSTALL_PREFIX], "${CACAO_INSTALL_PREFIX}", [Installation prefix])
-AC_SUBST(CACAO_INSTALL_PREFIX)
-
-
 dnl Checks for programs.
 AC_PROG_CC
 AM_PROG_AS
+AC_PROG_LD
+AC_PROG_LD_GNU
 AC_PROG_RANLIB
 AC_DISABLE_SHARED
 AC_PROG_LN_S
@@ -137,6 +125,7 @@ AC_CHECK_HEADERS([sys/ioctl.h])
 dnl Checks for typedefs, structures, and compiler characteristics.
 AC_C_CONST
 AC_C_INLINE
+AC_C_ATTRIBUTE
 AC_TYPE_OFF_T
 AC_TYPE_SIZE_T
 AC_HEADER_TIME
@@ -150,7 +139,6 @@ AC_TYPE_SIGNAL
 AC_CHECK_FUNCS(getcwd gettimeofday mkdir mktime select socket)
 
 dnl Checks for libraries.
-AC_CHECK_LIB(m, fmod)
 
 dnl Checking sizeof void *
 AC_COMPILE_CHECK_SIZEOF(void *)
@@ -202,22 +190,51 @@ if test $ac_cv_func_mmap_fixed_mapped = yes; then
 fi
 
 
+dnl check which ld flags are required to export symbols
+if test x"$with_gnu_ld" = "xyes"; then
+       EXPORT_SYMBOLS_FLAGS="-Wl,--export-dynamic"
+else
+       EXPORT_SYMBOLS_FLAGS=""
+fi
+AC_SUBST(EXPORT_SYMBOLS_FLAGS)
+
+
+dnl define install prefix
+if test "x$prefix" = "xNONE"; then
+       CACAO_INSTALL_PREFIX=$ac_default_prefix
+else
+       CACAO_INSTALL_PREFIX=$prefix
+fi
+AC_DEFINE_UNQUOTED([CACAO_INSTALL_PREFIX], "${CACAO_INSTALL_PREFIX}", [Installation prefix])
+AC_SUBST(CACAO_INSTALL_PREFIX)
+
+
 dnl Features
 
 dnl check arguments
 
-dnl check for garbage collector
-AC_ARG_ENABLE([gc], [AS_HELP_STRING(--disable-gc,disable garbage collector [[default=yes]])])
+dnl check for garbage collector usage
+AC_ARG_ENABLE([gc], [AS_HELP_STRING(--disable-gc,disable garbage collector (for debugging only!) [[default=yes]])])
 
-AC_MSG_CHECKING(whether GC should be disabled)
-if test x"$disable_gc" = "xyes"; then
-       AC_MSG_RESULT(yes)
+AC_MSG_CHECKING(whether GC should be used)
+if test x"$enable_gc" = "xno"; then
+       AC_MSG_RESULT(no)
        AM_CONDITIONAL([DISABLE_GC], [true])
 else
-       AC_MSG_RESULT(no)
+       AC_MSG_RESULT(yes)
        AM_CONDITIONAL([DISABLE_GC], [false])
 fi
 
+dnl check for dump memory usage
+AC_ARG_ENABLE([gc], [AS_HELP_STRING(--disable-dump,disable dump memory (for debugging only!) [[default=yes]])])
+
+AC_MSG_CHECKING(whether dump memory should be used)
+if test x"$enable_dump" = "xno"; then
+       AC_MSG_RESULT(no)
+       AC_DEFINE([DISABLE_DUMP], 1, [disable dump memory])
+else
+       AC_MSG_RESULT(yes)
+fi
 
 dnl check for statistics
 AC_ARG_ENABLE([statistics], [AS_HELP_STRING(--disable-statistics,disable statistics generation [[default=yes]])])
@@ -364,46 +381,46 @@ else
 fi
 
 
-dnl check if classpath should be linked statically with CACAO
-AC_ARG_ENABLE([dynamicclasspath], [AS_HELP_STRING(--disable-dynamicclasspath, link classpath native code static even on platforms supporting dynamic loading)], [use_dynamicclasspath=$enableval], [use_dynamicclasspath=yes])
+dnl check if CACAO should be linked statically
+AC_ARG_ENABLE([staticvm], [AS_HELP_STRING(--enable-staticvm, link GNU classpath's native libraries statically into CACAO [[default=no]])])
 
-AC_MSG_CHECKING(whether to link GNU classpath statically)
-if test x"$use_dynamicclasspath" = "xno"; then
-       STATIC_CLASSPATH="1"
+AC_MSG_CHECKING(whether to link GNU classpath statically into CACAO)
+if test x"$enable_staticvm" = "xyes"; then
+       ENABLE_STATICVM="1"
 fi
 
-if test x"${STATIC_CLASSPATH}" = "x1"; then
+if test x"${ENABLE_STATICVM}" = "x1"; then
        AC_MSG_RESULT(yes)
-       AM_CONDITIONAL([STATIC_CLASSPATH], [true])
+       AM_CONDITIONAL([ENABLE_STATICVM], [true])
 else
        AC_MSG_RESULT(no)
-       AM_CONDITIONAL([STATIC_CLASSPATH], [false])
+       AM_CONDITIONAL([ENABLE_STATICVM], [false])
 fi
-AC_SUBST(STATIC_CLASSPATH)
+AC_SUBST(ENABLE_STATICVM)
 
 
-dnl enable gtk peer
-AC_ARG_ENABLE([gtk-peer], [AS_HELP_STRING(--enable-gtk-peer,compile GTK native peers [[default=no]])])
+dnl check if we build gtk peers
+AC_ARG_ENABLE([gtk-peer], [AS_HELP_STRING(--disable-gtk-peer,compile GTK native peers [[default=yes]])])
 
-AC_MSG_CHECKING(whether to use GTK awt peers)
-if test x"$enable_gtk_peer" = "xyes"; then
-       AC_MSG_RESULT(yes)
-       AC_DEFINE([USE_GTK], 1, [use gtk])
-       AM_CONDITIONAL([USE_GTK_PEER], [true])
-       USE_GTK_PEER=yes
-else
+AC_MSG_CHECKING(whether to compile GTK awt peers)
+if test x"$enable_gtk_peer" = "xno"; then
        AC_MSG_RESULT(no)
        AM_CONDITIONAL([USE_GTK_PEER], [false])
        CONFIGURE_ARGS="${CONFIGURE_ARGS} --disable-gtk-peer"
        USE_GTK_PEER=no
+else
+       AC_MSG_RESULT(yes)
+       AC_DEFINE([USE_GTK], 1, [use gtk])
+       AM_CONDITIONAL([USE_GTK_PEER], [true])
+       USE_GTK_PEER=yes
 fi
 AC_SUBST(USE_GTK_PEER)
 
 
 dnl pass configure options to classpath
-if test x"${STATIC_CLASSPATH}" = "x1"; then
-        AC_DEFINE([STATIC_CLASSPATH], 1, [use classpath statically linked])
-       AM_CONDITIONAL([STATIC_CLASSPATH], [true])
+if test x"${ENABLE_STATICVM}" = "x1"; then
+        AC_DEFINE([ENABLE_STATICVM], 1, [link CACAO statically])
+       AM_CONDITIONAL([ENABLE_STATICVM], [true])
        CONFIGURE_ARGS="${CONFIGURE_ARGS} --enable-static --disable-shared"
 
        dnl check for some classpath related stuff when we link statically
@@ -431,7 +448,7 @@ if test x"${STATIC_CLASSPATH}" = "x1"; then
                AC_SUBST(PANGOFT2_CFLAGS)
        fi
 else
-       AM_CONDITIONAL([STATIC_CLASSPATH], [false])
+       AM_CONDITIONAL([ENABLE_STATICVM], [false])
        CONFIGURE_ARGS="${CONFIGURE_ARGS} --disable-static --enable-shared"
 fi
 
@@ -468,6 +485,7 @@ AC_CONFIG_SUBDIRS(src/boehm-gc src/classpath src/libltdl)
 
 
 AC_CONFIG_FILES([Makefile]
+               [contrib/Makefile]
                [doc/Makefile]
                [doc/handbook/Makefile]
                [man/Makefile]
@@ -483,8 +501,8 @@ AC_CONFIG_FILES([Makefile]
                [src/scripts/Makefile]
                [src/scripts/cacao]
                [src/scripts/java]
+               [src/scripts/javac]
                [src/scripts/kjc]
-               [src/scripts/rmic]
                [src/scripts/rmiregistry]
                [src/threads/Makefile]
                [src/threads/green/Makefile]
@@ -509,7 +527,6 @@ AC_CONFIG_FILES([Makefile]
                [src/vm/jit/x86_64/Makefile]
                [tests/Makefile]
                [tests/codepatching/Makefile]
-               [tests/kaffe/Makefile]
                [tests/native/Makefile])
 
 AC_OUTPUT