1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
|
;; -*-theme-*-
;; Copyright (C) 2015-2018, 2021 Tommi Höynälänmaa
;; Distributed under GNU Lesser General Public License version 3,
;; see file doc/LGPL-3.
(define-body (standard-library singleton)
(define-param-method make-singleton (%element)
(((obj %element)) (:singleton %element) pure)
(create (:singleton %element) obj))
(define-param-method singleton-get-element (%element)
(((sgt (:singleton %element))) %element pure)
(field-ref sgt 'obj))
(define-param-method singleton-set-element! (%element)
(((sgt (:singleton %element)) (obj %element))
<none> nonpure)
(field-set! sgt 'obj obj)))
|