summaryrefslogtreecommitdiff
path: root/elisp/geiser-autodoc.el
diff options
context:
space:
mode:
authorJose Antonio Ortega Ruiz <jao@gnu.org>2009-02-24 02:18:28 +0100
committerJose Antonio Ortega Ruiz <jao@gnu.org>2009-02-24 02:18:28 +0100
commit8bf2c578f184837968b1a16cf07235e9ba616a91 (patch)
treed65d8d84454bf5813cd0c8f261d28b7c26a2c595 /elisp/geiser-autodoc.el
parent540a2cb21e9d8b84ddd3be629b7f2937f76cf6e9 (diff)
downloadgeiser-8bf2c578f184837968b1a16cf07235e9ba616a91.tar.gz
geiser-8bf2c578f184837968b1a16cf07235e9ba616a91.tar.bz2
Partial support for stack trace display.
Diffstat (limited to 'elisp/geiser-autodoc.el')
-rw-r--r--elisp/geiser-autodoc.el57
1 files changed, 27 insertions, 30 deletions
diff --git a/elisp/geiser-autodoc.el b/elisp/geiser-autodoc.el
index 3c23b32..7460aa1 100644
--- a/elisp/geiser-autodoc.el
+++ b/elisp/geiser-autodoc.el
@@ -75,8 +75,7 @@ when `geiser-autodoc-display-module-p' is on."
(cdr pr))
(setq geiser-autodoc--last-funs funs)
(geiser-eval--send
- `(:eval ((:ge arguments)
- ,@(mapcar (lambda (f) (list 'quote (car f))) funs)))
+ `(:eval ((:ge arguments) ,@(mapcar (lambda (f) (list 'quote (car f))) funs)))
'geiser-autodoc--function-args-cont)
""))))
@@ -84,12 +83,9 @@ when `geiser-autodoc-display-module-p' is on."
(let ((result (geiser-eval--retort-result ret)))
(when (and result (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))
- 0))))))
+ (let* ((pos (or (cdr (assoc (car result) geiser-autodoc--last-funs)) 0))
+ (msg (geiser-autodoc--fun-args-str (car result) (cdr result) pos)))
+ (when msg (eldoc-message msg))))))
(defun geiser-autodoc--insert (sym current pos)
(let ((str (format "%s" sym)))
@@ -100,34 +96,35 @@ when `geiser-autodoc-display-module-p' is on."
(insert str)))
(defun geiser-autodoc--fun-args-str (fun args pos)
- (save-current-buffer
- (set-buffer (geiser-syntax--font-lock-buffer))
- (erase-buffer)
- (let* ((current 0)
- (module (and geiser-autodoc-display-module-p
- (cdr (assoc 'module args))))
- (fun (if module
- (format geiser-autodoc-procedure-name-format module fun)
- fun)))
- (insert "(")
- (geiser-autodoc--insert fun current pos)
- (dolist (arg (cdr (assoc 'required args)))
+ (when fun
+ (save-current-buffer
+ (set-buffer (geiser-syntax--font-lock-buffer))
+ (erase-buffer)
+ (let* ((current 0)
+ (module (and geiser-autodoc-display-module-p
+ (cdr (assoc 'module args))))
+ (fun (if module
+ (format geiser-autodoc-procedure-name-format module fun)
+ fun)))
+ (insert "(")
+ (geiser-autodoc--insert fun current pos)
+ (dolist (arg (cdr (assoc 'required args)))
+ (setq current (1+ current))
+ (insert " ")
+ (geiser-autodoc--insert arg current pos))
(setq current (1+ current))
- (insert " ")
- (geiser-autodoc--insert arg current pos))
- (setq current (1+ current))
- (when (cdr (assoc 'optional args))
- (when (> pos current) (setq current pos))
- (insert " . ")
- (geiser-autodoc--insert (cdr (assoc 'optional args)) current pos))
- (insert ")")
- (buffer-string))))
+ (when (cdr (assoc 'optional args))
+ (when (> pos current) (setq current pos))
+ (insert " . ")
+ (geiser-autodoc--insert (cdr (assoc 'optional args)) current pos))
+ (insert ")")
+ (buffer-string)))))
;;; Autodoc function:
(defun geiser-autodoc--eldoc-function ()
- (geiser-autodoc--function-args (geiser-syntax--enclosing-form-data)))
+ (or (geiser-autodoc--function-args (geiser-syntax--enclosing-form-data)) ""))
;;; Autodoc mode: