From: Stefan Monnier Date: Thu, 4 Mar 2021 23:20:56 +0000 (-0500) Subject: * lisp/emacs-lisp/cl-generic.el: Make `doc-string` prop work with qualifiers X-Git-Tag: emacs-28.0.90~3436 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=27428d22c8fd4f53a268484d235827122752d68a;p=emacs.git * lisp/emacs-lisp/cl-generic.el: Make `doc-string` prop work with qualifiers (cl--defmethod-doc-pos): New function. (cl-defmethod): Use it. --- diff --git a/lisp/emacs-lisp/cl-generic.el b/lisp/emacs-lisp/cl-generic.el index 89fc0b16d02..e78f88e30cf 100644 --- a/lisp/emacs-lisp/cl-generic.el +++ b/lisp/emacs-lisp/cl-generic.el @@ -425,6 +425,16 @@ the specializer used will be the one returned by BODY." (defun cl-generic--method-qualifier-p (x) (not (listp x))) +(defun cl--defmethod-doc-pos () + "Return the index of the docstring for a `cl-defmethod'. +Presumes point is at the end of the `cl-defmethod' symbol." + (save-excursion + (let ((n 2)) + (while (and (ignore-errors (forward-sexp 1) t) + (not (eq (char-before) ?\)))) + (cl-incf n)) + n))) + ;;;###autoload (defmacro cl-defmethod (name args &rest body) "Define a new method for generic function NAME. @@ -464,7 +474,7 @@ The set of acceptable TYPEs (also called \"specializers\") is defined \(and can be extended) by the various methods of `cl-generic-generalizers'. \(fn NAME [QUALIFIER] ARGS &rest [DOCSTRING] BODY)" - (declare (doc-string 3) (indent defun) + (declare (doc-string cl--defmethod-doc-pos) (indent defun) (debug (&define ; this means we are defining something [&name [sexp ;Allow (setf ...) additionally to symbols.