1
1
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:
Rob Rix 2018-04-03 17:54:29 -04:00
parent a71c3ffaea
commit 0a587f0949

View File

@ -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