X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=install.sh;h=5ee1c74627e183f18af8c41e2f41097fecd62bbd;hb=HEAD;hp=d14ddc1e31a1c8ae654ed8bb2670b5bb068766d0;hpb=cec71f1e4e1ead387f2ea642f760e553b6053f2b;p=sbcl.git diff --git a/install.sh b/install.sh index d14ddc1..5ee1c74 100644 --- a/install.sh +++ b/install.sh @@ -1,16 +1,31 @@ #!/bin/sh +set -e # Install SBCL files into the usual places. -ensure_dirs () +ensure_dirs () { - for j in $*; do - test -d $j || mkdir $j + for j in "$@"; do + test -d "$j" || mkdir -p "$j" done; } -INSTALL_ROOT=${INSTALL_ROOT-/usr/local} -SBCL_SOURCE=`pwd` +. output/prefix.def +DEFAULT_INSTALL_ROOT=$SBCL_PREFIX + +if [ "$OSTYPE" = "cygwin" -o "$OSTYPE" = "msys" ] ; then + RUNTIME=sbcl.exe + OLD_RUNTIME=sbcl.exe.old +else + RUNTIME=sbcl + OLD_RUNTIME=sbcl.old +fi +INSTALL_ROOT=${INSTALL_ROOT-$DEFAULT_INSTALL_ROOT} +MAN_DIR=${MAN_DIR-"$INSTALL_ROOT"/share/man} +INFO_DIR=${INFO_DIR-"$INSTALL_ROOT"/share/info} +DOC_DIR=${DOC_DIR-"$INSTALL_ROOT"/share/doc/sbcl} + +# Does the environment look sane? if [ -n "$SBCL_HOME" -a "$INSTALL_ROOT/lib/sbcl" != "$SBCL_HOME" ];then echo SBCL_HOME environment variable is set, and conflicts with INSTALL_ROOT. echo Aborting installation. Unset one or reset the other, then try again @@ -18,30 +33,119 @@ if [ -n "$SBCL_HOME" -a "$INSTALL_ROOT/lib/sbcl" != "$SBCL_HOME" ];then echo SBCL_HOME="$SBCL_HOME" exit 1 fi -SBCL_HOME=$INSTALL_ROOT/lib/sbcl -export SBCL_HOME -ensure_dirs $INSTALL_ROOT $INSTALL_ROOT/bin $INSTALL_ROOT/lib \ - $INSTALL_ROOT/man $INSTALL_ROOT/man/man1 \ - $SBCL_HOME $SBCL_HOME/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 +# Before doing anything else, make sure we have an SBCL to install +if [ -f src/runtime/$RUNTIME ]; then + if [ -f output/sbcl.core ]; then + true + else + echo "output/sbcl.core not found, aborting installation." + exit 1 + fi +else + echo "src/runtime/$RUNTIME not found, aborting installation." + exit 1 +fi + +SBCL_HOME="$INSTALL_ROOT"/lib/sbcl +export SBCL_HOME INSTALL_ROOT +ensure_dirs "$BUILD_ROOT$INSTALL_ROOT" "$BUILD_ROOT$INSTALL_ROOT"/bin \ + "$BUILD_ROOT$INSTALL_ROOT"/lib \ + "$BUILD_ROOT$MAN_DIR" "$BUILD_ROOT$MAN_DIR"/man1 \ + "$BUILD_ROOT$INFO_DIR" "$BUILD_ROOT$DOC_DIR" \ + "$BUILD_ROOT$DOC_DIR"/html \ + "$BUILD_ROOT$SBCL_HOME" \ + "$BUILD_ROOT$SBCL_HOME"/site-systems + +# 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 "$BUILD_ROOT$INSTALL_ROOT"/bin/$RUNTIME && \ + mv "$BUILD_ROOT$INSTALL_ROOT"/bin/$RUNTIME \ + "$BUILD_ROOT$INSTALL_ROOT"/bin/$OLD_RUNTIME +test -f "$BUILD_ROOT$SBCL_HOME"/sbcl.core && \ + mv "$BUILD_ROOT$SBCL_HOME"/sbcl.core "$BUILD_ROOT$SBCL_HOME"/sbcl.core.old -cp src/runtime/sbcl $INSTALL_ROOT/bin/ -cp output/sbcl.core $SBCL_HOME/sbcl.core -cp doc/sbcl.1 $INSTALL_ROOT/man/man1/ +cp src/runtime/$RUNTIME "$BUILD_ROOT$INSTALL_ROOT"/bin/ +cp output/sbcl.core "$BUILD_ROOT$SBCL_HOME"/sbcl.core -# installing contrib +# installing contrib -SBCL="`pwd`/src/runtime/sbcl --noinform --core `pwd`/output/sbcl.core --userinit /dev/null --sysinit /dev/null --disable-debugger" +. ./sbcl-pwd.sh +sbcl_pwd + +SBCL="$SBCL_PWD/src/runtime/sbcl --noinform --core $SBCL_PWD/output/sbcl.core --no-userinit --no-sysinit --disable-debugger" SBCL_BUILDING_CONTRIB=1 -export SBCL SBCL_BUILDING_CONTRIB +export SBCL SBCL_BUILDING_CONTRIB SBCL_PWD + +. ./find-gnumake.sh +find_gnumake + +for i in `cd obj/asdf-cache ; echo *`; do + test -d obj/asdf-cache/$i && test -f obj/asdf-cache/$i/test-passed.test-report || continue; + INSTALL_DIR="$SBCL_HOME/contrib/" + export INSTALL_DIR + ensure_dirs "$BUILD_ROOT$INSTALL_DIR" && $GNUMAKE -C contrib/$i install < /dev/null +done + +echo +echo "SBCL has been installed:" +echo " binary $BUILD_ROOT$INSTALL_ROOT/bin/$RUNTIME" +echo " core and contribs in $BUILD_ROOT$INSTALL_ROOT/lib/sbcl/" + +# Installing manual & misc bits of documentation +# +# Locations based on FHS 2.3. +# See: +# +# share/ architecture independent read-only things +# share/man/ manpages, should be the same as man/ +# share/info/ info files +# share/doc/ misc documentation + +echo +echo "Documentation:" + +# man +cp doc/sbcl.1 "$BUILD_ROOT$MAN_DIR"/man1/ && echo " man $BUILD_ROOT$MAN_DIR/man1/sbcl.1" + +# info +for info in doc/manual/*.info +do + cp $info "$BUILD_ROOT$INFO_DIR"/ \ + && BN=`basename $info` \ + && DIRFAIL=`install-info --info-dir="$BUILD_ROOT$INFO_DIR" \ + "$BUILD_ROOT$INFO_DIR"/$BN > /dev/null 2>&1 \ + || echo "(could not add to system catalog)"` \ + && echo " info $BUILD_ROOT$INFO_DIR/`basename $info` [$BUILD_ROOT$INFO_DIR/dir] $DIRFAIL" +done + +for info in doc/manual/*.info-* +do + cp $info "$BUILD_ROOT$INFO_DIR"/ \ + && echo " info $BUILD_ROOT$INFO_DIR/`basename $info`" +done + +# pdf +for pdf in doc/manual/*.pdf +do + cp $pdf "$BUILD_ROOT$DOC_DIR"/ \ + && echo " pdf $BUILD_ROOT$DOC_DIR/`basename $pdf`" +done + +# html +for html in doc/manual/sbcl doc/manual/asdf +do + test -d $html && cp -R -L $html "$BUILD_ROOT$DOC_DIR"/html \ + && echo " html $BUILD_ROOT$DOC_DIR/html/`basename $html`/index.html" +done + +for html in doc/manual/sbcl.html doc/manual/asdf.html +do + cp $html "$BUILD_ROOT$DOC_DIR"/ \ + && echo " html $BUILD_ROOT$DOC_DIR/`basename $html`" +done -gnumake=${GNUMAKE:-gmake} -for i in contrib/*; do - test -d $i && test -e $i/Makefile || continue; - export INSTALL_DIR=$SBCL_HOME/`basename $i ` - $gnumake -C $i test && ensure_dirs $INSTALL_DIR && $gnumake -C $i install +for f in BUGS CREDITS COPYING NEWS +do + cp $f "$BUILD_ROOT$DOC_DIR"/ done