diff options
author | Greg Brown <greg.brown01@ed.ac.uk> | 2024-08-14 15:06:30 +0100 |
---|---|---|
committer | Greg Brown <greg.brown01@ed.ac.uk> | 2024-08-14 19:04:40 +0100 |
commit | 18547332435c0e33106763daa9d8532c9df09115 (patch) | |
tree | da6a36d970007f621ea63250c7920fe12a21882d /src/Inky/Env.idr | |
parent | 942249a4aab941419c1519ab0e2990a727bf7778 (diff) |
Define environments over worlds.
Diffstat (limited to 'src/Inky/Env.idr')
-rw-r--r-- | src/Inky/Env.idr | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/Inky/Env.idr b/src/Inky/Env.idr new file mode 100644 index 0000000..174b681 --- /dev/null +++ b/src/Inky/Env.idr @@ -0,0 +1,30 @@ +module Inky.Env + +import Control.Relation +import Inky.Binding + +infix 2 :~ + +public export +record Assoc (0 a : Type) where + constructor (:~) + binder : Binder + value : a + +public export +data PartialEnv : Type -> World -> World -> Type where + Lin : PartialEnv a w w + (:<) : PartialEnv a w v -> (x : Assoc a) -> PartialEnv a (w :< x.binder) v + +public export +Env : Type -> World -> Type +Env a w = PartialEnv a w [<] + +public export +partialLookup : PartialEnv a w v -> Name w -> Either (Name v) a +partialLookup [<] = Left +partialLookup (env :< (x :~ v)) = stripWith (Right v) (partialLookup env) + +public export +lookup : Env a w -> Name w -> a +lookup = either absurd id .: partialLookup |