renamed init_reflect
[libfirm] / configure.in
index af6b976..cae51fa 100644 (file)
@@ -20,8 +20,10 @@ 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 ir/stat/Makefile \
+               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
@@ -31,13 +33,21 @@ 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 check for libxml2 library installation dir
+AC_ARG_WITH(libxml2, [  --with-libxml2=installation prefix of libxml2 (IPD: --with-libxml2=/usr/public/libxml2)],
+    LDFLAGS=$LDFLAGS" -L"$withval"/lib";
+       CPPFLAGS=$CPPFLAGS" -I"$withval"/include/libxml2")
 
 dnl Package options
 dnl ===============
@@ -53,13 +63,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 -------------
@@ -92,6 +104,27 @@ 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,
@@ -102,6 +135,16 @@ fi],
 [disable_libiberty=no])
 AC_SUBST(disable_libiberty)
 
+dnl enable Firm hooks
+dnl -------------
+AC_ARG_ENABLE(hooks,
+[  --disable-hooks         disable Firm hooks],
+[if test "$enableval" = yes; then
+  AC_DEFINE(FIRM_ENABLE_HOOKS)
+fi],
+AC_DEFINE(FIRM_ENABLE_HOOKS)
+)
+
 dnl enable Firm statistics
 dnl -------------
 AC_ARG_ENABLE(statistics,
@@ -111,6 +154,32 @@ AC_ARG_ENABLE(statistics,
 fi])
 AC_SUBST(enable_statistics)
 
+dnl enable libcore debugging support
+dnl --------------------------------
+AC_ARG_ENABLE(libcore,
+[  --enable-libcore        enable libcore debugging],
+[if test "$enableval"=yes; then
+  AC_DEFINE(WITH_LIBCORE)
+fi])
+AC_SUBST(enable_libcore)
+
+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 ====================
 
@@ -148,8 +217,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
 
@@ -239,6 +308,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 =====================
 
@@ -258,8 +334,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
 
@@ -278,3 +366,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