X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=install.sh;h=be855734a7a3791ff4eae6b1aa257e7396c85eef;hb=01e9e8c568777d6480699e6cb3947f38c3bed350;hp=d1a19c5f5c8e6256ba1ac2d172ff26ccd0362df5;hpb=905a0fc4c21ff6c8c752b9436e0616b868f1dfcc;p=sbcl.git diff --git a/install.sh b/install.sh index d1a19c5..be85573 100644 --- a/install.sh +++ b/install.sh @@ -1,21 +1,30 @@ #!/bin/sh +set -e # Install SBCL files into the usual places. -ensure_dirs () +ensure_dirs () { - for j in $*; do - test -d $j || mkdir -p $j + for j in $*; do + test -d $j || mkdir -p $j done; } -INSTALL_ROOT=${INSTALL_ROOT-/usr/local} +if [ "$OSTYPE" = "cygwin" -o "$OSTYPE" = "msys" ] ; then + DEFAULT_INSTALL_ROOT="$PROGRAMFILES/sbcl" + RUNTIME=sbcl.exe + OLD_RUNTIME=sbcl.exe.old +else + DEFAULT_INSTALL_ROOT=/usr/local + 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? -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. echo Aborting installation. Unset one or reset the other, then try again @@ -25,15 +34,15 @@ if [ -n "$SBCL_HOME" -a "$INSTALL_ROOT/lib/sbcl" != "$SBCL_HOME" ];then fi # Before doing anything else, make sure we have an SBCL to install -if [ -f src/runtime/sbcl ]; then +if [ -f src/runtime/$RUNTIME ]; then if [ -f output/sbcl.core ]; then - true + true else - echo "output/sbcl.core not found, aborting installation." - exit 1 + echo "output/sbcl.core not found, aborting installation." + exit 1 fi else - echo "src/runtime/sbcl not found, aborting installation." + echo "src/runtime/$RUNTIME not found, aborting installation." exit 1 fi @@ -44,22 +53,26 @@ ensure_dirs $BUILD_ROOT$INSTALL_ROOT $BUILD_ROOT$INSTALL_ROOT/bin \ $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/systems \ + $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/sbcl && \ - mv $BUILD_ROOT$INSTALL_ROOT/bin/sbcl $BUILD_ROOT$INSTALL_ROOT/bin/sbcl.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 $BUILD_ROOT$INSTALL_ROOT/bin/ +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.sh +sbcl_pwd -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 --no-userinit --no-sysinit --disable-debugger" SBCL_BUILDING_CONTRIB=1 export SBCL SBCL_BUILDING_CONTRIB @@ -75,7 +88,7 @@ done echo echo "SBCL has been installed:" -echo " binary $BUILD_ROOT$INSTALL_ROOT/bin/sbcl" +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 @@ -95,11 +108,11 @@ echo "Documentation:" 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 +for info in doc/manual/*.info doc/manual/*.info-* do cp $info $BUILD_ROOT$INFO_DIR/ \ - && echo -n " info $BUILD_ROOT$INFO_DIR/`basename $info`" \ - && ( install-info $BUILD_ROOT$INFO_DIR/`basename $info` > /dev/null 2>&1 \ + && 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