0.9.12.10:
[sbcl.git] / install.sh
index a2d30fd..51f8634 100644 (file)
@@ -1,16 +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 -p $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.
@@ -19,26 +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 $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$SBCL_HOME $BUILD_ROOT$SBCL_HOME/systems \
+    $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 $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 output/sbcl.core $BUILD_ROOT$SBCL_HOME/sbcl.core
-cp doc/sbcl.1 doc/sbcl-asdf-install.1 $BUILD_ROOT$MAN_DIR/man1/
 
-# 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
@@ -53,3 +83,53 @@ for i in contrib/*; do
     export INSTALL_DIR
     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: <http://www.pathname.com/fhs/pub/fhs-2.3.html>
+#
+# 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