X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=slam.sh;h=95a3194b5af17652e344a32f6d02b1dbf30a16af;hb=22c1de0a40df83bb5628974010a879cb2c17ff53;hp=8402cca7d899be80cfc194aa5b85e30c891ee03f;hpb=9a2e730f74641e7de6ad4099111db92c5ad863bf;p=sbcl.git diff --git a/slam.sh b/slam.sh index 8402cca..95a3194 100644 --- a/slam.sh +++ b/slam.sh @@ -63,10 +63,9 @@ # recommended way to make that happen. ####################################################################### -if [ "" != "$*" ]; then - echo no command line arguments supported in this version of slam - exit 1 -fi +HOST_TYPE="${1:-sbcl}" + +echo //HOST_TYPE=\"$HOST_TYPE\" # We don't try to be general about this in this script the way we are # in make.sh, since the idiosyncrasies of SBCL command line argument @@ -74,17 +73,44 @@ fi # and the SBCL-vs-CMUCL dependence of --core/-core argument syntax # make it too messy to try deal with arbitrary SBCL_XC_HOST variants. # So you have no choice: -export SBCL_XC_HOST='sbcl --disable-debugger' +case "$HOST_TYPE" in + cmucl) LISP="lisp -batch" + INIT="-noinit" + CORE="-core" + ;; + sbcl) LISP="sbcl" + INIT="--sysinit /dev/null --userinit /dev/null" + CORE="--core" + ;; + clisp) LISP="clisp" + INIT="-norc" + CORE="-M" + ;; + openmcl) + LISP="openmcl" + INIT="-b" + CORE="-I" + ;; + *) echo unknown host type: "$HOST_TYPE" + echo should be one of "sbcl", "cmucl", or "clisp" + exit 1 +esac + +SBCL_XC_HOST="$LISP $INIT" +export SBCL_XC_HOST # (We don't do make-host-1.sh at all. Hopefully nothing relevant has # changed.) +. ./find-gnumake.sh +find_gnumake + sh make-target-1.sh || exit 1 # Instead of doing the full make-host-2.sh, we (1) use after-xc.core # to rebuild only obviously-out-of-date Lisp files, then (2) run # GENESIS. -sbcl --core output/after-xc.core --sysinit /dev/null --userinit /dev/null <<'EOF' || exit 1 +$LISP $CORE output/after-xc.core $INIT <<'EOF' || exit 1 (load "src/cold/slam.lisp") EOF # (This ^ used to be