From 75f29fee61a19b3607bd8fafa8a31184c998c5b0 Mon Sep 17 00:00:00 2001 From: William Harold Newman Date: Sat, 9 Mar 2002 04:50:08 +0000 Subject: [PATCH] 0.7.1.35: responding to CSR "src/compiler/main.lisp" in sbcl-devel 2002-03-08... ...fixed argument list for COMPILE-LOAD-TIME-STUFF (broken in 0.7.1.32) ...added some test cases for MAKE-LOAD-FORM (to catch problems like this in the future) split the MAKE-LOAD-FORM tests, and some other tests, into new tests/dump.impure-cload.lisp --- src/compiler/main.lisp | 8 ++---- tests/compiler-1.impure-cload.lisp | 15 ----------- tests/compiler.pure-cload.lisp | 5 ---- tests/dump.impure-cload.lisp | 52 ++++++++++++++++++++++++++++++++++++ version.lisp-expr | 2 +- 5 files changed, 55 insertions(+), 27 deletions(-) create mode 100644 tests/dump.impure-cload.lisp diff --git a/src/compiler/main.lisp b/src/compiler/main.lisp index 67d6412..b5ad7f1 100644 --- a/src/compiler/main.lisp +++ b/src/compiler/main.lisp @@ -1575,7 +1575,7 @@ ;;; deal with it. (defvar *constants-being-created* nil) (defvar *constants-created-since-last-init* nil) -;;; FIXME: Shouldn't these^ variables be bound in LET forms? +;;; FIXME: Shouldn't these^ variables be unbound outside LET forms? (defun emit-make-load-form (constant) (aver (fasl-output-p *compile-object*)) (unless (or (fasl-constant-already-dumped-p constant *compile-object*) @@ -1635,11 +1635,7 @@ (loop for (name form) on (cdr info) by #'cddr collect name into names collect form into forms - finally - (compile-make-load-form-init-forms - forms - (format nil "init form~:[~;s~] for ~{~A~^, ~}" - (cdr forms) names))) + finally (compile-make-load-form-init-forms forms)) nil))) (when circular-ref (setf (cdr circular-ref) diff --git a/tests/compiler-1.impure-cload.lisp b/tests/compiler-1.impure-cload.lisp index 4e5e80b..e50cf6f 100644 --- a/tests/compiler-1.impure-cload.lisp +++ b/tests/compiler-1.impure-cload.lisp @@ -43,21 +43,6 @@ (+ i f))) (assert (= (exercise-valuesify 1.25) 2.25)) -;;; Don Geddis reported this test case 25 December 1999 on a CMU CL -;;; mailing list: dumping circular lists caused the compiler to enter -;;; an infinite loop. Douglas Crosher reported a patch 27 Dec 1999. -;;; The patch was tested on SBCL by Martin Atzmueller 2 Nov 2000, and -;;; merged in sbcl-0.6.8.11. -(defun q-dg1999-1 () (dolist (x '#1=("A" "B" . #1#)) x)) -(defun q-dg1999-2 () (dolist (x '#1=("C" "D" . #1#)) x)) -(defun q-dg1999-3 () (dolist (x '#1=("E" "F" . #1#)) x)) -(defun q-dg1999-4 () (dolist (x '#1=("C" "D" . #1#)) x)) -(defun useful-dg1999 (keys) - (declare (type list keys)) - (loop - for c in '#1=("Red" "Blue" . #1#) - for key in keys )) - ;;; An early version (sbcl-0.6.11.33) of code to check FTYPEs from DEFUN ;;; against DECLAIMed FTYPEs blew up when an FTYPE was DECLAIMed ;;; to be pure FUNCTION, because the internal representation of diff --git a/tests/compiler.pure-cload.lisp b/tests/compiler.pure-cload.lisp index 279b850..c1b5ef1 100644 --- a/tests/compiler.pure-cload.lisp +++ b/tests/compiler.pure-cload.lisp @@ -35,8 +35,3 @@ ;;; This is a slightly different way of getting the same symptoms out ;;; of the sbcl-0.6.11.13 byte compiler bug. (print (setq *print-level* *print-level*)) - - -;;; sbcl-0.6.11.25 or so had DEF!STRUCT/MAKE-LOAD-FORM/HOST screwed up -;;; so that the compiler couldn't dump pathnames. -(format t "Now the compiler can dump pathnames again: ~S ~S~%" #p"" #p"/x/y/z") diff --git a/tests/dump.impure-cload.lisp b/tests/dump.impure-cload.lisp new file mode 100644 index 0000000..8cb8b89 --- /dev/null +++ b/tests/dump.impure-cload.lisp @@ -0,0 +1,52 @@ +;;;; tests related to the way objects are dumped into fasl files + +;;;; This software is part of the SBCL system. See the README file for +;;;; more information. +;;;; +;;;; While most of SBCL is derived from the CMU CL system, the test +;;;; files (like this one) were written from scratch after the fork +;;;; from CMU CL. +;;;; +;;;; This software is in the public domain and is provided with +;;;; absolutely no warranty. See the COPYING and CREDITS files for +;;;; more information. + +(cl:in-package :cl-user) + +(declaim (optimize (debug 3) (speed 2) (space 1))) + +;;; Don Geddis reported this test case 25 December 1999 on a CMU CL +;;; mailing list: dumping circular lists caused the compiler to enter +;;; an infinite loop. Douglas Crosher reported a patch 27 Dec 1999. +;;; The patch was tested on SBCL by Martin Atzmueller 2 Nov 2000, and +;;; merged in sbcl-0.6.8.11. +(defun q-dg1999-1 () (dolist (x '#1=("A" "B" . #1#)) x)) +(defun q-dg1999-2 () (dolist (x '#1=("C" "D" . #1#)) x)) +(defun q-dg1999-3 () (dolist (x '#1=("E" "F" . #1#)) x)) +(defun q-dg1999-4 () (dolist (x '#1=("C" "D" . #1#)) x)) +(defun useful-dg1999 (keys) + (declare (type list keys)) + (loop + for c in '#1=("Red" "Blue" . #1#) + for key in keys )) + +;;; sbcl-0.6.11.25 or so had DEF!STRUCT/MAKE-LOAD-FORM/HOST screwed up +;;; so that the compiler couldn't dump pathnames. +(format t "Now the compiler can dump pathnames again: ~S ~S~%" #p"" #p"/x/y/z") + +(eval-when (:compile-toplevel :load-toplevel :execute) + (defstruct foo x y) + (defmethod make-load-form ((foo foo) &optional env) + (declare (ignore env)) + ;; an extremely meaningless MAKE-LOAD-FORM method whose only point + ;; is to exercise the mechanism a little bit + (values `(make-foo :x (list ',(foo-x foo))) + `(setf (foo-y ,foo) ',foo)))) + +(defparameter *foo* + #.(make-foo :x "X" :y "Y")) + +(assert (equalp (foo-x *foo*) '("X"))) +(assert (eql (foo-y *foo*) *foo*)) + +(sb-ext:quit :unix-status 104) ; success diff --git a/version.lisp-expr b/version.lisp-expr index 770ee4d..05813a2 100644 --- a/version.lisp-expr +++ b/version.lisp-expr @@ -18,4 +18,4 @@ ;;; for internal versions, especially for internal versions off the ;;; main CVS branch, it gets hairier, e.g. "0.pre7.14.flaky4.13".) -"0.7.1.34" +"0.7.1.35" -- 1.7.10.4