File: assoc-list-impl.thi

package info (click to toggle)
theme-d 7.2.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 21,036 kB
  • sloc: lisp: 9,625; sh: 5,321; makefile: 715; ansic: 477
file content (42 lines) | stat: -rw-r--r-- 1,204 bytes parent folder | download | duplicates (3)
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
38
39
40
41
42
;; -*-theme-*-

;; Copyright (C) 2015  Tommi Höynälänmaa
;; Distributed under GNU Lesser General Public License version 3,
;; see file doc/LGPL-3.

(define-interface (examples assoc-list-impl)


  (import (standard-library core)
	  (standard-library singleton))

  (define-param-class :assoc-list
    (parameters %key %value)
    (constructor-access module)
    (construct
     ((l-contents1 (:uniform-list (:pair %key (:singleton %value))))
      (eq-pred1? (:procedure (%key %key) <boolean> pure))))
    (fields
     (l-contents (:uniform-list (:pair %key (:singleton %value)))
		 module module l-contents1)
     (eq-pred? (:procedure (%key %key) <boolean> pure) module module
	       eq-pred1?)))
     
  (declare-method make-assoc-list
		  (:param-proc (%key %value)
			       ((:procedure (%key %key) <boolean> pure)
				%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)))