[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
bug#12977: defmacro* does not process declare options
From: |
Stefan Monnier |
Subject: |
bug#12977: defmacro* does not process declare options |
Date: |
Sat, 24 Nov 2012 16:36:41 -0500 |
User-agent: |
Gnus/5.13 (Gnus v5.13) Emacs/24.3.50 (gnu/linux) |
> (defmacro* whereas ((var test) &rest body)
> (declare (indent 1))
[...]
> 24.2.50 => (nil (lisp-indent-function 1))
Indeed, thanks, should be fixed now on the emacs-24 branch (see patch
below).
Stefan
=== modified file 'lisp/emacs-lisp/cl-macs.el'
--- lisp/emacs-lisp/cl-macs.el 2012-11-15 21:01:25 +0000
+++ lisp/emacs-lisp/cl-macs.el 2012-11-24 21:30:26 +0000
@@ -216,12 +216,17 @@
(defvar cl--bind-inits) (defvar cl--bind-lets) (defvar cl--bind-forms)
(defun cl--transform-lambda (form bind-block)
+ "Transform a function form FORM of name BIND-BLOCK.
+BIND-BLOCK is the name of the symbol to which the function will be bound,
+and which will be used for the name of the `cl-block' surrounding the
+function's body.
+FORM is of the form (ARGS . BODY)."
(let* ((args (car form)) (body (cdr form)) (orig-args args)
(cl--bind-block bind-block) (cl--bind-defs nil) (cl--bind-enquote nil)
(cl--bind-inits nil) (cl--bind-lets nil) (cl--bind-forms nil)
(header nil) (simple-args nil))
(while (or (stringp (car body))
- (memq (car-safe (car body)) '(interactive cl-declare)))
+ (memq (car-safe (car body)) '(interactive declare cl-declare)))
(push (pop body) header))
(setq args (if (listp args) (cl-copy-list args) (list '&rest args)))
(let ((p (last args))) (if (cdr p) (setcdr p (list '&rest (cdr p)))))