mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-15 18:20:42 +02:00
method is a defmacro.
* oop/goops.scm (method): Make into a defmacro.
This commit is contained in:
parent
56f952c682
commit
02e720ff76
1 changed files with 7 additions and 11 deletions
|
@ -467,7 +467,7 @@
|
|||
#:specializers specializers
|
||||
#:procedure procedure))
|
||||
|
||||
(define method
|
||||
(define-macro (method args . body)
|
||||
(letrec ((specializers
|
||||
(lambda (ls)
|
||||
(cond ((null? ls) (list (list 'quote '())))
|
||||
|
@ -482,16 +482,12 @@
|
|||
(cons (if (pair? (car ls)) (caar ls) (car ls))
|
||||
(formals (cdr ls)))
|
||||
ls))))
|
||||
(procedure->memoizing-macro
|
||||
(lambda (exp env)
|
||||
(let ((args (cadr exp))
|
||||
(body (cddr exp)))
|
||||
`(make <method>
|
||||
#:specializers (cons* ,@(specializers args))
|
||||
#:procedure (lambda ,(formals args)
|
||||
,@(if (null? body)
|
||||
(list *unspecified*)
|
||||
body))))))))
|
||||
`(make <method>
|
||||
#:specializers (cons* ,@(specializers args))
|
||||
#:procedure (lambda ,(formals args)
|
||||
,@(if (null? body)
|
||||
(list *unspecified*)
|
||||
body)))))
|
||||
|
||||
;;;
|
||||
;;; {add-method!}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue