X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=configure.in;h=43a0006b6f106d938c66e17cd5b44abedbf6b3e2;hp=316ff5ae83bbfb7b6f5724666736955b6721b9f1;hb=336c03561cdacb388041cf9345c51a28465ee653;hpb=f31440f2736c7c8a247da7d66a678a8f5f9684ce diff --git a/configure.in b/configure.in index 316ff5ae..43a0006b 100644 --- a/configure.in +++ b/configure.in @@ -18,7 +18,7 @@ dnl autoconf sees "AC_MAJOR_VERSION" and complains about an undefined macro dnl (don't we all *love* M4?)... GINACLIB_MAJOR_VERSION=0 -GINACLIB_MINOR_VERSION=6 +GINACLIB_MINOR_VERSION=8 GINACLIB_MICRO_VERSION=0 GINACLIB_INTERFACE_AGE=0 GINACLIB_BINARY_AGE=0 @@ -62,7 +62,6 @@ AC_SUBST(LT_AGE) dnl This defines PACKAGE and VERSION. AM_CONFIG_HEADER(config.h) AM_INIT_AUTOMAKE([GiNaC], $GINACLIB_VERSION) -AM_MAINTAINER_MODE dnl Check for the compiler and all the utilities needed for the build. AC_PROG_CXX @@ -75,9 +74,9 @@ AC_PROG_YACC dnl Configure options. AC_ARG_ENABLE(html-doc, [ --enable-html-doc build HTML documentation [default=no]], , enable_html_doc=no) AC_ARG_ENABLE(ps-doc, [ --enable-ps-doc build PostScript documentation [default=no]], , enable_ps_doc=no) -AC_ARG_WITH(cint, [ --with-cint=CINTSYSDIR build GiNaC-cint C++ interpreter [default=no]], , with_cint=no) -dnl Check for data types which are needed by the hash function (golden_ratio_hash). +dnl Check for data types which are needed by the hash function +dnl (golden_ratio_hash). AC_CHECK_SIZEOF(long, 4) AC_CHECK_SIZEOF(long long, 8) AC_CHECK_SIZEOF(long double, 12) @@ -109,9 +108,13 @@ AC_CHECK_HEADERS(iostream vector map string list typeinfo iterator stdexcept alg AC_MSG_ERROR(need to have ANSI compliant headers)) AC_CHECK_HEADERS(sstream strstream) -dnl We need to have Bruno Haible's CLN installed (macros are in acinclude.m4): -GINAC_CHECK_CLN_H -GINAC_CHECK_LIBCLN +dnl We need to have Bruno Haible's CLN installed. +dnl (CLN versions >= 1.1.0 must have installed cln.m4 at a visible place, +dnl which provides this macro): +AC_PATH_CLN(1.1.0, [ + LIBS="$LIBS $CLN_LIBS" + CPPFLAGS="$CPPFLAGS $CLN_CPPFLAGS" +], GINAC_ERROR([No suitable installed version of CLN could be found.])) dnl Expand the cppflags and libraries needed by apps using GiNaC GINACLIB_CPPFLAGS=$CPPFLAGS @@ -147,34 +150,57 @@ AC_SUBST(TUTORIAL_TARGETS) AC_SUBST(REFERENCE_TARGETS) dnl Configure GiNaC-cint +AC_ARG_WITH(cint, [ --with-cint=CINTSYSDIR build GiNaC-cint C++ interpreter [default=no]], , with_cint=no) +dnl The variable GINACCINTDIR controls whether the subdirectory cint is entered +dnl from the top-level Makefile or not. GINACCINTDIR= if test "x$with_cint" != "xno"; then - if test "x$with_cint" = "xyes"; then - if test "x$CINTSYSDIR" = "x"; then - AC_MSG_ERROR([please export \$CINTSYSDIR or specify --with-cint=CINTSYSDIR]) - fi - else + dnl Maybe CINTSYSDIR was passed as an argument. In this case it should + dnl override any CINTSYSDIR variable already set. + if test "x$with_cint" != "xyes"; then CINTSYSDIR=$with_cint export CINTSYSDIR fi - AC_PATH_PROG(CINT, cint, "", $CINTSYSDIR:$PATH) - AC_PATH_PROG(MAKECINT, makecint, "", $CINTSYSDIR:$PATH) - if [[ "$CINT" -a "$MAKECINT" ]]; then - AC_MSG_RESULT([creating cint/Makefile]) - (cd cint && \ - $MAKECINT -mk Makefile.makecint -o ginaccint.bin -m \ - -D OBSCURE_CINT_HACK -cc "$CXXFLAGS" \ - -I .. -I $CINTSYSDIR -m -H ../ginac/ginac.h \ - -C++ ginaccint.bin.cpp \ - -l -L../ginac/.libs -lginac -lcln \ - -cint -M0x10; \ - cd ..) - GINACCINTDIR="cint" + dnl Now have to handle two possbile cases, one with CINTSYSDIR set and one + dnl without. In the first one we search for cint and makecint in CINTSYSDIR + dnl and PATH, in the second there is only the PATH to search in. + if test "x$CINTSYSDIR" != "x"; then + AC_PATH_PROG(CINT, cint, , $CINTSYSDIR:$PATH) + AC_PATH_PROG(MAKECINT, makecint, , $CINTSYSDIR:$PATH) + if [[ "$CINT" -a "$MAKECINT" ]]; then + AC_MSG_RESULT([creating cint/Makefile]) + (cd cint && \ + $MAKECINT -mk Makefile.makecint -o ginaccint.bin -m \ + -D OBSCURE_CINT_HACK "$CPPFLAGS" -cc "$CXXFLAGS" \ + -I .. -I $CINTSYSDIR -m -H ../ginac/ginac.h \ + -C++ ginaccint.bin.cpp \ + -l -L../ginac/.libs -lginac -lcln \ + -cint -M0x110; \ + cd ..) + GINACCINTDIR="cint" + AC_SUBST(CINTSYSDIR) + else + GINAC_WARNING([I could not find cint and makecint (needed for building GiNaC-cint).]) + fi else - AC_MSG_ERROR([Cannot configure GiNaC-cint]) + AC_PATH_PROG(CINT, cint) + AC_PATH_PROG(MAKECINT, makecint) + if [[ "$CINT" -a "$MAKECINT" ]]; then + AC_MSG_RESULT([creating cint/Makefile]) + (cd cint && \ + $MAKECINT -mk Makefile.makecint -o ginaccint.bin -m \ + -D OBSCURE_CINT_HACK "$CPPFLAGS" -cc "$CXXFLAGS" \ + -I .. -m -H ../ginac/ginac.h \ + -C++ ginaccint.bin.cpp \ + -l -L../ginac/.libs -lginac -lcln \ + -cint -M0x110; \ + cd ..) + GINACCINTDIR="cint" + else + GINAC_WARNING([I could not find cint and makecint (needed for building GiNaC-cint).]) + fi fi fi -AC_SUBST(CINTSYSDIR) AC_SUBST(GINACCINTDIR) dnl Output makefiles etc. @@ -182,16 +208,19 @@ AC_OUTPUT([ Makefile GiNaC.spec ginac-config +ginac-config.1 ginac/Makefile ginac/version.h check/Makefile ginsh/Makefile +ginsh/ginsh.1 tools/Makefile +tools/viewgar.1 doc/Makefile doc/tutorial/Makefile doc/reference/Makefile cint/Makefile -cint/ginaccint -], [chmod +x ginac-config cint/ginaccint]) +cint/launch.h +], [chmod +x ginac-config]) dnl Display a final warning if there has been a GINAC_ERROR or a GINAC_WARNING GINAC_CHECK_ERRORS