-
Notifications
You must be signed in to change notification settings - Fork 1
/
Util.sig
100 lines (85 loc) · 5.08 KB
/
Util.sig
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
(* Celf
* Copyright (C) 2008 Anders Schack-Nielsen and Carsten Schürmann
*
* This file is part of Celf.
*
* Celf is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Celf is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Celf. If not, see <http://www.gnu.org/licenses/>.
*)
signature UTIL =
sig
structure ObjAuxDefs : AUX_DEFS where type 'a T.F = 'a Syntax.objF and type T.t = Syntax.obj
structure NfExpObjAuxDefs : AUX_DEFS where type 'a T.F = 'a Syntax.nfExpObjF and type T.t = Syntax.nfExpObj
structure KindRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.kindFF
and type T.t = Syntax.kind and type T.a = Syntax.asyncType
structure AsyncTypeRec : REC3 where type ('a, 'b, 't) T.F = ('a, 'b, 't) Syntax.asyncTypeFF
and type T.t = Syntax.asyncType and type T.a = Syntax.typeSpine
and type T.b = Syntax.syncType
structure TypeSpineRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.typeSpineFF
and type T.t = Syntax.typeSpine and type T.a = Syntax.obj
structure SyncTypeRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.syncTypeFF
and type T.t = Syntax.syncType and type T.a = Syntax.asyncType
structure ObjRec : REC4 where type ('a, 'b, 'c, 't) T.F = ('a, 'b, 'c, 't) Syntax.objFF
and type T.t = Syntax.obj and type T.a = Syntax.asyncType
and type T.b = Syntax.spine and type T.c = Syntax.expObj
structure SpineRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.spineFF
and type T.t = Syntax.spine and type T.a = Syntax.monadObj
structure ExpObjRec : REC4 where type ('a, 'b, 'c, 't) T.F = ('a, 'b, 'c, 't) Syntax.expObjFF
and type T.t = Syntax.expObj and type T.a = Syntax.obj
and type T.b = Syntax.spine and type T.c = Syntax.monadObj
structure MonadObjRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.monadObjFF
and type T.t = Syntax.monadObj and type T.a = Syntax.obj
structure NfKindRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.kindFF
and type T.t = Syntax.nfKind and type T.a = Syntax.nfAsyncType
structure NfAsyncTypeRec : REC3 where type ('a, 'b, 't) T.F = ('a, 'b, 't) Syntax.asyncTypeFF
and type T.t = Syntax.nfAsyncType and type T.a = Syntax.nfTypeSpine
and type T.b = Syntax.nfSyncType
structure NfTypeSpineRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.typeSpineFF
and type T.t = Syntax.nfTypeSpine and type T.a = Syntax.nfObj
structure NfSyncTypeRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.syncTypeFF
and type T.t = Syntax.nfSyncType and type T.a = Syntax.nfAsyncType
structure NfObjRec : REC3 where type ('a, 'b, 't) T.F = ('a, 'b, 't) Syntax.nfObjFF
and type T.t = Syntax.nfObj and type T.a = Syntax.nfSpine
and type T.b = Syntax.nfExpObj
structure NfSpineRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.spineFF
and type T.t = Syntax.nfSpine and type T.a = Syntax.nfMonadObj
structure NfExpObjRec : REC3 where type ('a, 'b, 't) T.F = ('a, 'b, 't) Syntax.nfExpObjFF
and type T.t = Syntax.nfExpObj and type T.a = Syntax.nfSpine
and type T.b = Syntax.nfMonadObj
structure NfMonadObjRec : REC2 where type ('a, 't) T.F = ('a, 't) Syntax.monadObjFF
and type T.t = Syntax.nfMonadObj and type T.a = Syntax.nfObj
val typePrjAbbrev : Syntax.asyncType -> Syntax.asyncType Syntax.asyncTypeF
val nfTypePrjAbbrev : Syntax.nfAsyncType -> Syntax.nfAsyncType Syntax.nfAsyncTypeF
val apxTypePrjAbbrev : Syntax.apxAsyncType -> Syntax.apxAsyncType Syntax.apxAsyncTypeF
val isNil : Syntax.spine -> bool
val objAppKind : ((unit, unit, unit, unit) Syntax.objFF -> unit) -> Syntax.kind -> unit
val objAppType : ((unit, unit, unit, unit) Syntax.objFF -> unit) -> Syntax.asyncType -> unit
val objAppObj : ((unit, unit, unit, unit) Syntax.objFF -> unit) -> Syntax.obj -> unit
val objMapKind : (Syntax.obj -> Syntax.obj Syntax.objF) -> Syntax.kind -> Syntax.kind
val objMapType : (Syntax.obj -> Syntax.obj Syntax.objF) -> Syntax.asyncType -> Syntax.asyncType
val objMapObj : (Syntax.obj -> Syntax.obj Syntax.objF) -> Syntax.obj -> Syntax.obj
val forceNormalizeKind : Syntax.kind -> Syntax.kind
val forceNormalizeType : Syntax.asyncType -> Syntax.asyncType
val forceNormalizeObj : Syntax.obj -> Syntax.obj
val whnfLetSpine : Syntax.expObj -> Syntax.expObj
val removeApxKind : Syntax.kind -> Syntax.kind
val removeApxType : Syntax.asyncType -> Syntax.asyncType
val removeApxSyncType : Syntax.syncType -> Syntax.syncType
val removeApxObj : Syntax.obj -> Syntax.obj
val asyncTypeFromApx : Syntax.apxAsyncType -> Syntax.asyncType
val syncTypeFromApx : Syntax.apxSyncType -> Syntax.syncType
val pat2apxSyncType : ('x, 'ix) Syntax.pattern -> Syntax.apxSyncType
val patternO2T : Syntax.opattern -> Syntax.tpattern
val patternT2O : Syntax.tpattern -> Syntax.opattern
val patternAddDep : Syntax.tpattern * Syntax.tpattern -> Syntax.tpattern
end