mirror of
https://github.com/github/semantic.git
synced 2025-01-03 13:02:37 +03:00
Interpret TaskF using a helper.
This commit is contained in:
parent
a71c3ffaea
commit
0a587f0949
@ -1,4 +1,4 @@
|
|||||||
{-# LANGUAGE GADTs, TypeOperators, UndecidableInstances #-}
|
{-# LANGUAGE GADTs, RankNTypes, TypeOperators, UndecidableInstances #-}
|
||||||
{-# OPTIONS_GHC -fno-warn-orphans #-}
|
{-# OPTIONS_GHC -fno-warn-orphans #-}
|
||||||
module Semantic.Task
|
module Semantic.Task
|
||||||
( Task
|
( Task
|
||||||
@ -183,21 +183,21 @@ runTaskWithOptions options task = do
|
|||||||
run' :: Task a -> IO (Either SomeException a)
|
run' :: Task a -> IO (Either SomeException a)
|
||||||
run' = runM . runError . go
|
run' = runM . runError . go
|
||||||
go :: Task a -> Eff '[Exc SomeException, IO] a
|
go :: Task a -> Eff '[Exc SomeException, IO] a
|
||||||
go = relay pure (\ task yield -> case task of
|
go = interpret (\ task -> case task of
|
||||||
ReadBlobs (Left handle) -> rethrowing (IO.readBlobsFromHandle handle) >>= yield
|
ReadBlobs (Left handle) -> rethrowing (IO.readBlobsFromHandle handle)
|
||||||
ReadBlobs (Right paths@[(path, Nothing)]) -> rethrowing (IO.isDirectory path >>= bool (IO.readBlobsFromPaths paths) (IO.readBlobsFromDir path)) >>= yield
|
ReadBlobs (Right paths@[(path, Nothing)]) -> rethrowing (IO.isDirectory path >>= bool (IO.readBlobsFromPaths paths) (IO.readBlobsFromDir path))
|
||||||
ReadBlobs (Right paths) -> rethrowing (IO.readBlobsFromPaths paths) >>= yield
|
ReadBlobs (Right paths) -> rethrowing (IO.readBlobsFromPaths paths)
|
||||||
ReadBlobPairs source -> rethrowing (either IO.readBlobPairsFromHandle (traverse (runBothWith IO.readFilePair)) source) >>= yield
|
ReadBlobPairs source -> rethrowing (either IO.readBlobPairsFromHandle (traverse (runBothWith IO.readFilePair)) source)
|
||||||
WriteToOutput destination contents -> liftIO (either B.hPutStr B.writeFile destination contents) >>= yield
|
WriteToOutput destination contents -> liftIO (either B.hPutStr B.writeFile destination contents)
|
||||||
WriteLog level message pairs -> queueLogMessage logger level message pairs >>= yield
|
WriteLog level message pairs -> queueLogMessage logger level message pairs
|
||||||
WriteStat stat -> liftIO (queue statter stat) >>= yield
|
WriteStat stat -> liftIO (queue statter stat)
|
||||||
Time statName tags task -> withTiming (liftIO . queue statter) statName tags (go task) >>= yield
|
Time statName tags task -> withTiming (liftIO . queue statter) statName tags (go task)
|
||||||
Parse parser blob -> go (runParser options blob parser) >>= yield
|
Parse parser blob -> go (runParser options blob parser)
|
||||||
Decorate algebra term -> pure (decoratorWithAlgebra algebra term) >>= yield
|
Decorate algebra term -> pure (decoratorWithAlgebra algebra term)
|
||||||
Semantic.Task.Diff differ term1 term2 -> pure (differ term1 term2) >>= yield
|
Semantic.Task.Diff differ term1 term2 -> pure (differ term1 term2)
|
||||||
Render renderer input -> pure (renderer input) >>= yield
|
Render renderer input -> pure (renderer input)
|
||||||
Distribute tasks -> liftIO (Async.mapConcurrently run' tasks) >>= either throwError yield . sequenceA . withStrategy (parTraversable (parTraversable rseq))
|
Distribute tasks -> liftIO (Async.mapConcurrently run' tasks) >>= either throwError pure . sequenceA . withStrategy (parTraversable (parTraversable rseq))
|
||||||
Bidistribute tasks -> liftIO (Async.runConcurrently (bitraverse (Async.Concurrently . run') (Async.Concurrently . run') tasks)) >>= either throwError yield . bisequenceA . withStrategy (parBitraversable (parTraversable rseq) (parTraversable rseq)))
|
Bidistribute tasks -> liftIO (Async.runConcurrently (bitraverse (Async.Concurrently . run') (Async.Concurrently . run') tasks)) >>= either throwError pure . bisequenceA . withStrategy (parBitraversable (parTraversable rseq) (parTraversable rseq)))
|
||||||
|
|
||||||
parBitraversable :: Bitraversable t => Strategy a -> Strategy b -> Strategy (t a b)
|
parBitraversable :: Bitraversable t => Strategy a -> Strategy b -> Strategy (t a b)
|
||||||
parBitraversable strat1 strat2 = bitraverse (rparWith strat1) (rparWith strat2)
|
parBitraversable strat1 strat2 = bitraverse (rparWith strat1) (rparWith strat2)
|
||||||
@ -262,5 +262,9 @@ rethrowing :: ( Member (Exc SomeException) r
|
|||||||
-> Eff r a
|
-> Eff r a
|
||||||
rethrowing m = catchException (liftIO m) (throwError . toException @SomeException)
|
rethrowing m = catchException (liftIO m) (throwError . toException @SomeException)
|
||||||
|
|
||||||
|
-- | Handle the topmost effect by interpreting it into the underlying effects.
|
||||||
|
interpret :: (forall a. eff a -> Eff effs a) -> Eff (eff ': effs) a -> Eff effs a
|
||||||
|
interpret f = relay pure (\ eff yield -> f eff >>= yield)
|
||||||
|
|
||||||
instance Member IO effs => MonadIO (Eff effs) where
|
instance Member IO effs => MonadIO (Eff effs) where
|
||||||
liftIO = send
|
liftIO = send
|
||||||
|
Loading…
Reference in New Issue
Block a user