You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ssql/foops.scm

62 lines
2.0 KiB
Scheme

(module foops
(make-object derive-object)
(cond-expand
(chicken-4
(import chicken scheme)
(import-for-syntax chicken)
(use matchable)
(begin-for-syntax
(use srfi-1)))
(chicken-5
(import-for-syntax srfi-1)
(import scheme matchable (chicken syntax))))
(define-for-syntax args-without-self
'(if (and (pair? args) (procedure? (car args)))
(cdr args)
args))
(define-syntax derive-object
(ir-macro-transformer
(lambda (x i c)
(let-optionals (second x)
((ancestor #f)
(self #f)
(super #f))
`(let ((ancestor ,ancestor))
(letrec ((self (lambda args
(if (null? args)
ancestor
(let* ((self* (if (and (pair? args) (procedure? (car args)))
(car args)
self))
,@(if self `((,self self*)) '())
,@(if super
`((,super
(lambda args
(apply ancestor self* args))))
'())
(args ,args-without-self))
(match args
,@(map (lambda (m)
`(((quote ,(caar m)) . ,(cdar m))
. ,(cdr m)))
(cddr x))
(_ (apply ancestor self* args))))))))
self))))))
(define-syntax make-object
(ir-macro-transformer
(lambda (x i r)
`(derive-object
((lambda args
(error "message not understood" ,args-without-self))
. ,(cadr x))
. ,(cddr x)))))
)