X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=acinclude.m4;h=68f75b2f2519dfc035aab8f1963600c8c3ded000;hp=157d7b854fd096872900a477338df08c2b755aec;hb=0481215b4a7e4b6585033c98d52ce1e7e53fe954;hpb=ece5f57b53603bea68161c946d26d58bb6d39aca diff --git a/acinclude.m4 b/acinclude.m4 index 157d7b85..68f75b2f 100644 --- a/acinclude.m4 +++ b/acinclude.m4 @@ -4,6 +4,37 @@ dnl additions' names with AC_ but with GINAC_ in order to steer clear of dnl future trouble. dnl =========================================================================== +dnl Usage: GINAC_RLVERSION +dnl The maintainers of libreadline are complete morons: they don't care a shit +dnl about compatiblilty (which is not so bad by itself) and at the same time +dnl they don't export the version to the preprocessor so we could kluge around +dnl incomatiblities. The only reliable way to figure out the version is by +dnl checking the extern variable rl_library_version at runtime. &#@$%*! +AC_DEFUN(GINAC_RLVERSION, +[AC_CACHE_CHECK([for version of libreadline], ginac_cv_rlversion, [ +AC_TRY_RUN([ +#include +#include +#include + +main() +{ + FILE *fd; + fd = fopen("conftest.out", "w"); + fprintf(fd, "%s\n", rl_library_version); + fclose(fd); + exit(0); +}], ginac_cv_rlversion=`cat 'conftest.out'`, ginac_cv_rlversion='unknown', ginac_cv_rlversion='4.2') +if test "x${ginac_cv_rlversion}" != "xunknown"; then + RLVERSION_MAJOR=`echo ${ginac_cv_rlversion} | sed -e 's/\([[0-9]]\)\.\([[0-9]]\)/\1/'` + AC_DEFINE_UNQUOTED(GINAC_RLVERSION_MAJOR, $RLVERSION_MAJOR) + RLVERSION_MINOR=`echo ${ginac_cv_rlversion} | sed -e 's/\([[0-9]]\)\.\([[0-9]]\)/\2/'` + AC_DEFINE_UNQUOTED(GINAC_RLVERSION_MINOR, $RLVERSION_MINOR) +else + GINAC_WARNING([I could not run a test of libreadline (needed for building ginsh ginsh).]) +fi +])]) + dnl Usage: GINAC_TERMCAP dnl libreadline is based on the termcap functions. dnl Some systems have tgetent(), tgetnum(), tgetstr(), tgetflag(), tputs(),