-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSTConvert.hs
30 lines (26 loc) · 1.06 KB
/
STConvert.hs
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
{-# LANGUAGE GADTs #-}
-- | Convert a source-language program to a target-language program without
-- changing semantics. This is always possible because the target language is a
-- superset of the source language.
module STConvert (
stConvert,
) where
import SourceLanguage
import TargetLanguage
stConvert :: STerm env a -> TTerm env a
stConvert (SVar i) = Var i
stConvert (SLambda e) = Lambda (stConvert e)
stConvert (SLet rhs e) = Let (stConvert rhs) (stConvert e)
stConvert (SApp f a) = App (stConvert f) (stConvert a)
stConvert SUnit = Unit
stConvert (SPair a b) = Pair (stConvert a) (stConvert b)
stConvert (SFst p) = Fst (stConvert p)
stConvert (SSnd p) = Snd (stConvert p)
stConvert (SInl p) = Inl (stConvert p)
stConvert (SInr p) = Inr (stConvert p)
stConvert (SCase e a b) = Case (stConvert e) (stConvert a) (stConvert b)
stConvert (SOp op a) = Op op (stConvert a)
stConvert (SMap a b) = Map (stConvert a) (stConvert b)
stConvert (SMap1 a b) = Map1 (stConvert a) (stConvert b)
stConvert (SReplicate x) = Replicate (stConvert x)
stConvert (SSum x) = Sum (stConvert x)