X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-target-contrib.sh;h=6d10ca3d3561e46d5d394edb74f0e8c1718c323b;hb=aa8c8cd473f1d487fa2c1a7490c78a59b9955bbe;hp=8e818b575f5d75404f816900c53d2aa8c32cd23b;hpb=10d2c05ea44ca0837091434fe2223c0c31687615;p=sbcl.git diff --git a/make-target-contrib.sh b/make-target-contrib.sh index 8e818b5..6d10ca3 100644 --- a/make-target-contrib.sh +++ b/make-target-contrib.sh @@ -1,9 +1,9 @@ #!/bin/sh +set -e # This is a script to be run as part of make.sh. The only time you'd -# probably want to run it by itself is if you're trying to -# cross-compile the system or if you're doing some kind of -# troubleshooting. +# probably want to run it by itself is if you're cross-compiling the +# system or doing some kind of troubleshooting. # This software is part of the SBCL system. See the README file for # more information. @@ -14,11 +14,67 @@ # provided with absolutely no warranty. See the COPYING and CREDITS # files for more information. -SBCL="`pwd`/src/runtime/sbcl --noinform --core `pwd`/output/sbcl.core --userinit /dev/null --sysinit /dev/null --disable-debugger" +LANG=C +LC_ALL=C +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 +if [ "$OSTYPE" = "cygwin" ] ; then + SBCL_BASE=`cygpath -m $(pwd)` +else + SBCL_BASE=`pwd` +fi +SBCL_HOME=$SBCL_BASE/contrib +export SBCL_HOME + + +SBCL="$SBCL_BASE/src/runtime/sbcl --noinform --core $SBCL_BASE/output/sbcl.core --disable-debugger --no-sysinit --no-userinit" SBCL_BUILDING_CONTRIB=1 export SBCL SBCL_BUILDING_CONTRIB + +# deleting things here lets us not worry about interaction with stale +# fasls. This is not good, but is better than :FORCE on each asdf +# operation, because that causes multiple builds of base systems such +# as SB-RT and SB-GROVEL, but FIXME: there's probably a better +# solution. -- CSR, 2003-05-30 + +find contrib/ \( -name '*.fasl' -o \ + -name '*.FASL' -o \ + -name 'foo.c' -o \ + -name 'FOO.C' -o \ + -name 'a.out' -o \ + -name 'A.OUT' -o \ + -name 'alien.so' -o \ + -name 'ALIEN.SO' -o \ + -name '*.o' -o \ + -name '*.O' \) \ + -print | xargs rm -f + for i in contrib/*; do - test -d $i || continue; + test -d $i && test -f $i/Makefile || continue; # export INSTALL_DIR=$SBCL_HOME/`basename $i ` - make -C $i test + test -f $i/test-passed && rm $i/test-passed + $GNUMAKE -C $i test && touch $i/test-passed +done + +# Sometimes people used to see the "No tests failed." output from the last +# DEFTEST in contrib self-tests and think that's all that is. So... +HEADER_HAS_BEEN_PRINTED=false +for dir in contrib/* +do + if [ -d "$dir" -a -f "$dir/Makefile" -a ! -f "$dir/test-passed" ]; then + if $HEADER_HAS_BEEN_PRINTED; then + echo > /dev/null + else + echo "Failed contribs:" + HEADER_HAS_BEEN_PRINTED=true + fi + echo " `basename $dir`" + fi done