1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-06-20 02:30:23 +02:00

New files for Guile Emacs support.

This commit is contained in:
Keisuke Nishida 2001-04-25 12:15:24 +00:00
parent 253081cf6a
commit 2d857fb1ac
6 changed files with 741 additions and 0 deletions

127
emacs/guile-emacs.scm Normal file
View file

@ -0,0 +1,127 @@
;;; guile-emacs.scm --- Guile Emacs interface
;; Copyright (C) 2001 Keisuke Nishida <kxn30@po.cwru.edu>
;; GNU Emacs is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.
;; GNU Emacs is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs; see the file COPYING. If not, write to the
;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
;; Boston, MA 02111-1307, USA.
;;; Code:
(use-modules (ice-9 regex))
(use-modules (ice-9 channel))
(use-modules (ice-9 session))
(use-modules (ice-9 documentation))
;;;
;;; Emacs Lisp channel
;;;
(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)))
;;;
;;; Scheme channel
;;;
(define (emacs-scheme-channel)
(define (print ch val) (channel-print-value ch (object->string val)))
(channel-open (make-object-channel print)))
;;;
;;; for guile-import and guile-use-modules
;;;
(define (guile-emacs-export-procedure proc)
(define (procedure-arity proc)
(assq-ref (procedure-properties proc) 'arity))
(define (procedure-args proc)
(let ((source (procedure-source proc)))
(if source
;; formals -> emacs args
(let loop ((formals (cadr source)))
(cond
((null? formals) '())
((symbol? formals) `(&rest ,formals))
(else (cons (car formals) (loop (cdr formals))))))
;; arity -> emacs args
(let* ((arity (procedure-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
`(list* ',name ,@args)
`(list ',name ,@args))))
(let ((name (procedure-name proc))
(args (procedure-args proc))
(docs (object-documentation proc)))
`(defun ,name ,args
,@(if docs (list docs) '())
(guile-lisp-eval ,(procedure-call name args)))))
(define (guile-emacs-export proc-name)
(guile-emacs-export-procedure (module-ref (current-module) proc-name)))
(define (guile-emacs-export-procedures module-name)
(define (module-public-procedures name)
(hash-fold (lambda (s v d)
(let ((val (variable-ref v)))
(if (procedure? val) (cons val d) d)))
'() (module-obarray (resolve-interface name))))
`(progn ,@(map guile-emacs-export-procedure
(module-public-procedures module-name))))
;;;
;;; for guile-emacs-complete-symbol
;;;
(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)))))
;;; guile-emacs.scm ends here