This is the mail archive of the guile-emacs@sourceware.cygnus.com mailing list for the Guile project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]

Re: Emacs Scheme interface


Keisuke Nishida <kxn30@po.cwru.edu> writes:

> I think everything in Scheme should be organized in the way of Scheme,
> including the naming style.

Naming style -- do you mean the question marks, or something else?

> Does Guile have any macro like `save-excursion'?

Actually, Guile has `save-module-excursion' which takes a thunk
parameter.  So I suppose `save-excursion' should take a thunk,
and the convenient macro (if we provide one) should be called
something else like `begin-save-excursion'.

> Maybe the new (emacs macro) should provide those convenient macros?

That would be convenient.  :-)

Here is a mostly tested implementation.  I did not commit this to
CVS because I suppose this shouldn't be in 0.3 yet.

;;; (emacs emacs)

(define (lisp-macro->procedure lisp-macro)
  "Return a procedure which calls LISP-MACRO.
The returned procedure accepts one argument, THUNK.  It calls
LISP-MACRO with one argument: a form which comes back to Scheme and
calls THUNK."
  (lambda (thunk)
    "Call some Lisp macro, passing it a form which calls THUNK."
    (lisp-eval `(,lisp-macro (scheme-eval '(',thunk))))))

(define (lisp-macro-1->procedure lisp-macro)
  "Return a procedure which calls LISP-MACRO.
The returned procedure accepts two arguments, PARAM and THUNK.  It
calls LISP-MACRO with two arguments: the quoted PARAM, and a form
which comes back to Scheme and calls THUNK."
  (lambda (param thunk)
    "Call some Lisp macro, passing it PARAM and a form which calls THUNK."
    (lisp-eval `(,lisp-macro ',param (scheme-eval '(',thunk))))))

;;; (emacs import)

(define-public save-excursion
  (lisp-macro->procedure 'save-excursion))

(define-public with-current-buffer
  (lisp-macro-1->procedure 'with-current-buffer))

;;; (emacs macro)

(define-macro (define-begin-macro macro-name procedure)
  "Define a macro MACRO-NAME which calls PROCEDURE with a thunk.
The thunk evaluates the macro arguments when called.
MACRO-NAME is an unevaluated symbol.  PROCEDURE is any expression
evaluating to a procedure, such as a variable.  It is evaluated
where `define-begin-macro' is called."
  `(define-macro ,macro-name
     (let ((procedure-val ,procedure))
       (lambda body
	 "Call some procedure with a thunk which evaluates BODY."
	 `(',procedure-val (lambda () ,@body))))))

(define-macro (define-begin-macro-1 macro-name procedure)
  "Define a macro MACRO-NAME which calls PROCEDURE with a parameter and a thunk.
The thunk evaluates the other arguments when called.
MACRO-NAME is an unevaluated symbol.  PROCEDURE is any expression
evaluating to a procedure, such as a variable.  It is evaluated
where `define-begin-macro-1' is called."
  `(define-macro ,macro-name
     (let ((procedure-val ,procedure))
       (lambda (param . body)
	 "Call some procedure with PARAM and a thunk which evaluates BODY."
	 `(',procedure-val ,param (lambda () ,@body))))))

(define-macro (define-public-begin-macro macro-name procedure)
  "Like `define-begin-macro', but also export MACRO-NAME."
  `(begin
     (define-begin-macro ,macro-name ,procedure)
     (export ,macro-name)))

(define-macro (define-public-begin-macro-1 macro-name procedure)
  "Like `define-begin-macro-1', but also export MACRO-NAME."
  `(begin
     (define-begin-macro-1 ,macro-name ,procedure)
     (export ,macro-name)))

(define-public-begin-macro begin-save-excursion save-excursion)

(define-public-begin-macro-1 begin-with-current-buffer with-current-buffer)

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]