diff options
| author | Jose Antonio Ortega Ruiz <jao@gnu.org> | 2009-02-13 00:54:26 +0100 | 
|---|---|---|
| committer | Jose Antonio Ortega Ruiz <jao@gnu.org> | 2009-02-13 00:54:26 +0100 | 
| commit | 4ba2141701d636a8465ea82aaecc29020f3dcde3 (patch) | |
| tree | eedbb4ef83fa3c66ac471b61b0de57029b374cb8 | |
| parent | 8e503205ba4daf6579da9abcb6b3b68408fbbb46 (diff) | |
| download | geiser-4ba2141701d636a8465ea82aaecc29020f3dcde3.tar.gz geiser-4ba2141701d636a8465ea82aaecc29020f3dcde3.tar.bz2 | |
Faster, asynchronous autodoc.
| -rw-r--r-- | elisp/geiser-autodoc.el | 38 | 
1 files changed, 24 insertions, 14 deletions
| diff --git a/elisp/geiser-autodoc.el b/elisp/geiser-autodoc.el index f5db63b..9c3c40b 100644 --- a/elisp/geiser-autodoc.el +++ b/elisp/geiser-autodoc.el @@ -67,13 +67,29 @@ when `geiser-autodoc-display-module-p' is on."  (make-variable-buffer-local   (defvar geiser-autodoc--last nil)) -(defun geiser-autodoc--function-args (fun) -  (if (eq fun (car geiser-autodoc--last)) -      (cdr geiser-autodoc--last) -    (let ((result (geiser-eval--send/result `(:gs ((:ge proc-args) ',fun))))) -      (when (not (listp result)) (setq result 'undefined)) -      (setq geiser-autodoc--last (cons fun result)) -      result))) +(make-variable-buffer-local + (defvar geiser-autodoc--last-funs nil)) + +(defun geiser-autodoc--function-args (funs) +  (let ((pr (and (eq (car geiser-autodoc--last) (caar funs)) (car funs)))) +    (if pr (geiser-autodoc--fun-args-str (car pr) +                                         (cdr geiser-autodoc--last) +                                         (cdr pr)) +      (setq geiser-autodoc--last-funs funs) +      (geiser-eval--send `(:gs ((:ge arguments) ,@(mapcar (lambda (f) (list 'quote (car f))) +                                                          funs))) +                         'geiser-autodoc--function-args-cont) +      nil))) + +(defun geiser-autodoc--function-args-cont (ret) +  (let ((result (geiser-eval--retort-result ret))) +    (when (listp result) +      (setq geiser-autodoc--last result) +      (eldoc-message +       (geiser-autodoc--fun-args-str (car result) +                                     (cdr result) +                                     (or (cdr (assoc (car result) +                                                     geiser-autodoc--last-funs))))))))  (defun geiser-autodoc--insert (sym current pos)    (let ((str (format "%s" sym))) @@ -111,13 +127,7 @@ when `geiser-autodoc-display-module-p' is on."  ;;; Autodoc function:  (defun geiser-autodoc--eldoc-function () -  (let ((data (geiser-syntax--enclosing-form-data))) -    (catch 'doc-msg -      (dolist (f/a data) -        (let ((args (geiser-autodoc--function-args (car f/a)))) -          (when (listp args) -            (throw 'doc-msg -                   (geiser-autodoc--fun-args-str (car f/a) args (cdr f/a))))))))) +  (geiser-autodoc--function-args (geiser-syntax--enclosing-form-data)))  ;;; Autodoc mode: | 
