X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=install.sh;h=fbad2a8ad136dd9b6b3aa6b1db62a7b4964b61ee;hb=e33e99504666fda29c1b3cc4ed2daa579aa90df1;hp=2002101e845dec1b7bee3b864f4d8b512dfef8d1;hpb=94ebb3fb0c00799e2fa3d69cb0c52a772cee47f6;p=sbcl.git diff --git a/install.sh b/install.sh index 2002101..fbad2a8 100644 --- a/install.sh +++ b/install.sh @@ -5,12 +5,15 @@ ensure_dirs () { for j in $*; do - test -d $j || mkdir $j + 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} + 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. @@ -23,7 +26,9 @@ 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 \ - $MAN_DIR $MAN_DIR/man1 \ + $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/site-systems @@ -36,7 +41,6 @@ test -f $BUILD_ROOT$SBCL_HOME/sbcl.core && \ cp src/runtime/sbcl $BUILD_ROOT$INSTALL_ROOT/bin/ cp output/sbcl.core $BUILD_ROOT$SBCL_HOME/sbcl.core -cp doc/sbcl.1 $BUILD_ROOT$MAN_DIR/man1/ # installing contrib @@ -53,3 +57,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: +# +# 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`" \ + && ( install-info $BUILD_ROOT$INFO_DIR/`basename $info` > /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