X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-target-contrib.sh;h=57ed2ebdc33170ea8f2c4200354182f73c0b6560;hb=HEAD;hp=9823d3708eac5fda0163ac59b9c4113d4069f436;hpb=b06500a7381d0d5a789034ab00e3f708e62805b1;p=sbcl.git diff --git a/make-target-contrib.sh b/make-target-contrib.sh index 9823d37..57ed2eb 100644 --- a/make-target-contrib.sh +++ b/make-target-contrib.sh @@ -14,21 +14,27 @@ 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 +CC=${CC:-gcc} +export CC LANG LC_ALL + +# Load our build configuration +. output/build-config -. ./find-gnumake.sh -find_gnumake +. ./sbcl-pwd.sh +sbcl_pwd -# 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 -export SBCL_HOME +SBCL_HOME="$SBCL_PWD/obj/sbcl-home" +export SBCL_HOME SBCL_PWD +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 @@ -37,38 +43,81 @@ export SBCL SBCL_BUILDING_CONTRIB # 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 +if [ -z "$DONT_CLEAN_SBCL_CONTRIB" ] ; then + find contrib/ obj/asdf-cache/ obj/sbcl-home/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 +fi + +find output -name 'building-contrib.*' -print | xargs rm -f + +# Ignore all source registries. +if [ -z "$*" ]; then + contribs_to_build="`cd contrib ; echo *`" +else + contribs_to_build="$*" +fi -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 && 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 +for i in $contribs_to_build; do + test -d contrib/$i && test -f contrib/$i/Makefile || continue; + test -f contrib/$i/test-passed && rm contrib/$i/test-passed # remove old convention + test -f obj/asdf-cache/$i/test-passed.test-report && rm obj/asdf-cache/$i/test-passed.test-report + mkdir -p obj/asdf-cache/$i/ + # hack to get exit codes right. + if $GNUMAKE -C contrib/$i test < /dev/null 2>&1 && touch obj/asdf-cache/$i/test-passed.test-report ; then + : + else + exit $? + fi | tee output/building-contrib.`basename $i` +done + +# Otherwise report expected failures: +HEADER_HAS_BEEN_PRINTED=false +for dir in `cd obj/asdf-cache/ ; echo *`; do + f="obj/asdf-cache/$dir/test-passed.test-report" + if test -f "$f" && grep -i fail "$f" >/dev/null; then + if ! $HEADER_HAS_BEEN_PRINTED; then + cat < /dev/null else - echo "Failed contribs:" + cat <