mirror of
https://github.com/github/semantic.git
synced 2024-12-24 23:42:31 +03:00
Define a moduleNotFound helper to throw LoadErrors.
This commit is contained in:
parent
662e385b97
commit
ccd7424af7
@ -70,10 +70,8 @@ runModules :: Members '[ Resumable (LoadError location value)
|
||||
-> Evaluator location term value (Modules location value ': effects) a
|
||||
-> Evaluator location term value (Reader (ModuleTable [Module term]) ': effects) a
|
||||
runModules evaluateModule = reinterpretEffect (\ m -> case m of
|
||||
Load name -> askModuleTable >>= maybe notFound (runMerging . foldMap (Merging . evalAndCache)) . ModuleTable.lookup name
|
||||
Load name -> askModuleTable >>= maybe (moduleNotFound name) (runMerging . foldMap (Merging . evalAndCache)) . ModuleTable.lookup name
|
||||
where
|
||||
notFound = throwResumable (LoadError name)
|
||||
|
||||
evalAndCache x = do
|
||||
let mPath = modulePath (moduleInfo x)
|
||||
loading <- loadingModule mPath
|
||||
@ -136,6 +134,9 @@ instance Show1 (LoadError location value) where
|
||||
instance Eq1 (LoadError location value) where
|
||||
liftEq _ (LoadError a) (LoadError b) = a == b
|
||||
|
||||
moduleNotFound :: Member (Resumable (LoadError location value)) effects => ModulePath -> Evaluator location term value effects (Maybe (Environment location value, value))
|
||||
moduleNotFound = throwResumable . LoadError
|
||||
|
||||
runLoadError :: Evaluator location term value (Resumable (LoadError location value) ': effects) a -> Evaluator location term value effects (Either (SomeExc (LoadError location value)) a)
|
||||
runLoadError = raiseHandler runError
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user