ikarus/src/libguardians.ss

24 lines
667 B
Scheme
Raw Normal View History

2006-12-19 12:15:36 -05:00
;;; The procedure make-guardian is coped en verbatim
;;; from Dybvig et al. Guardians paper.
2006-12-19 12:15:36 -05:00
(let ()
(define make-guardian
(lambda ()
(let ([tc
(let ([x (cons #f #f)])
(cons x x))])
(case-lambda
[()
(and (not (eq? (car tc) (cdr tc)))
(let ([x (car tc)])
(let ([y (car x)])
(set-car! tc (cdr x))
(set-car! x #f)
(set-cdr! x #f)
y)))]
[(obj)
(foreign-call "ikrt_register_guardian" tc obj)
(void)]))))
(primitive-set! 'make-guardian make-guardian))