X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=install.sh;h=50c66b6beedca0786a73b6d2cae727a43cc7e5d8;hb=1b650be8b800cf96e2c268ae317fb26d0bf36827;hp=9a02a511dd2a49c72f26d61e7db9a9dee45aa6e8;hpb=98f3f617894ce24a40764aa98606ce68c5482cf0;p=sbcl.git diff --git a/install.sh b/install.sh index 9a02a51..50c66b6 100644 --- a/install.sh +++ b/install.sh @@ -19,15 +19,17 @@ if [ -n "$SBCL_HOME" -a "$INSTALL_ROOT/lib/sbcl" != "$SBCL_HOME" ];then exit 1 fi SBCL_HOME=$INSTALL_ROOT/lib/sbcl -export SBCL_HOME +export SBCL_HOME INSTALL_ROOT ensure_dirs $INSTALL_ROOT $INSTALL_ROOT/bin $INSTALL_ROOT/lib \ $INSTALL_ROOT/man $INSTALL_ROOT/man/man1 \ - $SBCL_HOME $SBCL_HOME/systems + $SBCL_HOME $SBCL_HOME/systems $SBCL_HOME/site-systems -test -e $INSTALL_ROOT/bin/sbcl && \ - cp $INSTALL_ROOT/bin/sbcl $INSTALL_ROOT/bin/sbcl.old -test -e $SBCL_HOME/sbcl.core && \ - cp $SBCL_HOME/sbcl.core $SBCL_HOME/sbcl.core.old +# move old versions out of the way. Safer than copying: don't want to +# break any running instances that have these files mapped +test -f $INSTALL_ROOT/bin/sbcl && \ + mv $INSTALL_ROOT/bin/sbcl $INSTALL_ROOT/bin/sbcl.old +test -f $SBCL_HOME/sbcl.core && \ + mv $SBCL_HOME/sbcl.core $SBCL_HOME/sbcl.core.old cp src/runtime/sbcl $INSTALL_ROOT/bin/ cp output/sbcl.core $SBCL_HOME/sbcl.core @@ -39,9 +41,12 @@ SBCL="`pwd`/src/runtime/sbcl --noinform --core `pwd`/output/sbcl.core --userinit SBCL_BUILDING_CONTRIB=1 export SBCL SBCL_BUILDING_CONTRIB -gnumake=$(GNUMAKE:-gmake} +. ./find-gnumake.sh +find_gnumake + for i in contrib/*; do - test -d $i || continue; - export INSTALL_DIR=$SBCL_HOME/`basename $i ` - $gnumake -C $i test && ensure_dirs $INSTALL_DIR && make -C $i install + test -d $i && test -f $i/test-passed || continue; + INSTALL_DIR=$SBCL_HOME/`basename $i ` + export INSTALL_DIR + ensure_dirs $INSTALL_DIR && $GNUMAKE -C $i install done