- (typecase fun
- ;; ordinary (SETF FOO) case
- (symbol (values t fun))
- ;; reasonable (SETF (QUUX BAZ)) case [but not (SETF (SETF
- ;; FOO))]
- (cons (unless (eq (car fun) 'setf)
- (valid-function-name-p fun))))))))
+ (typecase fun
+ ;; ordinary (SETF FOO) case
+ (symbol (values t fun))
+ ;; reasonable (SETF (QUUX BAZ)) case [but not (SETF (SETF
+ ;; FOO))]
+ (cons (unless (eq (car fun) 'setf)
+ (valid-function-name-p fun))))))))
+
+(defun macro-function-name (name)
+ (when (and (cdr name)
+ (consp (cdr name)))
+ (destructuring-bind (fun &rest rest) (cdr name)
+ (when (null rest)
+ (typecase fun
+ ;; (DEFMACRO FOO)
+ (symbol (values t fun))
+ ;; (DEFMACRO (SETF FOO))
+ (cons (when (eq (car fun) 'setf)
+ (valid-function-name-p fun))))))))
+
+(define-function-name-syntax defmacro (name)
+ (macro-function-name name))
+
+(define-function-name-syntax macrolet (name)
+ (macro-function-name name))