1 {-# LANGUAGE FlexibleContexts #-}
3 {-# LANGUAGE MultiParamTypeClasses #-}
4 {-# LANGUAGE OverloadedStrings #-}
5 {-# LANGUAGE ScopedTypeVariables #-}
6 {-# LANGUAGE TypeFamilies #-}
7 module Language.Symantic.Type.Map where
9 import Data.Map.Strict as Map
10 import Data.Maybe (isJust)
11 import Data.Type.Equality ((:~:)(Refl))
13 import Language.Symantic.Type.Common
17 data Type_Map root h where
21 -> Type_Map root (Map h_k h_a)
23 type instance Root_of_Type (Type_Map root) = root
24 type instance Error_of_Type ast (Type_Map root) = No_Error_Type
28 Eq_Type (Type_Map root) where
29 eq_type (Type_Map k1 a1) (Type_Map k2 a2)
30 | Just Refl <- k1 `eq_type` k2
31 , Just Refl <- a1 `eq_type` a2
36 Eq (Type_Map root h) where
37 x == y = isJust $ eq_type x y
38 instance -- String_from_Type
39 String_from_Type root =>
40 String_from_Type (Type_Map root) where
41 string_from_type (Type_Map k a) =
42 "Map (" ++ string_from_type k ++ ")"
43 ++ " (" ++ string_from_type a ++ ")"
45 String_from_Type root =>
46 Show (Type_Map root h) where
47 show = string_from_type
49 -- | Convenient alias to include a 'Type_Map' within a type.
51 :: (Type_Root_Lift Type_Map root, Ord h_k)
55 type_map k a = type_root_lift (Type_Map k a)