Fix cpp-from-stdin detection so that it works even if the
compiler silently accepts an empty command line. Don't bother searching for bison and yacc unless we are going to use them.
This commit is contained in:
parent
ae7e19c586
commit
c719a82683
@ -355,36 +355,40 @@ echo "- setting LDFLAGS=$LDFLAGS"
|
|||||||
dnl Checks for programs.
|
dnl Checks for programs.
|
||||||
AC_PROG_CPP
|
AC_PROG_CPP
|
||||||
|
|
||||||
dnl Check to see what flags are required to get stdin into cpp
|
dnl Check to see what flags are required to get stdin into cpp.
|
||||||
|
dnl Note that we need to look at the output, since the C compiler might
|
||||||
|
dnl not raise an error when no input files are named on the cmd line.
|
||||||
|
dnl (This is a somewhat modified version of AC_EGREP_CPP)
|
||||||
|
dnl AC_TRY_CPPSTDIN(PATTERN, PROGRAM, [ACTION-IF-FOUND [,
|
||||||
|
dnl ACTION-IF-NOT-FOUND]])
|
||||||
AC_DEFUN(AC_TRY_CPPSTDIN,
|
AC_DEFUN(AC_TRY_CPPSTDIN,
|
||||||
[AC_REQUIRE_CPP()dnl
|
[AC_REQUIRE_CPP()dnl
|
||||||
cat > conftest.$ac_ext <<EOF
|
cat > conftest.$ac_ext <<EOF
|
||||||
[#]line __oline__ "configure"
|
[#]line __oline__ "configure"
|
||||||
#include "confdefs.h"
|
#include "confdefs.h"
|
||||||
[$1]
|
[$2]
|
||||||
EOF
|
EOF
|
||||||
ac_try="$ac_cpp $CPPSTDIN <conftest.$ac_ext >/dev/null 2>conftest.out"
|
dnl eval is necessary to expand ac_cpp.
|
||||||
AC_TRY_EVAL(ac_try)
|
dnl Ultrix and Pyramid sh refuse to redirect output of eval, so use subshell.
|
||||||
ac_err=`grep -v '^ *+' conftest.out`
|
if (eval "$ac_cpp $CPPSTDIN <conftest.$ac_ext") 2>&AC_FD_CC |
|
||||||
if test -z "$ac_err"; then
|
grep "$1" >/dev/null 2>&1; then
|
||||||
ifelse([$2], , :, [rm -rf conftest*
|
ifelse([$3], , :, [rm -rf conftest*
|
||||||
$2])
|
$3])
|
||||||
else
|
ifelse([$4], , , [else
|
||||||
echo "$ac_err" >&AC_FD_CC
|
rm -rf conftest*
|
||||||
echo "configure: failed program was:" >&AC_FD_CC
|
$4
|
||||||
cat conftest.$ac_ext >&AC_FD_CC
|
|
||||||
ifelse([$3], , , [ rm -rf conftest*
|
|
||||||
$3
|
|
||||||
])dnl
|
])dnl
|
||||||
fi
|
fi
|
||||||
rm -f conftest*])
|
rm -f conftest*
|
||||||
|
])
|
||||||
|
|
||||||
AC_MSG_CHECKING(how to use cpp with stdin)
|
AC_MSG_CHECKING(how to use cpp with stdin)
|
||||||
if test -z "$CPPSTDIN"; then
|
if test -z "$CPPSTDIN"; then
|
||||||
AC_CACHE_VAL(ac_cv_cpp_stdin,
|
AC_CACHE_VAL(ac_cv_cpp_stdin,
|
||||||
[ CPPSTDIN=""
|
[ CPPSTDIN="-"
|
||||||
AC_TRY_CPPSTDIN([#include <assert.h>
|
AC_TRY_CPPSTDIN([^Find Me Or Else],
|
||||||
Syntax Error], , CPPSTDIN="-")
|
[#include <assert.h>
|
||||||
|
Find Me Or Else], , CPPSTDIN="")
|
||||||
ac_cv_cpp_stdin="$CPPSTDIN"])
|
ac_cv_cpp_stdin="$CPPSTDIN"])
|
||||||
CPPSTDIN="$ac_cv_cpp_stdin"
|
CPPSTDIN="$ac_cv_cpp_stdin"
|
||||||
else
|
else
|
||||||
@ -510,24 +514,24 @@ dnl (1) We specify in YACC and YFLAGS what we want
|
|||||||
dnl (2) We have bison and we use bison -y
|
dnl (2) We have bison and we use bison -y
|
||||||
dnl (3) We have yacc and use it
|
dnl (3) We have yacc and use it
|
||||||
|
|
||||||
AC_SUBST(YACC)
|
|
||||||
AC_SUBST(YFLAGS)
|
|
||||||
AC_PATH_PROG(yacc, yacc)
|
|
||||||
AC_PATH_PROG(bison, bison)
|
|
||||||
if test -f "$YACC"
|
if test -f "$YACC"
|
||||||
then
|
then
|
||||||
echo "- Using $YACC $YFLAGS"
|
echo "- Using $YACC $YFLAGS"
|
||||||
elif test -f "$bison"
|
else
|
||||||
then
|
AC_PATH_PROG(bison, bison)
|
||||||
|
if test -f "$bison"
|
||||||
|
then
|
||||||
echo "- Using $bison -y $YFLAGS"
|
echo "- Using $bison -y $YFLAGS"
|
||||||
YACC="$bison"
|
YACC="$bison"
|
||||||
YFLAGS="-y $YFLAGS"
|
YFLAGS="-y $YFLAGS"
|
||||||
export YACC YFLAGS
|
else
|
||||||
else
|
AC_PATH_PROG(yacc, yacc)
|
||||||
echo "- Using $yacc $YFLAGS"
|
echo "- Using $yacc $YFLAGS"
|
||||||
YACC="$yacc"
|
YACC="$yacc"
|
||||||
export YACC
|
fi
|
||||||
fi
|
fi
|
||||||
|
AC_SUBST(YACC)
|
||||||
|
AC_SUBST(YFLAGS)
|
||||||
|
|
||||||
AC_CHECK_LIB(sfio, main)
|
AC_CHECK_LIB(sfio, main)
|
||||||
for curses in ncurses curses ; do
|
for curses in ncurses curses ; do
|
||||||
|
Loading…
Reference in New Issue
Block a user