X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-target-2.sh;h=fb85d1de08edf35858475f1940b7b0431743d59a;hb=4a0ab5193096ca70dbbf43bb21418544f6d018b7;hp=03d53aaf4f5f420bb80775f70be1244869183dbb;hpb=d7f6139a91d7d9b0667a597584ae306d958bb2f4;p=sbcl.git diff --git a/make-target-2.sh b/make-target-2.sh index 03d53aa..fb85d1d 100644 --- a/make-target-2.sh +++ b/make-target-2.sh @@ -29,25 +29,32 @@ echo //doing warm init --core output/cold-sbcl.core \ --sysinit /dev/null --userinit /dev/null <<-'EOF' || exit 1 - (sb!int:/show "hello, world!") + ;; 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* 5) + (let ((*print-length* 10) (*print-level* 5)) - (sb!int:/show "about to LOAD warm.lisp") + #+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) - ;; REMOVEME: This is supposed to be :PURIFY T, the :PURIFY NIL - ;; is a hopefully-very-short-lived workaround for a bug in - ;; sbcl-0.6.12.8. - (sb-ext:save-lisp-and-die "output/sbcl.core" :purify nil) + (sb-ext:save-lisp-and-die "output/sbcl.core" :purify t) EOF