Skip to content

Instantly share code, notes, and snippets.

@justjoheinz
Created January 30, 2019 09:38
Show Gist options
  • Save justjoheinz/de294fb184c75cb305eb00c91bfa96dc to your computer and use it in GitHub Desktop.
Save justjoheinz/de294fb184c75cb305eb00c91bfa96dc to your computer and use it in GitHub Desktop.
import Data.Vect
import Data.Fin
%default total
%access public export
data Ty: Type where
TyBool: Ty
TyInt: Ty
TyFun: Ty -> Ty -> Ty
interpTy: Ty -> Type
interpTy TyBool = Bool
interpTy TyInt = Integer
interpTy (TyFun x y) = interpTy x -> interpTy y
using (G:Vect n Ty)
data HasType : (i : Fin n) -> Vect n Ty -> Ty -> Type where
Stop : HasType FZ (t :: G) t
Pop : HasType k G t -> HasType (FS k) (u :: G) t
data Expr : Vect n Ty -> Ty -> Type where
Var : HasType i G t -> Expr G t
Val : (x : Integer) -> Expr G TyInt
Lam : Expr (a :: G) t -> Expr G (TyFun a t)
App : Expr G (TyFun a t) -> Expr G a -> Expr G t
Op : (interpTy a -> interpTy b -> interpTy c) ->
Expr G a -> Expr G b -> Expr G c
If : Expr G TyBool ->
Lazy (Expr G a) ->
Lazy (Expr G a) -> Expr G a
data Env : Vect n Ty -> Type where
Nil : Env Nil
(::) : interpTy a -> Env G -> Env (a :: G)
lookup : HasType i G t -> Env G -> interpTy t
lookup Stop (x :: xs) = x
lookup (Pop k) (x :: xs) = lookup k xs
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment