blob: 67ac4ae9b220271ec8b5abc1c3bc03eb48768fa1 (
plain)
| 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
 | open Bwd
type t = Data.value =
  | Neutral of ne
  | Pi of t * clo
  | Lam of clo
  | Sg of t * clo
  | Pair of t * t
  | Type
  | Bool
  | True
  | False
and ne = Data.ne
and ne_head = Data.ne_head = Var of int (* De Bruijn levels *)
and frm = Data.frm =
  | App of t
  | Fst
  | Snd
  | BoolElim of {
      cmot: clo;
      vtrue: t;
      vfalse: t;
    }
and env = Data.env
and clo = Data.clo = Clo of { body : Data.syn; env : env }
let var i = Neutral (Var i, Bwd.Emp)
 |