X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=install.sh;h=51f86348e3bb5f68c9099edee72d62a9a8b84981;hb=aa8c8cd473f1d487fa2c1a7490c78a59b9955bbe;hp=50c66b6beedca0786a73b6d2cae727a43cc7e5d8;hpb=08e218c9bd9fdfb1e4dcc5f5e245feea17762471;p=sbcl.git diff --git a/install.sh b/install.sh index 50c66b6..51f8634 100644 --- a/install.sh +++ b/install.sh @@ -1,15 +1,21 @@ #!/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} +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? SBCL_SOURCE=`pwd` if [ -n "$SBCL_HOME" -a "$INSTALL_ROOT/lib/sbcl" != "$SBCL_HOME" ];then echo SBCL_HOME environment variable is set, and conflicts with INSTALL_ROOT. @@ -18,24 +24,51 @@ if [ -n "$SBCL_HOME" -a "$INSTALL_ROOT/lib/sbcl" != "$SBCL_HOME" ];then echo SBCL_HOME="$SBCL_HOME" exit 1 fi + +# Before doing anything else, make sure we have an SBCL to install +if [ -f src/runtime/sbcl ]; then + if [ -f output/sbcl.core ]; then + true + else + echo "output/sbcl.core not found, aborting installation." + exit 1 + fi +else + echo "src/runtime/sbcl not found, aborting installation." + exit 1 +fi + SBCL_HOME=$INSTALL_ROOT/lib/sbcl 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/site-systems +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 + +if [ "$OSTYPE" = "msys" ] +then + RUNTIME=sbcl.exe + OLD_RUNTIME=sbcl_old.exe +else + RUNTIME=sbcl + OLD_RUNTIME=sbcl.old +fi # 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 +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/sbcl $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_BUILDING_CONTRIB=1 @@ -48,5 +81,55 @@ for i in contrib/*; do 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 + ensure_dirs $BUILD_ROOT$INSTALL_DIR && $GNUMAKE -C $i install +done + +echo +echo "SBCL has been installed:" +echo " binary $BUILD_ROOT$INSTALL_ROOT/bin/sbcl" +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/ \ + && echo -n " info $BUILD_ROOT$INFO_DIR/`basename $info` $BUILD_ROOT$INFO_DIR/dir" \ + && ( install-info $BUILD_ROOT$INFO_DIR/`basename $info` $BUILD_ROOT$INFO_DIR/dir > /dev/null 2>&1 \ + || echo -n " (could not add to system catalog)" ) \ + && echo +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 f in BUGS SUPPORT CREDITS COPYING NEWS +do + cp $f $BUILD_ROOT$DOC_DIR/ done