X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=configure.in;h=6680f5b43029445d4893e5d1293bfe23ad4ba985;hb=4b76022c2d15da980982500340da6887007bd9b7;hp=89bed7d0837c5ceab4c5d6db58cb05f657246a80;hpb=01c7bd301f09cfd622cb7fea87acbf3b9e4ee8f9;p=libfirm diff --git a/configure.in b/configure.in index 89bed7d08..6680f5b43 100644 --- a/configure.in +++ b/configure.in @@ -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,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 =============== @@ -52,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 ------------- @@ -91,16 +104,72 @@ 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 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, +[ --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 +208,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 @@ -211,11 +280,11 @@ fi AC_CHECK_HEADERS(alloca.h, ac_alloca_headers="yes", ac_alloca_headers="no") -if test "$ac_alloca_headers" != yes; then - if test "$ac_cv_header_stdc" == no; then - AC_MSG_ERROR("alloca.h and stdlib.h not found") - else +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 @@ -230,6 +299,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 +325,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 +357,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