---sysinit /dev/null --userinit /dev/null <<-'EOF' || exit 1
-
- ;; Now that we use the byte compiler for macros,
- ;; interpreted /SHOW doesn't work until later in init.
- #+sb-show (print "/hello, world!")
-
- ;; Do warm init.
- (let ((*print-length* 10)
- (*print-level* 5))
- #+sb-show (print "/about to LOAD warm.lisp")
- (load "src/cold/warm.lisp"))
-
- ;; Unintern no-longer-needed stuff before the possible PURIFY
- ;; in SAVE-LISP-AND-DIE.
- #-sb-fluid (sb-impl::!unintern-init-only-stuff)
-
- ;; FIXME: Why is it that, at least on x86 sbcl-0.6.12.46,
- ;; GC :FULL T isn't nearly as effective as PURIFY here?
- ;; (GC :FULL T gets us down to about 38 Mbytes, but PURIFY
- ;; gets us down to about 19 Mbytes.)
- (let ((*gc-notify-stream* *standard-output*))
- (sb-int:/show "done with warm.lisp, about to GC :FULL T")
- (gc :full t))
-
- (sb-int:/show "done with warm.lisp, about to SAVE-LISP-AND-DIE")
- ;; Even if /SHOW output was wanted during build, it's probably
- ;; not wanted by default after build is complete. (And if it's
- ;; wanted, it can easily be turned back on.)
- #+sb-show (setf sb-int:*/show* nil)
- (sb-ext:save-lisp-and-die "output/sbcl.core" :purify t)
- EOF
+--lose-on-corruption \
+--no-sysinit --no-userinit < make-target-2.lisp
+echo //doing warm init - load and dump phase
+./src/runtime/sbcl \
+--core output/cold-sbcl.core \
+--lose-on-corruption \
+--no-sysinit --no-userinit < make-target-2-load.lisp