X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-target-contrib.sh;h=af56892abc257eda009792c967ffc23b1b22ca62;hb=40e3ba03d0e1b824e4d1ae75d74246b975b70964;hp=98526b3729fb7f378a1a116e233876a439295a04;hpb=df679ed627975948b1cee190f4d79c397588c43e;p=sbcl.git diff --git a/make-target-contrib.sh b/make-target-contrib.sh index 98526b3..af56892 100644 --- a/make-target-contrib.sh +++ b/make-target-contrib.sh @@ -13,6 +13,12 @@ # provided with absolutely no warranty. See the COPYING and CREDITS # files for more information. +LANG=C +export LANG + +. ./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 @@ -24,6 +30,15 @@ SBCL="`pwd`/src/runtime/sbcl --noinform --core `pwd`/output/sbcl.core --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 'foo.c' -o -name 'a.out' -o -name 'alien.so' -o -name '*.o' \) \ + -print | xargs rm -f + mkdir -p contrib/systems rm -f contrib/systems/* @@ -37,3 +52,19 @@ for i in contrib/*; do 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