*** empty log message ***
[libfirm] / configure.in
index b7e75b8..05ae436 100644 (file)
@@ -20,8 +20,11 @@ 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/testprograms/Makefile libfirm.doxygen"
+               ir/ana/Makefile ir/tr/Makefile ir/ana2/Makefile ir/stat/Makefile \
+               ir/opt/Makefile ir/external/Makefile ir/config/Makefile \
+               testprograms/Makefile firmjni/Makefile firmjni/testprograms/Makefile \
+               ir/be/Makefile \
+               libfirm.doxygen"
 
 dnl generate the config header file
 AC_CONFIG_HEADER(config.h)
@@ -30,13 +33,16 @@ dnl keep track of the environment set by the user
 libfirm_conf_env="${CC+CC='$CC'} ${CFLAGS+CFLAGS='$CFLAGS'} ${CPP+CPP='$CPP'} ${CPPFLAGS+CPPFLAGS='$CPPFLAGS'} ${LDFLAGS+LDFLAGS='$LDFLAGS'} ${LIBS+LIBS='$LIBS'}"
 AC_SUBST(libfirm_conf_env)
 
+dnl where is the configure file
+CONF_DIR_NAME=`dirname $0`
+
 dnl check for additional include dirs
 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="")
+    CPPFLAGS=$CPPFLAGS" -I"`echo $withval|sed 's;\:; -I;g'`)
 
+dnl check for additional library dirs
 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="")
-
+    LDFLAGS=$LDFLAGS" -L"`echo $withval|sed 's;\:; -L;g'`)
 
 dnl Package options
 dnl ===============
@@ -52,13 +58,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 -------------
@@ -91,16 +99,62 @@ fi],
 [enable_firm_jni=no])
 AC_SUBST(enable_firm_jni)
 
+dnl set heap analyses support
+dnl -------------------------
+AC_MSG_CHECKING([for heapanalysis])
+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([disabled])
+else
+  AC_DEFINE(DO_HEAPANALYSIS)
+  AC_MSG_RESULT([enabled])
+fi
+AC_SUBST(enable_heapanalysis)
+
+dnl set backend support
+dnl -------------------------
+AC_ARG_ENABLE(backend, [  --enable-backend        Compile with backend facility.],
+[if test "$enableval" = "yes"; then
+  AC_DEFINE(FIRM_BACKEND)
+fi], [enable_backend="yes"])
+AC_SUBST(enable_backend)
+
 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 disable external effects in XML
+dnl -------------------------------
+AC_MSG_CHECKING([for using external effects in xml2])
+AC_ARG_ENABLE(external-effects,
+[  --disable-external-effects  disable descriptions of external effects in XML],
+[if test "$enableval"="no"; then
+  enable_external_effects=no
+fi],
+[enable_external_effects=yes])
+AC_SUBST(enable_external_effects)
+if test "$enable_external_effects" == no; then
+  AC_MSG_RESULT([disabled])
+else
+  AC_MSG_RESULT([enabled])
+fi
+dnl check for header and library below
 
 dnl Checks for programs.
 dnl ====================
@@ -139,8 +193,8 @@ 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"
+if eval "$INSTALL tmp-install.a tmp-install.b" ; then
+    INSTALL="$INSTALL"
 fi
 rm tmp-install.a tmp-install.b
 
@@ -230,6 +284,13 @@ if test "$enable_firm_jni" = yes; then
 fi
 
 
+if test "$enable_external_effects" == "yes"; then
+  AC_CHECK_HEADERS(libxml/parser.h, ac_xml_headers="yes", ac_xml_headers="no")
+  if test "$ac_xml_headers" != yes; then
+    AC_MSG_ERROR(xml header files not found. (IPD: add --with-includedir=/usr/public/libxml2/include/libxml2/ to configure flags))
+  fi
+fi
+
 dnl Checks for libraries.
 dnl =====================
 
@@ -249,8 +310,20 @@ if test "$ac_m_library" != yes; then
 fi
 
 
+if test "$enable_external_effects" == "yes"; then
+  AC_CHECK_LIB(xml2, xmlParseFile, ac_xml_library="yes", ac_xml_library="no")
+  if test "$ac_m_library" != yes; then
+    AC_MSG_ERROR("xml2 library not found (IPD: add --with-libdir=/usr/public/libxml2/lib/ to configure flags)")
+  else
+    LIBS=$LIBS" -lxml2"
+  fi
+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
 
@@ -269,3 +342,6 @@ dnl ===============
 
 
 AC_OUTPUT($ac_output_file,[ touch stamp-h ])
+
+dnl snip the lower prt of config.h and put it to ir/config/firm_config.h
+gawk -f $CONF_DIR_NAME/filter.awk < config.h | sed -f $CONF_DIR_NAME/filter.sed > ir/config/firm_config.h