123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- (use-modules (ice-9 regex))
- (use-modules (ice-9 channel))
- (use-modules (ice-9 session))
- (use-modules (ice-9 documentation))
- (define (emacs-lisp-channel)
- (define (native-type? x)
- (or (integer? x) (symbol? x) (string? x) (pair? x) (vector? x)))
- (define (emacs-lisp-print ch val)
- (cond
- ((unspecified? val))
- ((eq? val #t) (channel-print-value ch 't))
- ((or (eq? val #f) (null? val)) (channel-print-value ch 'nil))
- ((native-type? val) (channel-print-value ch val))
- (else (channel-print-token ch val))))
- (channel-open (make-object-channel emacs-lisp-print)))
- (define (emacs-scheme-channel)
- (define (print ch val) (channel-print-value ch (object->string val)))
- (channel-open (make-object-channel print)))
- (define (guile-emacs-export-procedure name proc docs)
- (define (procedure-args proc)
- (let ((source (procedure-source proc)))
- (if source
-
- (let loop ((formals (cadr source)))
- (cond
- ((null? formals) '())
- ((symbol? formals) `(&rest ,formals))
- (else (cons (car formals) (loop (cdr formals))))))
-
- (let* ((arity (procedure-minimum-arity proc))
- (nreqs (car arity))
- (nopts (cadr arity))
- (restp (caddr arity)))
- (define (nsyms n)
- (if (= n 0) '() (cons (gensym "a") (nsyms (1- n)))))
- (append! (nsyms nreqs)
- (if (> nopts 0) (cons '&optional (nsyms nopts)) '())
- (if restp (cons '&rest (nsyms 1)) '()))))))
- (define (procedure-call name args)
- (let ((restp (memq '&rest args))
- (args (delq '&rest (delq '&optional args))))
- (if restp
- `('apply ',name ,@args)
- `(',name ,@args))))
- (let ((args (procedure-args proc))
- (docs (and docs (object-documentation proc))))
- `(defun ,name ,args
- ,@(if docs (list docs) '())
- (guile-lisp-flat-eval ,@(procedure-call (procedure-name proc) args)))))
- (define (guile-emacs-export proc-name func-name docs)
- (let ((proc (module-ref (current-module) proc-name)))
- (guile-emacs-export-procedure func-name proc docs)))
- (define (guile-emacs-export-procedures module-name docs)
- (define (module-public-procedures name)
- (hash-fold (lambda (s v d)
- (let ((val (variable-ref v)))
- (if (procedure? val) (acons s val d) d)))
- '() (module-obarray (resolve-interface name))))
- `(progn ,@(map (lambda (n+p)
- (guile-emacs-export-procedure (car n+p) (cdr n+p) docs))
- (module-public-procedures module-name))))
- (define (guile-emacs-complete-alist str)
- (sort! (apropos-fold (lambda (module name val data)
- (cons (list (symbol->string name)
- (cond ((procedure? val) " <p>")
- ((macro? val) " <m>")
- (else "")))
- data))
- '() (string-append "^" (regexp-quote str))
- apropos-fold-all)
- (lambda (p1 p2) (string<? (car p1) (car p2)))))
- (define (guile-emacs-apropos regexp)
- (with-output-to-string (lambda () (apropos regexp))))
- (define (guile-emacs-describe sym)
- (object-documentation (eval sym (current-module))))
- (define object->string
- (if (defined? 'object->string)
- object->string
- (lambda (x) (format #f "~S" x))))
|