Safe Haskell | None |
---|---|
Language | Haskell2010 |
- type NameEnv a = UniqFM a
- mkNameEnv :: [(Name, a)] -> NameEnv a
- emptyNameEnv :: NameEnv a
- isEmptyNameEnv :: NameEnv a -> Bool
- unitNameEnv :: Name -> a -> NameEnv a
- nameEnvElts :: NameEnv a -> [a]
- nameEnvUniqueElts :: NameEnv a -> [(Unique, a)]
- extendNameEnv_C :: (a -> a -> a) -> NameEnv a -> Name -> a -> NameEnv a
- extendNameEnv_Acc :: (a -> b -> b) -> (a -> b) -> NameEnv b -> Name -> a -> NameEnv b
- extendNameEnv :: NameEnv a -> Name -> a -> NameEnv a
- extendNameEnvList :: NameEnv a -> [(Name, a)] -> NameEnv a
- extendNameEnvList_C :: (a -> a -> a) -> NameEnv a -> [(Name, a)] -> NameEnv a
- foldNameEnv :: (a -> b -> b) -> b -> NameEnv a -> b
- filterNameEnv :: (elt -> Bool) -> NameEnv elt -> NameEnv elt
- anyNameEnv :: (elt -> Bool) -> NameEnv elt -> Bool
- plusNameEnv :: NameEnv a -> NameEnv a -> NameEnv a
- plusNameEnv_C :: (a -> a -> a) -> NameEnv a -> NameEnv a -> NameEnv a
- alterNameEnv :: (Maybe a -> Maybe a) -> NameEnv a -> Name -> NameEnv a
- lookupNameEnv :: NameEnv a -> Name -> Maybe a
- lookupNameEnv_NF :: NameEnv a -> Name -> a
- delFromNameEnv :: NameEnv a -> Name -> NameEnv a
- delListFromNameEnv :: NameEnv a -> [Name] -> NameEnv a
- elemNameEnv :: Name -> NameEnv a -> Bool
- mapNameEnv :: (elt1 -> elt2) -> NameEnv elt1 -> NameEnv elt2
- disjointNameEnv :: NameEnv a -> NameEnv a -> Bool
- type DNameEnv a = UniqDFM a
- emptyDNameEnv :: DNameEnv a
- lookupDNameEnv :: DNameEnv a -> Name -> Maybe a
- mapDNameEnv :: (a -> b) -> DNameEnv a -> DNameEnv b
- alterDNameEnv :: (Maybe a -> Maybe a) -> DNameEnv a -> Name -> DNameEnv a
- depAnal :: (node -> [Name]) -> (node -> [Name]) -> [node] -> [SCC node]
Var, Id and TyVar environments (maps)
Manipulating these environments
emptyNameEnv :: NameEnv a Source #
isEmptyNameEnv :: NameEnv a -> Bool Source #
unitNameEnv :: Name -> a -> NameEnv a Source #
nameEnvElts :: NameEnv a -> [a] Source #
nameEnvUniqueElts :: NameEnv a -> [(Unique, a)] Source #
foldNameEnv :: (a -> b -> b) -> b -> NameEnv a -> b Source #
lookupNameEnv_NF :: NameEnv a -> Name -> a Source #
mapNameEnv :: (elt1 -> elt2) -> NameEnv elt1 -> NameEnv elt2 Source #
emptyDNameEnv :: DNameEnv a Source #
mapDNameEnv :: (a -> b) -> DNameEnv a -> DNameEnv b Source #