-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathSyntax.v
56 lines (52 loc) · 2.11 KB
/
Syntax.v
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
(*! Frontend | Untyped syntax !*)
Require Export Koika.Common Koika.Primitives Koika.Types Koika.ErrorReporting.
Section Syntax.
Context {pos_t var_t rule_name_t fn_name_t: Type}.
Class Lift {from to: Type} := lift: from -> to.
Hint Mode Lift - ! : typeclass_instances.
Inductive uaction {reg_t ext_fn_t} :=
| UError (err: error pos_t var_t fn_name_t)
| UFail (tau: type)
| UVar (var: var_t)
| UConst {tau: type} (cst: type_denote tau)
| UAssign (v: var_t) (ex: uaction)
| USeq (a1 a2: uaction)
| UBind (v: var_t) (ex: uaction) (body: uaction)
| UIf (cond: uaction) (tbranch: uaction) (fbranch: uaction)
| URead (port: Port) (idx: reg_t)
| UWrite (port: Port) (idx: reg_t) (value: uaction)
| UUnop (ufn1: PrimUntyped.ufn1) (arg1: uaction)
| UBinop (ufn2: PrimUntyped.ufn2) (arg1: uaction) (arg2: uaction)
| UExternalCall (ufn: ext_fn_t) (arg: uaction)
| UInternalCall (ufn: InternalFunction var_t fn_name_t uaction) (args: list uaction)
| UAPos (p: pos_t) (e: uaction)
| USugar (s: usugar)
with usugar {reg_t ext_fn_t} :=
| UErrorInAst
| USkip
| UConstBits {sz} (bs: bits sz)
| UConstString (s: string)
| UConstEnum (sig: enum_sig) (cst: string)
| UProgn (aa: list uaction)
| ULet (bindings: list (var_t * uaction)) (body: uaction)
| UWhen (cond: uaction) (body: uaction)
| USwitch (var: uaction)
(default: uaction)
(branches: list (uaction * uaction))
| UStructInit (sig: struct_sig) (fields: list (string * uaction))
| UArrayInit (tau: type) (elements: list uaction)
| UCallModule {module_reg_t module_ext_fn_t: Type}
(fR: module_reg_t -> reg_t)
(fSigma: @Lift module_ext_fn_t ext_fn_t)
(fn: InternalFunction var_t fn_name_t (@uaction module_reg_t module_ext_fn_t))
(args: list uaction).
Inductive scheduler :=
| Done
| Cons (r: rule_name_t) (s: scheduler)
| Try (r: rule_name_t) (s1 s2: scheduler)
| SPos (p: pos_t) (s: scheduler).
End Syntax.
Arguments Lift: clear implicits.
Arguments usugar : clear implicits.
Arguments uaction : clear implicits.
Arguments scheduler : clear implicits.