mirror of
https://github.com/github/semantic.git
synced 2025-01-04 05:27:08 +03:00
Port Timeout effect to FE1.
This commit is contained in:
parent
d53a7bafdd
commit
9a419428af
@ -8,8 +8,8 @@ module Semantic.Timeout
|
|||||||
, Duration(..)
|
, Duration(..)
|
||||||
) where
|
) where
|
||||||
|
|
||||||
import Control.Effect.Carrier
|
import Control.Algebra
|
||||||
import Control.Effect.Reader
|
import Control.Carrier.Reader
|
||||||
import Control.Monad.IO.Class
|
import Control.Monad.IO.Class
|
||||||
import Control.Monad.IO.Unlift
|
import Control.Monad.IO.Unlift
|
||||||
import Data.Duration
|
import Data.Duration
|
||||||
@ -18,7 +18,7 @@ import qualified System.Timeout as System
|
|||||||
-- | Run an action with a timeout. Returns 'Nothing' when no result is available
|
-- | Run an action with a timeout. Returns 'Nothing' when no result is available
|
||||||
-- within the specified duration. Uses 'System.Timeout.timeout' so all caveats
|
-- within the specified duration. Uses 'System.Timeout.timeout' so all caveats
|
||||||
-- about not operating over FFI boundaries apply.
|
-- about not operating over FFI boundaries apply.
|
||||||
timeout :: (Member Timeout sig, Carrier sig m) => Duration -> m output -> m (Maybe output)
|
timeout :: Has Timeout sig m => Duration -> m output -> m (Maybe output)
|
||||||
timeout n = send . flip (Timeout n) pure
|
timeout n = send . flip (Timeout n) pure
|
||||||
|
|
||||||
-- | 'Timeout' effects run other effects, aborting them if they exceed the
|
-- | 'Timeout' effects run other effects, aborting them if they exceed the
|
||||||
@ -32,7 +32,7 @@ instance HFunctor Timeout where
|
|||||||
hmap f (Timeout n task k) = Timeout n (f task) (f . k)
|
hmap f (Timeout n task k) = Timeout n (f task) (f . k)
|
||||||
|
|
||||||
instance Effect Timeout where
|
instance Effect Timeout where
|
||||||
handle state handler (Timeout n task k) = Timeout n (handler (task <$ state)) (handler . maybe (k Nothing <$ state) (fmap (k . Just)))
|
thread state handler (Timeout n task k) = Timeout n (handler (task <$ state)) (handler . maybe (k Nothing <$ state) (fmap (k . Just)))
|
||||||
|
|
||||||
-- | Evaulate a 'Timeout' effect.
|
-- | Evaulate a 'Timeout' effect.
|
||||||
runTimeout :: (forall x . m x -> IO x)
|
runTimeout :: (forall x . m x -> IO x)
|
||||||
@ -59,8 +59,8 @@ instance MonadUnliftIO m => MonadUnliftIO (TimeoutC m) where
|
|||||||
askUnliftIO = TimeoutC . ReaderC $ \(Handler h) ->
|
askUnliftIO = TimeoutC . ReaderC $ \(Handler h) ->
|
||||||
withUnliftIO $ \u -> pure (UnliftIO $ \r -> unliftIO u (runTimeout h r))
|
withUnliftIO $ \u -> pure (UnliftIO $ \r -> unliftIO u (runTimeout h r))
|
||||||
|
|
||||||
instance (Carrier sig m, MonadIO m) => Carrier (Timeout :+: sig) (TimeoutC m) where
|
instance (Algebra sig m, MonadIO m) => Algebra (Timeout :+: sig) (TimeoutC m) where
|
||||||
eff (L (Timeout n task k)) = do
|
alg (L (Timeout n task k)) = do
|
||||||
handler <- TimeoutC ask
|
handler <- TimeoutC ask
|
||||||
liftIO (System.timeout (toMicroseconds n) (runHandler handler task)) >>= k
|
liftIO (System.timeout (toMicroseconds n) (runHandler handler task)) >>= k
|
||||||
eff (R other) = TimeoutC (eff (R (handleCoercible other)))
|
alg (R other) = TimeoutC (alg (R (handleCoercible other)))
|
||||||
|
Loading…
Reference in New Issue
Block a user