-dnl autoconf; autoheader; automake
-
dnl Process this file with autoconf to produce a configure script.
-AC_INIT(cacao, 0.40, cacao@complang.tuwien.ac.at)
+
+AC_INIT(cacao, 0.91, cacao@cacaojvm.org)
AC_CONFIG_SRCDIR(src/cacao/cacao.c)
AC_CANONICAL_HOST
AC_PREREQ(2.59)
AC_PREFIX_DEFAULT(/usr/local/cacao)
-dnl system type
+dnl system type
case "$host_cpu" in
-alpha* )
+alpha )
ARCH_DIR="alpha"
STATIC_CLASSPATH="1"
CFLAGS="-mieee -D__ALPHA__"
- AC_DEFINE([TRACE_ARGS_NUM], 6, [Defines integer argument register count])
- AC_DEFINE([USE_CODEMMAP], 1, [use code mmap])
;;
-i386* | i486* | i586* | i686* )
+i386 | i486 | i586 | i686 )
ARCH_DIR="i386"
STATIC_CLASSPATH="0"
- CFLAGS="-D__I386__"
+ CFLAGS="-D__I386__ $CFLAGS"
;;
-mips* )
+mips )
ARCH_DIR="mips"
STATIC_CLASSPATH="1"
- CFLAGS="-64 -O2 -OPT:Olimit=0 -g -woff 1110,1164,1515 -D__MIPS__"
- LIBS="-lelfutil"
- AC_DEFINE([TRACE_ARGS_NUM], 8, [Defines integer argument register count])
+
+dnl for MIPSPro Compiler
+dnl CFLAGS="-64 -OPT:Olimit=0 -woff 1110,1164,1515 -D__MIPS__ -D__MIPSEB__"
+ CFLAGS="-64 -D__MIPS__ -D__MIPSEB__"
+
+dnl for GCC
+dnl CFLAGS="-mabi=64 -D__MIPS__ -D__MIPSEB__"
+dnl LDFLAGS="-mabi=64"
;;
-powerpc* | ppc* )
+powerpc | ppc )
ARCH_DIR="powerpc"
STATIC_CLASSPATH="1"
CFLAGS="-D__POWERPC__"
- AC_DEFINE([TRACE_ARGS_NUM], 8, [Defines integer argument register count])
;;
-x86_64* )
+x86_64 )
ARCH_DIR="x86_64"
- STATIC_CLASSPATH="1"
+ STATIC_CLASSPATH="0"
CFLAGS="-D__X86_64__"
;;
-sparc* | * )
+* )
AC_MSG_ERROR($host_cpu systems are not supported at this time)
;;
esac
+
+dnl set optimization and debugging for all architectures and systems
+CFLAGS="-O2 -g3 $CFLAGS"
+
+
case "$host_os" in
*linux* | *Linux* )
- CFLAGS="-ansi -pedantic -Wall -Wno-long-long -O0 -g3 $CFLAGS -D__LINUX__ -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__LINUX__ -D_POSIX_C_SOURCE=199506L -D_XOPEN_SOURCE=500 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE"
;;
*darwin* )
- CFLAGS="-ansi -pedantic -Wall -Wno-long-long -O0 -g3 $CFLAGS -D__DARWIN__"
+ CFLAGS="-ansi -pedantic -Wall -Wno-long-long $CFLAGS -D__DARWIN__"
;;
*irix* )
CFLAGS="$CFLAGS -D__IRIX__"
esac
+dnl define install prefix
+if test "x$prefix" = xNONE; then
+ INSTALL_PREFIX=$ac_default_prefix
+else
+ INSTALL_PREFIX=$prefix
+fi
+AC_DEFINE_UNQUOTED([INSTALL_PREFIX], "$INSTALL_PREFIX", [Installation prefix])
+AC_SUBST(INSTALL_PREFIX)
+
+
AC_DEFINE_UNQUOTED([ARCH_DIR], "$ARCH_DIR", [Architecture directory])
AC_SUBST(ARCH_DIR)
+
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 force static classpath linking ??
AC_MSG_CHECKING(Link classpath static)
AC_PROG_CC
AM_PROG_AS
AC_PROG_RANLIB
+AC_DISABLE_SHARED
+AC_PROG_LIBTOOL
+AC_PROG_LN_S
AC_PROG_MAKE_SET
dnl Checks for header files.
dnl no threads for boehm
ac_configure_args="$ac_configure_args --disable-boehm-threads"
AM_CONDITIONAL([USE_THREADS], [false])
+ AM_CONDITIONAL([NATIVE_THREADS], [false])
;;
green | native | posix | pthreads)
AC_MSG_CHECKING(whether zip archives should be supported)
if test x"$enable_zlib" = "xno"; then
AC_MSG_RESULT(no)
+ AM_CONDITIONAL([USE_ZLIB], [false])
else
- AC_DEFINE([USE_ZLIB], 1, [use zlib])
AC_MSG_RESULT(yes)
+ AC_DEFINE([USE_ZLIB], 1, [use zlib])
AC_CHECK_HEADERS([zlib.h])
AC_CHECK_LIB(z, main)
+ AM_CONDITIONAL([USE_ZLIB], [true])
fi
-AM_CONDITIONAL([USE_ZLIB], [test x"$enable_zlib" != "xno"])
-
-
-dnl set some essential classpath options, even if their classpath default is
-dnl suitable for us
-ac_configure_args="$ac_configure_args --enable-jni --disable-cni --disable-regen-headers --enable-static --enable-shared --enable-load-library"
dnl check arguments
AC_MSG_CHECKING(whether to use gtk awt peers)
if test x"$enable_gtk_peer" = "xyes"; then
AC_MSG_RESULT(yes)
- CACAO_GTK=yes
- AWTPEERS="java.awt.peer.ComponentPeer \
- java.awt.Graphics\
- java.awt.Window\
- java.awt.peer.MenuPeer \
- java.awt.peer.MenuItemPeer \
- gnu.java.awt.peer.gtk.GdkPixbufDecoder \
- gnu.java.awt.peer.gtk.GtkGenericPeer \
- gnu.java.awt.peer.gtk.GtkMenuBarPeer \
- gnu.java.awt.peer.gtk.GtkScrollPanePeer \
- gnu.java.awt.peer.gtk.GtkMenuPeer \
- gnu.java.awt.peer.gtk.GtkTextComponentPeer \
- gnu.java.awt.peer.gtk.GtkComponentPeer \
- gnu.java.awt.peer.gtk.GtkPopupMenuPeer \
- gnu.java.awt.peer.gtk.GtkCheckboxPeer \
- gnu.java.awt.peer.gtk.GtkCheckboxGroupPeer \
- gnu.java.awt.peer.gtk.GtkMenuItemPeer \
- gnu.java.awt.peer.gtk.GdkGraphics \
- gnu.java.awt.peer.gtk.GtkToolkit \
- gnu.java.awt.peer.gtk.GtkCanvasPeer \
- gnu.java.awt.peer.gtk.GtkFramePeer \
- gnu.java.awt.peer.gtk.GdkFontMetrics \
- gnu.java.awt.peer.gtk.GtkScrollbarPeer \
- gnu.java.awt.peer.gtk.GtkListPeer \
- gnu.java.awt.peer.gtk.GtkLabelPeer \
- gnu.java.awt.peer.gtk.GtkTextAreaPeer \
- gnu.java.awt.peer.gtk.GtkFileDialogPeer \
- gnu.java.awt.peer.gtk.GtkImagePainter \
- gnu.java.awt.peer.gtk.GtkChoicePeer \
- gnu.java.awt.peer.gtk.GtkPanelPeer \
- gnu.java.awt.peer.gtk.GtkMainThread \
- gnu.java.awt.peer.gtk.GtkButtonPeer \
- gnu.java.awt.peer.gtk.GtkTextFieldPeer \
- gnu.java.awt.peer.gtk.GtkCheckboxMenuItemPeer \
- gnu.java.awt.peer.gtk.GtkClipboard \
- gnu.java.awt.peer.gtk.GtkWindowPeer"
- AWT_OBJS="classpath/native/jni/gtk-peer/.libs/libgtkpeer.a \
- -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgdk_pixbuf-2.0 -lm -lpangoxft-1.0 \
- -lpangox-1.0 -lpango-1.0 -lgobject-2.0 -lgmodule-2.0 -ldl -lglib-2.0 \
- -lgthread-2.0 -lart_lgpl_2"
- USEGTK="yes"
- AC_SUBST(USEGTK)
- AC_SUBST(AWTPEERS)
- AC_SUBST(AWT_OBJS)
- AC_DEFINE([USE_GTK], 1, [use gtk])
+ AC_DEFINE([USE_GTK], 1, [use gtk])
+ AM_CONDITIONAL([USE_GTK_PEER], [true])
else
- CACAO_GTK=no
- AWT_OBJS=""
- AWTPEERS=""
- USEGTK="no"
- AC_SUBST(USEGTK)
- AC_SUBST(AWTPEERS)
- AC_SUBST(AWT_OBJS)
AC_MSG_RESULT(no)
-
- ac_configure_args="$ac_configure_args --disable-gtk-peer"
+ ac_configure_args="$ac_configure_args --disable-gtk-peer"
+ AM_CONDITIONAL([USE_GTK_PEER], [false])
fi
fi
+dnl set some essential classpath options, even if their classpath default is
+dnl suitable for us
+ac_configure_args="$ac_configure_args --enable-jni --disable-cni --disable-regen-headers --enable-static --enable-shared --enable-load-library"
+
+
dnl now configure boehm gc and gnu classpath
dnl the export is not my favorite (is there another way?)
export CFLAGS
-export CACAO_GTK
AC_CONFIG_SUBDIRS(src/boehm-gc src/classpath)
AC_OUTPUT(Makefile \
doc/Makefile \
+ doc/handbook/Makefile \
+ man/Makefile \
src/Makefile \
src/cacao/Makefile \
src/cacaoh/Makefile \
src/vm/jit/x86_64/Makefile \
tests/Makefile \
tests/jvm98/Makefile \
- tests/kaffe/Makefile )
+ tests/kaffe/Makefile \
+ tests/native/Makefile )
## Local variables: