summaryrefslogtreecommitdiff
path: root/geiser/doc.scm
diff options
context:
space:
mode:
authorJose Antonio Ortega Ruiz <jao@gnu.org>2009-03-03 22:39:26 +0100
committerJose Antonio Ortega Ruiz <jao@gnu.org>2009-03-03 22:39:26 +0100
commit5be0195e6ca13734477a222bfe2e93057dee421f (patch)
treed66fc00363be37e73992842cfd561578cb574c9d /geiser/doc.scm
parent0d624953c2a5e3c999b9b36e1f777d2aa4548674 (diff)
downloadgeiser-guile-5be0195e6ca13734477a222bfe2e93057dee421f.tar.gz
geiser-guile-5be0195e6ca13734477a222bfe2e93057dee421f.tar.bz2
Cache arguments parsed from documentation; don't treat quasiquote as a function.
Diffstat (limited to 'geiser/doc.scm')
-rw-r--r--geiser/doc.scm21
1 files changed, 14 insertions, 7 deletions
diff --git a/geiser/doc.scm b/geiser/doc.scm
index 175fe19..1057b89 100644
--- a/geiser/doc.scm
+++ b/geiser/doc.scm
@@ -45,7 +45,8 @@
(cond ((symbol? lst) (or (describe-application (list lst))
(describe-application form)))
((pair? lst)
- (or (and (not (eq? (car lst) 'quote)) (autodoc (pair->list lst)))
+ (or (and (not (memq (car lst) '(quote quasiquote)))
+ (autodoc (pair->list lst)))
(autodoc (map (lambda (s) (if (pair? s) (gensym) s)) form))))
(else (describe-application form)))))
(else #f)))
@@ -109,7 +110,7 @@
((procedure-property proc 'arglist) => arglist->args)
((procedure-source proc) => source->args)
((program? proc) ((@ (system vm program) program-arguments) proc))
- ((doc->args (object-documentation proc)))
+ ((doc->args proc))
((procedure-property proc 'arity) => arity->args)
(else #f)))
@@ -141,13 +142,19 @@
(keyword . ,(caddr arglist))
(rest . ,(car (cddddr arglist)))))
-(define (doc->args doc)
+(define (doc->args proc)
(define proc-rx "-- Scheme Procedure: ([^[\n]+)\n")
(define proc-rx2 "-- Scheme Procedure: ([^[\n]+\\[[^\n]*(\n[^\n]+\\]+)?)")
- (and doc
- (let ((match (or (string-match proc-rx doc)
- (string-match proc-rx2 doc))))
- (and match (parse-signature-string (match:substring match 1))))))
+ (cond ((procedure-property proc 'geiser-document-args))
+ ((object-documentation proc)
+ => (lambda (doc)
+ (let* ((match (or (string-match proc-rx doc)
+ (string-match proc-rx2 doc)))
+ (args (and match
+ (parse-signature-string (match:substring match 1)))))
+ (set-procedure-property! proc 'geiser-document-args args)
+ args)))
+ (else #f)))
(define (parse-signature-string str)
(define opt-arg-rx "\\[([^] ]+)\\]?")