Safe Haskell | Safe-Inferred |
---|---|
Language | GHC2021 |
Polysemy.Conc.Queue
Description
Synopsis
- readMaybe :: Member (Queue d) r => Sem r (Maybe d)
- loop :: Member (Queue d) r => (d -> Sem r ()) -> Sem r ()
- loopOr :: Member (Queue d) r => Sem r Bool -> (d -> Sem r Bool) -> Sem r ()
- tryReadMaybe :: Member (Queue d) r => Sem r (Maybe d)
- data Queue d :: Effect
- read :: forall d r. Member (Queue d) r => Sem r (QueueResult d)
- peek :: forall d r. Member (Queue d) r => Sem r (QueueResult d)
- close :: forall d r. Member (Queue d) r => Sem r ()
- write :: forall d r. Member (Queue d) r => d -> Sem r ()
- tryRead :: forall d r. Member (Queue d) r => Sem r (QueueResult d)
- closed :: forall d r. Member (Queue d) r => Sem r Bool
- readTimeout :: forall d r t. (Member (Queue d) r, TimeUnit t) => t -> Sem r (QueueResult d)
- tryPeek :: forall d r. Member (Queue d) r => Sem r (QueueResult d)
- tryWrite :: forall d r. Member (Queue d) r => d -> Sem r (QueueResult ())
- writeTimeout :: forall d r t. (Member (Queue d) r, TimeUnit t) => t -> d -> Sem r (QueueResult ())
- module Polysemy.Conc.Data.QueueResult
- module Polysemy.Conc.Data.QueueResult
Documentation
loop :: Member (Queue d) r => (d -> Sem r ()) -> Sem r () Source #
Read from a Queue
repeatedly until it is closed.
When an element is received, call action
and recurse.
data Queue d :: Effect Source #
Abstracts queues like TBQueue
.
For documentation on the constructors, see the module Polysemy.Conc.Data.Queue.
import Polysemy.Conc (Queue, QueueResult) import Polysemy.Conc.Effect.Queue as Queue prog :: Member (Queue Int) r => Sem r (QueueResult Int) prog = do Queue.write 5 Queue.write 10 Queue.read >>= \case QueueResult.Success i -> fmap (i +) <$> Queue.read r -> pure r
read :: forall d r. Member (Queue d) r => Sem r (QueueResult d) Source #
Read an element from the queue, blocking until one is available.
peek :: forall d r. Member (Queue d) r => Sem r (QueueResult d) Source #
Read an element, leaving it in the queue, blocking until one is available.
write :: forall d r. Member (Queue d) r => d -> Sem r () Source #
Write an element to the queue, blocking until a slot is available.
tryRead :: forall d r. Member (Queue d) r => Sem r (QueueResult d) Source #
Read an element from the queue, immediately returning if none is available.
closed :: forall d r. Member (Queue d) r => Sem r Bool Source #
Indicate whether the queue is closed.
readTimeout :: forall d r t. (Member (Queue d) r, TimeUnit t) => t -> Sem r (QueueResult d) Source #
Read an element from the queue, blocking until one is available or the timeout expires.
tryPeek :: forall d r. Member (Queue d) r => Sem r (QueueResult d) Source #
Read an element, leaving it in the queue, immediately returning if none is available.
tryWrite :: forall d r. Member (Queue d) r => d -> Sem r (QueueResult ()) Source #
Write an element to the queue, immediately returning if no slot is available.
writeTimeout :: forall d r t. (Member (Queue d) r, TimeUnit t) => t -> d -> Sem r (QueueResult ()) Source #
Write an element to the queue, blocking until a slot is available or the timeout expires.