Added RTA --flo
[libfirm] / configure.in
index 48eac14..9363246 100644 (file)
@@ -1,19 +1,29 @@
-dnl Process this file withautoconf to produce a configure script.
-dnl Copyright (c) 2001 IPD, Universität Karlsruhe (TH)
+dnl
+dnl Project:     libFIRM
+dnl File name:   configure.in
+dnl Purpose:
+dnl Author:      Till Riedel (??)
+dnl Modified by:
+dnl Created:
+dnl CVS-ID:      $Id$
+dnl Copyright:   (c) 2002-2003 Universität Karlsruhe
+dnl Licence:     This file protected by GPL -  GNU GENERAL PUBLIC LICENSE.
+dnl
 
-dnl libFIRM Project
-dnl $Id$
 
 AC_REVISION($Id$)
 
 
+
 AC_INIT(libfirm,0.3.0)
 AC_PREREQ(2.50)
 dnl if other files should be generated just add them to ac_output_files
 ac_output_file="Makefile MakeRules ir/Makefile ir/adt/Makefile ir/debug/Makefile \
                ir/tv/Makefile ir/common/Makefile ir/ident/Makefile ir/ir/Makefile \
-               ir/ana/Makefile ir/tr/Makefile ir/st/Makefile testprograms/Makefile \
-               firmjni/Makefile firmjni/build_firm_jni firmjni/testprograms/Makefile"
+               ir/ana/Makefile ir/tr/Makefile ir/st/Makefile ir/stat/Makefile \
+               ir/opt/Makefile \
+               testprograms/Makefile firmjni/Makefile firmjni/testprograms/Makefile \
+               libfirm.doxygen"
 
 dnl generate the config header file
 AC_CONFIG_HEADER(config.h)
@@ -23,8 +33,11 @@ libfirm_conf_env="${CC+CC='$CC'} ${CFLAGS+CFLAGS='$CFLAGS'} ${CPP+CPP='$CPP'} ${
 AC_SUBST(libfirm_conf_env)
 
 dnl check for additional include dirs
-AC_ARG_WITH(includedir, [  --with-includedir=dir add directory to include search path],
-    CPPFLAGS=$CPPFLAGS" -I"$withval, T_FLAG="")
+AC_ARG_WITH(includedir, [  --with-includedir=add colon seperated list of directories to include search path],
+    CPPFLAGS=$CPPFLAGS" -I"`echo $withval|sed 's;\:; -I;g'`, T_FLAG="")
+
+AC_ARG_WITH(libdir, [  --with-libdir=add colon seperated list of directories to linker search path],
+    LDFLAGS=$LDFLAGS" -L"`echo $withval|sed 's;\:; -L;g'`, T_FLAG="")
 
 dnl Package options
 dnl ===============
@@ -40,13 +53,15 @@ else
 fi])
 AC_SUBST(enable_debug_libfirm)
 
-AC_ARG_ENABLE(gcc_inline,
-[  --enable-gcc_inline     enable gcc inline C-extension],
+dnl disable inlining
+dnl ----------------
+AC_ARG_ENABLE(inlining,
+[  --disable-inlining      disable inline C-extension],
 [if test "$enableval" = yes; then
-  AC_DEFINE(USE_GCC_INLINE)
-fi])
-AC_SUBST(enable_gcc_inline)
-
+  AC_DEFINE(USE_INLINING)
+fi],
+AC_DEFINE(USE_INLINING)
+)
 
 dnl set profiling
 dnl -------------
@@ -79,16 +94,36 @@ fi],
 [enable_firm_jni=no])
 AC_SUBST(enable_firm_jni)
 
+dnl set heap analyses support
+dnl -------------------------
+AC_ARG_ENABLE(heapanalysis, [  --enable-heapanalysis       Compile with heap analysis.],
+        [enable_heapanalysis=$enableval], [enable_heapanalysis="no"])
+if test "$enable_heapanalysis" = "no"; then
+  AC_MSG_RESULT([heapanalysis disabled])
+else
+  AC_DEFINE(DO_HEAPANALYSIS)
+  AC_MSG_RESULT([heapanalysis enabled])
+fi
+AC_SUBST(enable_heapanalysis)
+
 dnl disable linking of libiberty parts (xmalloc, xprintf, obstack, ...)
 dnl ----------------------
 AC_ARG_ENABLE(libiberty,
-[  --disable-libiberty        disable own libiberty parts],
+[  --disable-libiberty     disable own libiberty parts],
 [if test "$enableval"=yes; then
   disable_libiberty_=yes
 fi],
 [disable_libiberty=no])
 AC_SUBST(disable_libiberty)
 
+dnl enable Firm statistics
+dnl -------------
+AC_ARG_ENABLE(statistics,
+[  --enable-statistics     enable Firm statistics],
+[if test "$enableval"=yes; then
+  AC_DEFINE(FIRM_STATISTICS)
+fi])
+AC_SUBST(enable_statistics)
 
 dnl Checks for programs.
 dnl ====================
@@ -126,6 +161,13 @@ AC_PROG_RANLIB
 
 AC_PROG_INSTALL
 
+touch tmp-install.a tmp-install.b
+if eval "$INSTALL -C tmp-install.a tmp-install.b" ; then
+    INSTALL="$INSTALL -C"
+fi
+rm tmp-install.a tmp-install.b
+
+
 AC_PROG_LN_S
 
 dnl check for doxygen if enabled
@@ -179,11 +221,25 @@ fi
 
 
 dnl check for the obstack header file
+dnl does not work with:
+dnl  - cygwin
+dnl  - MacOSX
+#AC_FUNC_OBSTACK
 
 AC_CHECK_HEADERS(obstack.h, ac_obstack_headers="yes", ac_obstack_headers="no")
 if test "$ac_obstack_headers" != yes; then
   dnl obstack header not found.
-  AC_MSG_ERROR("obstack header file not found")
+  AC_MSG_ERROR("obstack.h not found")
+fi
+
+
+AC_CHECK_HEADERS(alloca.h, ac_alloca_headers="yes", ac_alloca_headers="no")
+if test "$ac_alloca_headers" = "yes"; then
+    AC_DEFINE(HAVE_ALLOCA_H)
+else
+  if test "$ac_cv_header_stdc" = "no"; then
+    AC_MSG_ERROR("alloca.h and stdlib.h not found")
+  fi
 fi
 
 
@@ -192,7 +248,7 @@ dnl check for jni header files
 if test "$enable_firm_jni" = yes; then
   AC_CHECK_HEADERS(jni.h, ac_jni_headers="yes", ac_jni_headers="no")
   if test "$ac_jni_headers" != yes; then
-    AC_MSG_ERROR(jni header file not found. (IPD: add -I/usr/public2/java/jdk1.3.1-sun/include/ -I/usr/public2/java/jdk1.3.1-sun/include/linux/ to CPPFLAGS))
+    AC_MSG_ERROR(jni header file not found. (IPD: add --with-includedir=/usr/public2/java/jdk1.3.1-sun/include/:/usr/public2/java/jdk1.3.1-sun/include/linux/ to configure flags))
   fi
 fi
 
@@ -218,7 +274,11 @@ fi
 
 dnl Checks for typedefs, structures, and compiler characteristics.
 dnl ==============================================================
-
+AC_C_CONST
+AC_C_VOLATILE
+AC_C_INLINE
+AC_C_BIGENDIAN(,,,)
+AC_C_LONG_DOUBLE
 
 dnl Checks for library functions.
 dnl =============================