X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-target-2.sh;h=a5ee9faf7bd038ae4afc0cf710ab08188588fdf5;hb=93b89755004549ed5f20d1938fd6e54ee20650b2;hp=0a51ab9e2140529389115c5354fe71ea337dfebc;hpb=3eb39e017e52b5d704e7d33405c873af52a533fd;p=sbcl.git diff --git a/make-target-2.sh b/make-target-2.sh index 0a51ab9..a5ee9fa 100644 --- a/make-target-2.sh +++ b/make-target-2.sh @@ -32,6 +32,7 @@ echo //doing warm init ;; Now that we use the compiler for macros, interpreted ;; /SHOW doesn't work until later in init. #+sb-show (print "/hello, world!") + (sb!ext:purify) ;; Until PRINT-OBJECT and other machinery is set up, ;; we want limits on printing to avoid infinite output. @@ -63,9 +64,9 @@ echo //doing warm init ;; 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 GC :FULL T") + (sb-c::pack-before-gc-hook) ; KLUDGE + (gc :full t) ;; resetting compilation policy to neutral values in ;; preparation for SAVE-LISP-AND-DIE as final SBCL core (not @@ -83,5 +84,8 @@ echo //doing warm init ;; 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) + ;; The system is complete now, all standard functions are + ;; defined. + (setq sb-c::*flame-on-necessarily-undefined-function* t) (sb-ext:save-lisp-and-die "output/sbcl.core" :purify t) EOF