1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
|
;; -*-theme-*-
;; Copyright (C) 2015 Tommi Höynälänmaa
;; Distributed under GNU General Public License version 3,
;; see file doc/GPL-3.
;; Expected results: compilation OK
(define-interface (tests test365)
(import (standard-library core)
(standard-library singleton))
(define-param-class :assoc-list
(parameters %key %value)
(constructor-access module)
(fields
(l-contents (:uniform-list (:pair %key (:singleton %value)))
module module)))
(declare make-assoc-list
(:param-proc (%key %value) ()
(:assoc-list %key %value) pure))
(declare-static-virtual-method gen-assoc
(:param-proc (%key %value)
((:assoc-list %key %value) %key)
(:maybe %value)
pure))
(declare-static-virtual-method gen-assoc-set!
(:param-proc (%key %value)
((:assoc-list %key %value) %key %value)
<none>
nonpure)))
|