diff options
| author | Jose Antonio Ortega Ruiz <jao@gnu.org> | 2009-09-07 00:23:17 +0200 | 
|---|---|---|
| committer | Jose Antonio Ortega Ruiz <jao@gnu.org> | 2009-09-07 00:23:17 +0200 | 
| commit | 8f5e58189692663901266dc83f2e2b4e47803b8d (patch) | |
| tree | af04cbe37abec51cbf4106f06a497445904dc7a6 /scheme/guile/geiser | |
| parent | 61edb258a45d5ad00ee907594c6dfbcd21d93485 (diff) | |
| parent | 3a80af06f2b9272db379fed3b5b659ecfeeceb70 (diff) | |
| download | geiser-guile-8f5e58189692663901266dc83f2e2b4e47803b8d.tar.gz geiser-guile-8f5e58189692663901266dc83f2e2b4e47803b8d.tar.bz2 | |
Merge branch 'devel'
Diffstat (limited to 'scheme/guile/geiser')
| -rw-r--r-- | scheme/guile/geiser/completion.scm | 25 | ||||
| -rw-r--r-- | scheme/guile/geiser/doc.scm | 89 | ||||
| -rw-r--r-- | scheme/guile/geiser/emacs.scm | 3 | ||||
| -rw-r--r-- | scheme/guile/geiser/evaluation.scm | 64 | ||||
| -rw-r--r-- | scheme/guile/geiser/xref.scm | 9 | 
5 files changed, 66 insertions, 124 deletions
| diff --git a/scheme/guile/geiser/completion.scm b/scheme/guile/geiser/completion.scm index f4342bb..564b8f5 100644 --- a/scheme/guile/geiser/completion.scm +++ b/scheme/guile/geiser/completion.scm @@ -31,28 +31,9 @@    #:use-module (ice-9 session)    #:use-module (ice-9 regex)) -(define (completions prefix . context) -  (let ((context (and (not (null? context)) (car context))) -        (prefix (string-append "^" (regexp-quote prefix)))) -    (append (filter (lambda (s) (string-match prefix s)) -                    (map symbol->string (local-bindings context))) -            (sort! (map symbol->string (apropos-internal prefix)) string<?)))) - -(define (local-bindings form) -  (define (body f) (if (> (length f) 2) (cddr f) '())) -  (let loop ((form form) (bindings '())) -    (cond ((not (pair? form)) bindings) -          ((list? (car form)) -           (loop (cdr form) (append (local-bindings (car form)) bindings))) -          ((and (list? form) (< (length form) 2)) bindings) -          ((memq (car form) '(define define* lambda)) -           (loop (body form) (append (pair->list (cadr form)) bindings))) -          ((and (memq (car form) '(let let* letrec letrec*)) -                (list? (cadr form))) -           (loop (body form) (append (map car (cadr form)) bindings))) -          ((and (eq? 'let (car form)) (symbol? (cadr form))) -           (loop (cons 'let (body form)) (cons (cadr form) bindings))) -          (else (loop (cdr form) bindings))))) +(define (completions prefix) +  (let ((prefix (string-append "^" (regexp-quote prefix)))) +    (sort! (map symbol->string (apropos-internal prefix)) string<?)))  (define (module-completions prefix)    (let* ((prefix (string-append "^" (regexp-quote prefix))) diff --git a/scheme/guile/geiser/doc.scm b/scheme/guile/geiser/doc.scm index c61502e..52f5625 100644 --- a/scheme/guile/geiser/doc.scm +++ b/scheme/guile/geiser/doc.scm @@ -37,82 +37,41 @@    #:use-module (oop goops)    #:use-module (srfi srfi-1)) -(define (autodoc form) -  (cond ((null? form) #f) -        ((symbol? form) (describe-application (list form))) -        ((not (pair? form)) #f) -        ((not (list? form)) (autodoc (pair->list form))) -        ((define-head? form) => autodoc) -        (else (autodoc/list form)))) - -(define (autodoc/list form) -  (let ((lst (last form))) -    (cond ((and (symbol? lst) (describe-application (list lst)))) -          ((and (pair? lst) (not (memq (car lst) '(quote))) (autodoc lst))) -          (else (describe-application form))))) - -(define (define-head? form) -  (define defforms '(define define* define-macro define-macro* -                      define-method define-class define-generic)) -  (and (= 2 (length form)) -       (memq (car form) defforms) -       (car form))) - -(define (describe-application form) -  (let* ((fun (car form)) -         (args (obj-args (symbol->object fun)))) +(define (autodoc ids) +  (if (not (list? ids)) +      '() +      (map (lambda (id) (or (autodoc* id) (list id))) ids))) + +(define (autodoc* id) +  (let ((args (obj-args (symbol->object id))))      (and args -         (list (cons 'signature (signature fun args)) -               (cons 'position (find-position args form)) -               (cons 'module (symbol-module fun)))))) +         `(,@(signature id args) +           (module . ,(symbol-module id))))))  (define (object-signature name obj)    (let ((args (obj-args obj)))      (and args (signature name args)))) -(define (signature fun args) -  (let ((req (arglst args 'required)) -        (opt (arglst args 'optional)) -        (key (arglst args 'keyword)) -        (rest (assq-ref args 'rest))) -    (let ((sgn `(,fun ,@req -                      ,@(if (not (null? opt)) (cons #:opt opt) '()) -                      ,@(if (not (null? key)) (cons #:key key) '())))) -      (if rest `(,@sgn #:rest ,rest) sgn)))) - -(define (find-position args form) -  (let* ((lf (length form)) -         (lf-1 (- lf 1))) -    (if (= 1 lf) 0 -        (let ((req (length (arglst args 'required))) -              (opt (length (arglst args 'optional))) -              (keys (map (lambda (k) (symbol->keyword (if (list? k) (car k) k))) -                         (arglst args 'keyword))) -              (rest (assq-ref args 'rest))) -          (cond ((<= lf (+ 1 req)) lf-1) -                ((<= lf (+ 1 req opt)) (if (> opt 0) lf lf-1)) -                ((or (memq (last form) keys) -                     (memq (car (take-right form 2)) keys)) => -                 (lambda (sl) -                   (+ 2 req -                      (if (> opt 0) (+ 1 opt) 0) -                      (- (length keys) (length sl))))) -                (else (+ 1 req -                         (if (> opt 0) (+ 1 opt) 0) -                         (if (null? keys) 0 (+ 1 (length keys))) -                         (if rest 2 0)))))))) - -(define (arglst args kind) -  (let ((args (assq-ref args kind))) -    (cond ((or (not args) (null? args)) '()) -          ((list? args) args) -          (else (list args))))) +(define (signature id args) +  (define (arglst kind) +    (let ((args (assq-ref args kind))) +      (cond ((or (not args) (null? args)) '()) +            ((list? args) args) +            (else (list args))))) +  `(,id +    (args ,@(if (list? args) +                `((required ,@(arglst 'required)) +                  (optional ,@(arglst 'optional) +                            ,@(let ((rest (assq-ref args 'rest))) +                                (if rest (list "...") '()))) +                  (key ,@(arglst 'keyword))) +                '()))))  (define (obj-args obj)    (cond ((not obj) #f)          ((or (procedure? obj) (program? obj)) (arguments obj))          ((macro? obj) (or (obj-args (macro-transformer obj)) '((required ...)))) -        (else #f))) +        (else 'variable)))  (define (arguments proc)    (cond diff --git a/scheme/guile/geiser/emacs.scm b/scheme/guile/geiser/emacs.scm index edae487..2aa91da 100644 --- a/scheme/guile/geiser/emacs.scm +++ b/scheme/guile/geiser/emacs.scm @@ -39,7 +39,8 @@                 ge:module-exports                 ge:module-location                 ge:callers -               ge:callees) +               ge:callees +               ge:find-file)    #:use-module (geiser evaluation)    #:use-module ((geiser modules) :renamer (symbol-prefix-proc 'ge:))    #:use-module ((geiser completion) :renamer (symbol-prefix-proc 'ge:)) diff --git a/scheme/guile/geiser/evaluation.scm b/scheme/guile/geiser/evaluation.scm index 537e145..cbc088e 100644 --- a/scheme/guile/geiser/evaluation.scm +++ b/scheme/guile/geiser/evaluation.scm @@ -47,53 +47,47 @@      (else (display (format "ERROR: ~a, args: ~a" (car args) (cdr args)))))    `(error (key . ,(car args)))) -(define (evaluate form module-name evaluator) -  (let ((module (or (and (list? module-name) -                         (resolve-module module-name)) -                    (current-module))) -        (evaluator (lambda (f m) -                     (call-with-values (lambda () (evaluator f m)) list))) -        (result #f) -        (captured-stack #f) -        (error #f)) +(define (ge:compile form module-name) +  (let* ((module (or (and (list? module-name) +                          (resolve-module module-name)) +                     (current-module))) +         (result #f) +         (captured-stack #f) +         (error #f) +         (ev (lambda () +               (save-module-excursion +                (lambda () +                  (set-current-module module) +                  (set! result (call-with-values +                                   (lambda () (compile form)) +                                 (lambda vs +                                   (map (lambda (v) +                                          (with-output-to-string +                                            (lambda () (write v)))) +                                        vs)))))))))      (let ((output             (with-output-to-string               (lambda () -               (set! result -                     (catch #t -                       (lambda () -                         (start-stack 'geiser-eval (evaluator form module))) -                       (lambda args -                         (set! error #t) -                         (apply handle-error captured-stack args)) -                       (lambda args -                         (set! captured-stack (make-stack #t 1 13))))))))) +               (catch #t +                 (lambda () (start-stack 'geiser-eval (ev))) +                 (lambda args +                   (set! error #t) +                   (apply handle-error captured-stack args)) +                 (lambda args +                   (set! captured-stack (make-stack #t 2 15))))))))        (write `(,(if error result (cons 'result result))                 (output . ,output)))        (newline)))) -(define (eval-compile form module) -  (save-module-excursion -   (lambda () -     (set-current-module module) -     (compile form)))) - -(define (ge:eval form module-name) -  (evaluate form module-name eval)) - -(define (ge:compile form module-name) -  (evaluate form module-name eval-compile)) +(define ge:eval ge:compile)  (define (ge:compile-file path) -  "Compile and load file, given its full @var{path}." -  (evaluate `(and (compile-file ,path) -                  (load-compiled ,(compiled-file-name path))) -            '(system base compile) -            eval-compile)) +  "Compile a file, given its full @var{path}." +  (ge:compile `(compile-and-load ,path) '(geiser evaluation)))  (define (ge:load-file path)    "Load file, given its full @var{path}." -  (evaluate `(load ,path) #f eval)) +  (ge:compile `(load-compiled ,(compiled-file-name path)) '(geiser evaluation)))  (define (ge:macroexpand form . all)    (let ((all (and (not (null? all)) (car all)))) diff --git a/scheme/guile/geiser/xref.scm b/scheme/guile/geiser/xref.scm index f00f724..2336fb2 100644 --- a/scheme/guile/geiser/xref.scm +++ b/scheme/guile/geiser/xref.scm @@ -28,7 +28,8 @@    #:export (symbol-location              generic-methods              callers -            callees) +            callees +            find-file)    #:use-module (geiser utils)    #:use-module (geiser modules)    #:use-module (geiser doc) @@ -90,4 +91,10 @@      (and obj           (map procedure-xref (procedure-callees obj))))) +(define (find-file path) +  (let loop ((dirs %load-path)) +    (if (null? dirs) #f +        (let ((candidate (string-append (car dirs) "/" path))) +          (if (file-exists? candidate) candidate (loop (cdr dirs))))))) +  ;;; xref.scm ends here | 
