X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-target-contrib.sh;h=22fe7e59fc12805d68758d4d9687e9494eacb216;hb=e0aff99a73d836da0dad4602e5559595fbe5ba5c;hp=d541ea9d5cdc11259f5cbefa52940173bb82ea55;hpb=99501797db3d77ff2a7f32071d7fab0db3fdacae;p=sbcl.git diff --git a/make-target-contrib.sh b/make-target-contrib.sh index d541ea9..22fe7e5 100644 --- a/make-target-contrib.sh +++ b/make-target-contrib.sh @@ -1,4 +1,5 @@ #!/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 cross-compiling the @@ -13,14 +14,26 @@ # provided with absolutely no warranty. See the COPYING and CREDITS # files for more information. -# 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_HOME=`pwd`/contrib +echo //entering make-target-contrib.sh + +LANG=C +LC_ALL=C +export LANG LC_ALL + +# Load our build configuration +. output/build-config + +. ./sbcl-pwd.sh +sbcl_pwd + +SBCL_HOME="$SBCL_PWD/contrib" export SBCL_HOME +if [ "$OSTYPE" = "cygwin" ] ; then + SBCL_PWD=`echo $SBCL_PWD | sed s/\ /\\\\\\\\\ /g` +fi -SBCL="`pwd`/src/runtime/sbcl --noinform --core `pwd`/output/sbcl.core --userinit /dev/null --sysinit /dev/null --disable-debugger" +SBCL="$SBCL_PWD/src/runtime/sbcl --noinform --core $SBCL_PWD/output/sbcl.core \ +--lose-on-corruption --disable-debugger --no-sysinit --no-userinit" SBCL_BUILDING_CONTRIB=1 export SBCL SBCL_BUILDING_CONTRIB @@ -30,19 +43,64 @@ export SBCL SBCL_BUILDING_CONTRIB # 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' \) \ +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 -mkdir -p contrib/systems -rm -f contrib/systems/* +find output -name 'building-contrib.*' -print | xargs rm -f -for i in contrib/*/*.asd; do - ln -sf ../../$i contrib/systems/ -done +# Ignore all source registries. +CL_SOURCE_REGISTRY='(:source-registry :ignore-inherited-configuration)' +export CL_SOURCE_REGISTRY -for i in contrib/*; do +if [ -z "$*" ]; then + contribs_to_build=contrib/* +else + for name in $*; do + contribs_to_build="contrib/$name $contribs_to_build" + done +fi + +for i in $contribs_to_build; 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 + test -f $i/test-passed && rm $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 +# 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 + cat <