X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-target-contrib.sh;h=934fb9a74d4693ecac8980f45bf8ca89fd2ec36a;hb=d62443f0937aa0ab67a01dcbce31272a2a7425d1;hp=3e964494c1c49bd2dd8a18d71c1a1d23a10487e9;hpb=9f809e2e8abb84000f35c22a86def1d8085ed791;p=sbcl.git diff --git a/make-target-contrib.sh b/make-target-contrib.sh index 3e96449..934fb9a 100644 --- a/make-target-contrib.sh +++ b/make-target-contrib.sh @@ -14,6 +14,8 @@ set -e # provided with absolutely no warranty. See the COPYING and CREDITS # files for more information. +echo //entering make-target-contrib.sh + LANG=C LC_ALL=C export LANG LC_ALL @@ -21,20 +23,16 @@ export LANG LC_ALL . ./find-gnumake.sh find_gnumake -# usually SBCL_HOME refers to the installed root of SBCL, not the -# build directory. Right now, however, where there are dependencies -# between contrib packages, we want the _uninstalled_ versions to be -# found +. ./sbcl-pwd.sh +sbcl_pwd + +SBCL_HOME="$SBCL_PWD/contrib" +export SBCL_HOME if [ "$OSTYPE" = "cygwin" ] ; then - SBCL_BASE=`cygpath -m $(pwd)` -else - SBCL_BASE=`pwd` + SBCL_PWD=`echo $SBCL_PWD | sed s/\ /\\\\\\\\\ /g` fi -SBCL_HOME=$SBCL_BASE/contrib -export SBCL_HOME - -SBCL="$SBCL_BASE/src/runtime/sbcl --noinform --core $SBCL_BASE/output/sbcl.core --disable-debugger" +SBCL="$SBCL_PWD/src/runtime/sbcl --noinform --core $SBCL_PWD/output/sbcl.core --disable-debugger --no-sysinit --no-userinit" SBCL_BUILDING_CONTRIB=1 export SBCL SBCL_BUILDING_CONTRIB @@ -56,11 +54,18 @@ find contrib/ \( -name '*.fasl' -o \ -name '*.O' \) \ -print | xargs rm -f +find output -name 'building-contrib.*' -print | xargs rm -f + for i in contrib/*; do test -d $i && test -f $i/Makefile || continue; # export INSTALL_DIR=$SBCL_HOME/`basename $i ` test -f $i/test-passed && rm $i/test-passed - $GNUMAKE -C $i test && touch $i/test-passed + # hack to get exit codes right. + if $GNUMAKE -C $i test 2>&1 && touch $i/test-passed ; then + : + else + exit $? + fi | tee output/building-contrib.`basename $i` done # Sometimes people used to see the "No tests failed." output from the last @@ -72,9 +77,17 @@ do if $HEADER_HAS_BEEN_PRINTED; then echo > /dev/null else - echo "Failed contribs:" + cat <