summaryrefslogtreecommitdiff
path: root/transfer/examples/pair.tr
blob: 1b70411e894740135507bb49993efbc9001bb1cc (plain)
1
2
3
4
5
6
7
8
9
10
11
Pair : Type -> Type -> Type
Pair A B = sig { p1 : A; p2 : B }

pair : (A:Type) -> (B:Type) -> A -> B -> Pair A B
pair _ _ x y = rec { p1 = x; p2 = y }

fst : (A:Type) -> (B:Type) -> Pair A B -> A
fst _ _ p = case p of Pair _ _ x _ -> x

snd : (A:Type) -> (B:Type) -> Pair A B -> B
snd _ _ p = case p of Pair _ _ x _ -> x