X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcode%2Fdefboot.lisp;h=9f3bf28a7a478eaef9f64f29220029a4035c0874;hb=be974ede67a3d7f8a6e7aa200ad042d3ac644cff;hp=2285b4f6e704e74d3d0152dd9b0fb98475f27cf1;hpb=1d881f74d4c2c6099107544a5f337837eb281865;p=sbcl.git diff --git a/src/code/defboot.lisp b/src/code/defboot.lisp index 2285b4f..9f3bf28 100644 --- a/src/code/defboot.lisp +++ b/src/code/defboot.lisp @@ -360,17 +360,18 @@ evaluated as a PROGN." ;; var. (multiple-value-bind (forms decls) (parse-body body :doc-string-allowed nil) (let* ((n-list (gensym "N-LIST")) - (start (gensym "START")) - (tmp (gensym "TMP"))) + (start (gensym "START"))) (multiple-value-bind (clist members clist-ok) (cond ((sb!xc:constantp list env) (let ((value (constant-form-value list env))) - (multiple-value-bind (all dot) (list-members value) - (when dot + (multiple-value-bind (all dot) (list-members value :max-length 20) + (when (eql dot t) ;; Full warning is too much: the user may terminate the loop ;; early enough. Contents are still right, though. (style-warn "Dotted list ~S in DOLIST." value)) - (values value all t)))) + (if (eql dot :maybe) + (values value nil nil) + (values value all t))))) ((and (consp list) (eq 'list (car list)) (every (lambda (arg) (sb!xc:constantp arg env)) (cdr list))) (let ((values (mapcar (lambda (arg) (constant-form-value arg env)) (cdr list)))) @@ -382,10 +383,9 @@ evaluated as a PROGN." (tagbody ,start (unless (endp ,n-list) - (let* (,@(if clist-ok - `((,tmp (truly-the (member ,@members) (car ,n-list))) - (,var ,tmp)) - `((,var (car ,n-list))))) + (let ((,var ,(if clist-ok + `(truly-the (member ,@members) (car ,n-list)) + `(car ,n-list)))) ,@decls (setq ,n-list (cdr ,n-list)) (tagbody ,@forms)) @@ -549,6 +549,7 @@ evaluated as a PROGN." clauses)))) `(block ,block-tag (let ((,temp-var nil)) + (declare (ignorable ,temp-var)) (tagbody (restart-bind ,(mapcar (lambda (datum)