mirror of
https://github.com/github/semantic.git
synced 2025-01-04 21:47:07 +03:00
Define assign for types.
This commit is contained in:
parent
b861543d06
commit
5dbba8a92d
@ -68,6 +68,11 @@ lookup' name = Map.lookup name <$> ask
|
||||
allocType :: Applicative (m Name effects) => Name -> m Name effects Name
|
||||
allocType = pure
|
||||
|
||||
assignType :: (Effectful (m location), Member (State (Map location (Set Type))) effects, Monad (m location effects), Ord location, Show location) => location -> Type -> m location effects ()
|
||||
assignType addr value = do
|
||||
cell <- gets (Map.lookup addr) >>= maybeM (pure (Set.empty))
|
||||
modify' (Map.insert addr (Set.insert value cell))
|
||||
|
||||
derefType :: (Alternative (m location effects), Effectful (m location), Members '[Fail, NonDet, State (Map location (Set Type))] effects, Monad (m location effects), Ord location, Show location) => location -> m location effects (Maybe Type)
|
||||
derefType loc = do
|
||||
cell <- gets (Map.lookup loc) >>= maybeM (raiseEff (fail ("unallocated address: " <> show loc)))
|
||||
|
Loading…
Reference in New Issue
Block a user