diff lisp/cl-macs.el @ 5509:9ac0016d8fe8

Remove `bind-inits', cl-macs.el, it's no longer used. 2011-05-18 Aidan Kehoe <kehoea@parhasard.net> * cl-macs.el (bind-inits)): Removed. * cl-macs.el (defun*): * cl-macs.el (defmacro*): * cl-macs.el (function*): * cl-macs.el (macrolet): * cl-macs.el (cl-transform-function-property): * cl-macs.el (destructuring-bind): Remove `bind-inits' from this file, and only ever return nil as the first element of cl-transform-lambda's result list; bind-inits hasn't been used since the support for non-self-quoting keywords was removed, and its absence (and the guarantee that the first element of the result of cl-transform-lambda is nil) make the implementations of various other macros easier and clearer. * cl-macs.el (cl-transform-lambda): Give this function a docstring.
author Aidan Kehoe <kehoea@parhasard.net>
date Wed, 18 May 2011 14:21:52 +0100
parents 4813ff11c6e2
children 7b5254f6e0d5
line wrap: on
line diff
--- a/lisp/cl-macs.el	Mon May 09 20:47:31 2011 +0100
+++ b/lisp/cl-macs.el	Wed May 18 14:21:52 2011 +0100
@@ -222,9 +222,8 @@
    The format of each binding is VAR || (VAR [INITFORM]) -- exactly like the
    format of `let'/`let*' bindings.
 "
-  (let* ((res (cl-transform-lambda (list* arglist docstring body) name))
-	 (form (list* 'defun name (cdr res))))
-    (if (car res) (list 'progn (car res) form) form)))
+  (list* 'defun name (cdr (cl-transform-lambda (list* arglist docstring body)
+                                               name))))
 
 ;;;###autoload
 (defmacro defmacro* (name arglist &optional docstring &rest body)
@@ -278,33 +277,29 @@
        are ignored, not enough arguments cause the remaining parameters to
        receive a value of nil, etc.
 "
-  (let* ((res (cl-transform-lambda (list* arglist docstring body) name))
-	 (form (list* 'defmacro name (cdr res))))
-    (if (car res) (list 'progn (car res) form) form)))
+  (list* 'defmacro name (cdr (cl-transform-lambda (list* arglist docstring body)
+                                                  name))))
 
 ;;;###autoload
 (defmacro function* (symbol-or-lambda)
   "Introduce a function.
 Like normal `function', except that if argument is a lambda form, its
 ARGLIST allows full Common Lisp conventions."
-  (if (eq (car-safe symbol-or-lambda) 'lambda)
-      (let* ((res (cl-transform-lambda (cdr symbol-or-lambda) 'cl-none))
-	     (form (list 'function (cons 'lambda (cdr res)))))
-	(if (car res) (list 'progn (car res) form) form))
-    (list 'function symbol-or-lambda)))
+  `(function
+    ,(if (eq (car-safe symbol-or-lambda) 'lambda)
+         (cons 'lambda (cdr (cl-transform-lambda (cdr symbol-or-lambda)
+                                                 'cl-none)))
+       symbol-or-lambda)))
 
 (defun cl-transform-function-property (func prop form)
-  (let ((res (cl-transform-lambda form func)))
-    (append '(progn) (cdr (cdr (car res)))
-	    (list (list 'put (list 'quote func) (list 'quote prop)
-			(list 'function (cons 'lambda (cdr res))))))))
+  `(put ',func ',prop #'(lambda ,@(cdr (cl-transform-lambda form func)))))
 
 (defconst lambda-list-keywords
   '(&optional &rest &key &allow-other-keys &aux &whole &body &environment))
 
 (defvar cl-macro-environment nil)
 (defvar bind-block) (defvar bind-defs) (defvar bind-enquote)
-(defvar bind-inits) (defvar bind-lets) (defvar bind-forms)
+(defvar bind-lets) (defvar bind-forms)
 
 ;; npak@ispras.ru
 (defun cl-upcase-arg (arg)
@@ -346,9 +341,20 @@
 	(t "Not available")))))
 
 (defun cl-transform-lambda (form bind-block)
+  "Transform a lambda expression to support Common Lisp conventions.
+
+FORM is the cdr of the lambda expression.  BIND-BLOCK is the implicit block
+name that's added, typically the name of the associated function. It can be
+the symbol `cl-none', to indicate no implicit block is needed.
+
+The Common Lisp conventions described are those detailed in the `defun*' and
+`defmacro*' docstrings.  This function returns a list with the first element
+nil, to be ignored. The rest of the list represents a transformed lambda
+expression, with any argument list parsing code necessary, and a surrounding
+block."
   (let* ((args (car form)) (body (cdr form))
 	 (bind-defs nil) (bind-enquote nil)
-	 (bind-inits nil) (bind-lets nil) (bind-forms nil)
+         (bind-lets nil) (bind-forms nil)
 	 (header nil) (simple-args nil)
          (complex-arglist (cl-function-arglist args))
          (doc ""))
@@ -389,10 +395,10 @@
       (cl-do-arglist args nil (- (length simple-args)
 				 (if (memq '&optional simple-args) 1 0)))
       (setq bind-lets (nreverse bind-lets))
-      (list* (and bind-inits (list* 'eval-when '(compile load eval)
-				    (nreverse bind-inits)))
-	     (nconc simple-args
-		    (list '&rest (car (pop bind-lets))))
+      ;; This code originally needed to create the keywords itself, that
+      ;; wasn't done by the Lisp reader; the first element of the result
+      ;; list comprised code to do this. It's not used any more.
+      (list* nil (nconc simple-args (list '&rest (car (pop bind-lets))))
 	     ;; XEmacs change: we add usage information using Nickolay's
 	     ;; approach above
 	     (nconc header
@@ -571,13 +577,9 @@
 I say \"approximately\" because the destructuring works in a somewhat
 different fashion, although for most reasonably simple constructs the
 results will be the same."
-  (let* ((bind-lets nil) (bind-forms nil) (bind-inits nil)
-	 (bind-defs nil) (bind-block 'cl-none))
+  (let ((bind-block 'cl-none) bind-lets bind-forms bind-defs)
     (cl-do-arglist (or args '(&aux)) expr)
-    (append '(progn) bind-inits
-	    (list (nconc (list 'let* (nreverse bind-lets))
-			 (nreverse bind-forms) body)))))
-
+    (nconc (list 'let* (nreverse bind-lets)) (nreverse bind-forms) body)))
 
 ;;; The `eval-when' form.
 
@@ -1777,11 +1779,8 @@
                          for (name . details)
                          in (cons (list* name arglist docstring body) macros)
                          collect
-                         (list* name 'lambda
-                                (prog1
-                                    (cdr (setq details (cl-transform-lambda
-                                                        details name)))
-                                  (eval (car details)))))
+                         (list* name 'lambda (cdr (cl-transform-lambda details
+                                                                       name))))
                        cl-macro-environment)))
 
 ;;;###autoload