X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=autogen.sh;h=b9b81f6d76441307c0a87eacefd64e33a0539079;hb=e54ae72e5fac6f750c3f7972c74bb42b57f3a049;hp=e07b3560e1be086e080d2744b28ab703a894853a;hpb=13f58fa6ae4d3110207aaab49b522806dd865071;p=lyx.git diff --git a/autogen.sh b/autogen.sh index e07b3560e1..b9b81f6d76 100755 --- a/autogen.sh +++ b/autogen.sh @@ -1,108 +1,122 @@ #!/bin/sh -ACLOCAL=aclocal -AUTOHEADER=autoheader -AUTOMAKE="automake -a -c --foreign" -AUTOCONF=autoconf -GNUM4= +ACLOCAL="aclocal -I m4 -I config" +AUTOHEADER="autoheader" +AUTOMAKE="automake --add-missing --copy --foreign" +AUTOCONF="autoconf" + +# Discover what version of automake we are using. +automake_version=`$AUTOMAKE --version 2>/dev/null | head -n 1` + +test "$automake_version" != "" && { + echo "Using $automake_version" +} || { + echo "LyX requires automake >= 1.5" + exit 1 +} + +case $automake_version in + *' '1.[5-9]*|*' '1.10*) + ;; + *) + + echo "This automake version is not supported by LyX." + echo "LyX only supports automake 1.5 to 1.10." + exit 1 + ;; +esac + +# Discover what version of autoconf we are using. +autoversion=`$AUTOCONF --version 2>/dev/null | head -n 1` + +test "$autoversion" != "" && { + echo "Using $autoversion" +} || { + echo "LyX requires autoconf >= 2.52" + exit 1 +} + +case $autoversion in + *' '2.5[2-9]|*' '2.60[ab]|*' '2.6[0-1]) + ;; + *) + echo "This autoconf version is not supported by LyX." + echo "LyX only supports autoconf 2.52-2.61." + exit 1 + ;; +esac echo -n "Locating GNU m4... " -for prog in $M4 gm4 gnum4 m4 ; do - case `$prog --version 2>&1` in - *GNU*) ok=yes - GNUM4=$prog - echo "found: $GNUM4" - break ;; - *) ;; - esac +GNUM4= +for prog in $M4 gm4 gnum4 m4; do + # continue if $prog generates error (e.g. does not exist) + ( $prog --version ) < /dev/null > /dev/null 2>&1 + if test $? -ne 0 ; then continue; fi + + # /dev/null input prevents a hang of the script for some m4 compilers (e.g. on FreeBSD) + case `$prog --version < /dev/null 2>&1` in + *GNU*) GNUM4=$prog + break ;; + esac done -if test x$ok = xno ; then - echo "not found." +if test x$GNUM4 = x ; then + echo "not found." + exit 1 +else + echo `which $GNUM4` fi -# Generate acinclude.m4 -echo -n "Generate acinclude.m4... " -rm -f acinclude.m4 sigc++/acinclude.m4 boost/acinclude.m4 -touch acinclude.m4 -for fil in config/lyxinclude.m4 config/libtool.m4 config/gettext.m4 config/lcmessage.m4 config/progtest.m4 config/sigc++.m4 config/kde.m4 config/qt2.m4 config/gtk--.m4 config/gnome--.m4 config/gnome.m4 config/pspell.m4; do - cat $fil >> acinclude.m4 -done -touch sigc++/acinclude.m4 -for fil in config/libtool.m4 ; do - cat $fil >> sigc++/acinclude.m4 -done -touch boost/acinclude.m4 -for fil in config/boost.m4 config/libtool.m4 ; do - cat $fil >> boost/acinclude.m4 -done -echo "done." +# Delete old cache directories. +# automake will stop if their contents was created by an earlier version. +rm -rf autom4te.cache # Generate the Makefiles and configure files -if ( aclocal --version ) /dev/null 2>&1; then +if ( $ACLOCAL --version ) < /dev/null > /dev/null 2>&1; then echo "Building macros..." - for dir in . lib/reLyX sigc++ boost ; do + for dir in . ; do echo " $dir" ( cd $dir ; $ACLOCAL ) done -# $ACLOCAL ; ( cd lib/reLyX; $ACLOCAL ) ; ( cd sigc++; $ACLOCAL ) -# ( cd boost; $ACLOCAL ) echo "done." else echo "aclocal not found -- aborting" - exit + exit 1 fi -if ( autoheader --version ) /dev/null 2>&1; then +if ( $AUTOHEADER --version ) < /dev/null > /dev/null 2>&1; then echo "Building config header template..." - for dir in . sigc++ boost ; do + for dir in . ; do echo " $dir" ( cd $dir ; $AUTOHEADER ) done -# $AUTOHEADER ; ( cd sigc++; $AUTOHEADER ) ; ( cd boost; $AUTOHEADER ) echo "done." else echo "autoheader not found -- aborting" - exit + exit 1 fi -if ( $AUTOMAKE --version ) /dev/null 2>&1; then +if ( $AUTOMAKE --version ) < /dev/null > /dev/null 2>&1; then echo "Building Makefile templates..." - for dir in . lib/reLyX sigc++ boost ; do + for dir in . ; do echo " $dir" ( cd $dir ; $AUTOMAKE ) done -# $AUTOMAKE ; ( cd lib/reLyX ; $AUTOMAKE ) ; ( cd sigc++; $AUTOMAKE ) -# ( cd boost; $AUTOMAKE ) echo "done." else echo "automake not found -- aborting" - exit + exit 1 fi -if ( $AUTOCONF --version ) /dev/null 2>&1; then +if ( $AUTOCONF --version ) < /dev/null > /dev/null 2>&1; then echo "Building configure..." - for dir in . lib/reLyX sigc++ boost ; do + for dir in . ; do echo " $dir" ( cd $dir ; $AUTOCONF ) done -# $AUTOCONF ; ( cd lib/reLyX ; $AUTOCONF ) ; ( cd sigc++; $AUTOCONF ) -# ( cd boost; $AUTOCONF ) echo "done." else echo "autoconf not found -- aborting" - exit -fi - -# Autogenerate lib/configure.m4. -if test x$GNUM4 != x ; then - echo -n "Building lib/configure ... " - rm -f lib/configure - $GNUM4 lib/configure.m4 > lib/configure - chmod a+x lib/configure - echo "done." -else - echo "No GNU m4. Impossible to build lib/configure -- aborting" - exit + exit 1 fi echo