diff options
| -rw-r--r-- | elisp/geiser-autodoc.el | 17 | ||||
| -rw-r--r-- | elisp/geiser-doc.el | 4 | 
2 files changed, 14 insertions, 7 deletions
| diff --git a/elisp/geiser-autodoc.el b/elisp/geiser-autodoc.el index 5bdfb1a..2873bb0 100644 --- a/elisp/geiser-autodoc.el +++ b/elisp/geiser-autodoc.el @@ -87,11 +87,18 @@ when `geiser-autodoc-display-module-p' is on."          (t '...)))  (defun geiser-autodoc--format-arg (a) -  (if (and (listp a) (keywordp (car a))) -      (if (and (cdr a) (listp (cdr a))) -          (format "(#%s %s)" (car a) (cadr a)) -        (format "(#%s)" (car a))) -    (format "%s" a))) +  (cond ((null a) "()") +        ((symbolp a) (format "%s" a)) +        ((stringp a) (format "%S" a)) +        ((and (listp a) (keywordp (car a))) +         (if (and (cdr a) (listp (cdr a))) +             (format "(#%s %s)" (car a) (geiser-autodoc--format-arg (cadr a))) +           (format "(#%s)" (car a)))) +        ((and (listp a) (eq (car a) 'quote)) +         (format "'%s" (geiser-autodoc--format-arg (cadr a)))) +        ((listp a) (format "(%s)" +                           (mapconcat 'geiser-autodoc--format-arg a " "))) +        (t (format "%S" a))))  (defun geiser-autodoc--insert-arg-group (args current &optional pos)    (when args (insert " ")) diff --git a/elisp/geiser-doc.el b/elisp/geiser-doc.el index b95242c..3778770 100644 --- a/elisp/geiser-doc.el +++ b/elisp/geiser-doc.el @@ -278,8 +278,8 @@ With prefix argument, ask for symbol (with completion)."          (geiser-doc--insert-title (format "%s" module) t)          (newline)          (dolist (g '(("Procedures:" . procs) -                     ("Variables:" . vars) -                     ("Syntax:" . syntax))) +                     ("Syntax:" . syntax) +                     ("Variables:" . vars)))            (geiser-doc--insert-list (car g)                                     (cdr (assoc (cdr g) exports))                                     module | 
