Safe Haskell | None |
---|---|
Language | Haskell2010 |
If this is your first time with conduit, you should probably start with the tutorial: https://github.com/snoyberg/conduit#readme .
Synopsis
- data ConduitT i o m r
- type Source m o = ConduitT () o m ()
- type Conduit i m o = ConduitT i o m ()
- type Sink i = ConduitT i Void
- type ConduitM = ConduitT
- (.|) :: Monad m => ConduitT a b m () -> ConduitT b c m r -> ConduitT a c m r
- connect :: Monad m => ConduitT () a m () -> ConduitT a Void m r -> m r
- fuse :: Monad m => ConduitT a b m () -> ConduitT b c m r -> ConduitT a c m r
- ($$) :: Monad m => Source m a -> Sink a m b -> m b
- ($=) :: Monad m => Conduit a m b -> ConduitT b c m r -> ConduitT a c m r
- (=$) :: Monad m => Conduit a m b -> ConduitT b c m r -> ConduitT a c m r
- (=$=) :: Monad m => Conduit a m b -> ConduitT b c m r -> ConduitT a c m r
- fuseBoth :: Monad m => ConduitT a b m r1 -> ConduitT b c m r2 -> ConduitT a c m (r1, r2)
- fuseBothMaybe :: Monad m => ConduitT a b m r1 -> ConduitT b c m r2 -> ConduitT a c m ( Maybe r1, r2)
- fuseUpstream :: Monad m => ConduitT a b m r -> ConduitT b c m () -> ConduitT a c m r
- await :: Monad m => ConduitT i o m ( Maybe i)
- yield :: Monad m => o -> ConduitT i o m ()
- yieldM :: Monad m => m o -> ConduitT i o m ()
- leftover :: i -> ConduitT i o m ()
- runConduit :: Monad m => ConduitT () Void m r -> m r
- runConduitPure :: ConduitT () Void Identity r -> r
- runConduitRes :: MonadUnliftIO m => ConduitT () Void ( ResourceT m) r -> m r
- bracketP :: MonadResource m => IO a -> (a -> IO ()) -> (a -> ConduitT i o m r) -> ConduitT i o m r
- catchC :: ( MonadUnliftIO m, Exception e) => ConduitT i o m r -> (e -> ConduitT i o m r) -> ConduitT i o m r
- handleC :: ( MonadUnliftIO m, Exception e) => (e -> ConduitT i o m r) -> ConduitT i o m r -> ConduitT i o m r
- tryC :: ( MonadUnliftIO m, Exception e) => ConduitT i o m r -> ConduitT i o m ( Either e r)
- type Producer m o = forall i. ConduitT i o m ()
- type Consumer i m r = forall o. ConduitT i o m r
- toProducer :: Monad m => ConduitT () a m () -> ConduitT i a m ()
- toConsumer :: Monad m => ConduitT a Void m b -> ConduitT a o m b
- awaitForever :: Monad m => (i -> ConduitT i o m r) -> ConduitT i o m ()
- transPipe :: Monad m => ( forall a. m a -> n a) -> ConduitT i o m r -> ConduitT i o n r
- mapOutput :: Monad m => (o1 -> o2) -> ConduitT i o1 m r -> ConduitT i o2 m r
- mapOutputMaybe :: Monad m => (o1 -> Maybe o2) -> ConduitT i o1 m r -> ConduitT i o2 m r
- mapInput :: Monad m => (i1 -> i2) -> (i2 -> Maybe i1) -> ConduitT i2 o m r -> ConduitT i1 o m r
- mapInputM :: Monad m => (i1 -> m i2) -> (i2 -> m ( Maybe i1)) -> ConduitT i2 o m r -> ConduitT i1 o m r
- mergeSource :: Monad m => ConduitT () i m () -> ConduitT a (i, a) m ()
- passthroughSink :: Monad m => ConduitT i Void m r -> (r -> m ()) -> ConduitT i i m ()
- sourceToList :: Monad m => ConduitT () a m () -> m [a]
- data SealedConduitT i o m r
- sealConduitT :: ConduitT i o m r -> SealedConduitT i o m r
- unsealConduitT :: Monad m => SealedConduitT i o m r -> ConduitT i o m r
- ($$+) :: Monad m => ConduitT () a m () -> ConduitT a Void m b -> m ( SealedConduitT () a m (), b)
- ($$++) :: Monad m => SealedConduitT () a m () -> ConduitT a Void m b -> m ( SealedConduitT () a m (), b)
- ($$+-) :: Monad m => SealedConduitT () a m () -> ConduitT a Void m b -> m b
- ($=+) :: Monad m => SealedConduitT () a m () -> ConduitT a b m () -> SealedConduitT () b m ()
- (=$$+) :: Monad m => ConduitT a b m () -> ConduitT b Void m r -> ConduitT a Void m ( SealedConduitT a b m (), r)
- (=$$++) :: Monad m => SealedConduitT i o m () -> ConduitT o Void m r -> ConduitT i Void m ( SealedConduitT i o m (), r)
- (=$$+-) :: Monad m => SealedConduitT i o m () -> ConduitT o Void m r -> ConduitT i Void m r
- fuseLeftovers :: Monad m => ([b] -> [a]) -> ConduitT a b m () -> ConduitT b c m r -> ConduitT a c m r
- fuseReturnLeftovers :: Monad m => ConduitT a b m () -> ConduitT b c m r -> ConduitT a c m (r, [b])
- data Flush a
-
newtype
ZipSource
m o =
ZipSource
{
- getZipSource :: ConduitT () o m ()
- sequenceSources :: ( Traversable f, Monad m) => f ( ConduitT () o m ()) -> ConduitT () (f o) m ()
-
newtype
ZipSink
i m r =
ZipSink
{
- getZipSink :: ConduitT i Void m r
- sequenceSinks :: ( Traversable f, Monad m) => f ( ConduitT i Void m r) -> ConduitT i Void m (f r)
-
newtype
ZipConduit
i o m r =
ZipConduit
{
- getZipConduit :: ConduitT i o m r
- sequenceConduits :: ( Traversable f, Monad m) => f ( ConduitT i o m r) -> ConduitT i o m (f r)
- data Void
Core interface
Types
data ConduitT i o m r Source #
Core datatype of the conduit package. This type represents a general
component which can consume a stream of input values
i
, produce a stream
of output values
o
, perform actions in the
m
monad, and produce a final
result
r
. The type synonyms provided here are simply wrappers around this
type.
Since 1.3.0
Instances
Deprecated
type Source m o = ConduitT () o m () Source #
Deprecated: Use ConduitT directly
Provides a stream of output values, without consuming any input or producing a final result.
Since 0.5.0
type Conduit i m o = ConduitT i o m () Source #
Deprecated: Use ConduitT directly
Consumes a stream of input values and produces a stream of output values, without producing a final result.
Since 0.5.0
type Sink i = ConduitT i Void Source #
Deprecated: Use ConduitT directly
Consumes a stream of input values and produces a final result, without producing any output.
type Sink i m r = ConduitT i Void m r
Since 0.5.0
Connect/fuse operators
Combine two
Conduit
s together into a new
Conduit
(aka
fuse
).
Output from the upstream (left) conduit will be fed into the
downstream (right) conduit. Processing will terminate when
downstream (right) returns.
Leftover data returned from the right
Conduit
will be discarded.
Equivalent to
fuse
and
=$=
, however the latter is deprecated and will
be removed in a future version.
Note that, while this operator looks like categorical composition (from Control.Category ), there are a few reasons it's different:
-
The position of the type parameters to
ConduitT
do not match. We would need to changeConduitT i o m r
toConduitT r m i o
, which would preclude aMonad
orMonadTrans
instance. -
The result value from upstream and downstream are allowed to
differ between upstream and downstream. In other words, we would
need the type signature here to look like
ConduitT a b m r -> ConduitT b c m r -> ConduitT a c m r
. -
Due to leftovers, we do not have a left identity in Conduit. This
can be achieved with the underlying
Pipe
datatype, but this is not generally recommended. See https://stackoverflow.com/a/15263700 .
Since: 1.2.8
connect :: Monad m => ConduitT () a m () -> ConduitT a Void m r -> m r Source #
Equivalent to using
runConduit
and
.|
together.
Since 1.2.3
Deprecated
($$) :: Monad m => Source m a -> Sink a m b -> m b infixr 0 Source #
Deprecated: Use runConduit and .|
The connect operator, which pulls data from a source and pushes to a sink.
If you would like to keep the
Source
open to be used for other
operations, use the connect-and-resume operator
$$+
.
Since 0.4.0
(=$=) :: Monad m => Conduit a m b -> ConduitT b c m r -> ConduitT a c m r infixr 2 Source #
Deprecated: Use .|
Deprecated fusion operator.
Since 0.4.0
Fuse with upstream results
fuseBoth :: Monad m => ConduitT a b m r1 -> ConduitT b c m r2 -> ConduitT a c m (r1, r2) Source #
Fuse two
ConduitT
s together, and provide the return value of both. Note
that this will force the entire upstream
ConduitT
to be run to produce the
result value, even if the downstream terminates early.
Since 1.1.5
fuseBothMaybe :: Monad m => ConduitT a b m r1 -> ConduitT b c m r2 -> ConduitT a c m ( Maybe r1, r2) Source #
Like
fuseBoth
, but does not force consumption of the
Producer
.
In the case that the
Producer
terminates, the result value is
provided as a
Just
value. If it does not terminate, then a
Nothing
value is returned.
One thing to note here is that "termination" here only occurs if the
Producer
actually yields a
Nothing
value. For example, with the
Producer
mapM_ yield [1..5]
, if five values are requested, the
Producer
has not yet terminated. Termination only occurs when the
sixth value is awaited for and the
Producer
signals termination.
Since 1.2.4
fuseUpstream :: Monad m => ConduitT a b m r -> ConduitT b c m () -> ConduitT a c m r Source #
Same as
fuseBoth
, but ignore the return value from the downstream
Conduit
. Same caveats of forced consumption apply.
Since 1.1.5
Primitives
await :: Monad m => ConduitT i o m ( Maybe i) Source #
Wait for a single input value from upstream. If no data is available,
returns
Nothing
. Once
await
returns
Nothing
, subsequent calls will
also return
Nothing
.
Since 0.5.0
Send a value downstream to the next component to consume. If the downstream component terminates, this call will never return control.
Since 0.5.0
yieldM :: Monad m => m o -> ConduitT i o m () Source #
Send a monadic value downstream for the next component to consume.
Since: 1.2.7
leftover :: i -> ConduitT i o m () Source #
Provide a single piece of leftover input to be consumed by the next component in the current monadic binding.
Note : it is highly encouraged to only return leftover values from input already consumed from upstream.
Since: 0.5.0
runConduit :: Monad m => ConduitT () Void m r -> m r Source #
Run a pipeline until processing completes.
Since 1.2.1
runConduitPure :: ConduitT () Void Identity r -> r Source #
Run a pure pipeline until processing completes, i.e. a pipeline
with
Identity
as the base monad. This is equivalient to
runIdentity . runConduit
.
Since: 1.2.8
runConduitRes :: MonadUnliftIO m => ConduitT () Void ( ResourceT m) r -> m r Source #
Run a pipeline which acquires resources with
ResourceT
, and
then run the
ResourceT
transformer. This is equivalent to
runResourceT . runConduit
.
Since: 1.2.8
Finalization
:: MonadResource m | |
=> IO a |
computation to run first ("acquire resource") |
-> (a -> IO ()) |
computation to run last ("release resource") |
-> (a -> ConduitT i o m r) |
computation to run in-between |
-> ConduitT i o m r |
Bracket a conduit computation between allocation and release of a resource. Two guarantees are given about resource finalization:
- It will be prompt . The finalization will be run as early as possible.
-
It is exception safe. Due to usage of
resourcet
, the finalization will be run in the event of any exceptions.
Since 0.5.0
Exception handling
catchC :: ( MonadUnliftIO m, Exception e) => ConduitT i o m r -> (e -> ConduitT i o m r) -> ConduitT i o m r Source #
Catch all exceptions thrown by the current component of the pipeline.
Note: this will
not
catch exceptions thrown by other components! For
example, if an exception is thrown in a
Source
feeding to a
Sink
, and
the
Sink
uses
catchC
, the exception will
not
be caught.
Due to this behavior (as well as lack of async exception safety), you
should not try to implement combinators such as
onException
in terms of this
primitive function.
Note also that the exception handling will not be applied to any finalizers generated by this conduit.
Since 1.0.11
handleC :: ( MonadUnliftIO m, Exception e) => (e -> ConduitT i o m r) -> ConduitT i o m r -> ConduitT i o m r Source #
The same as
flip catchC
.
Since 1.0.11
tryC :: ( MonadUnliftIO m, Exception e) => ConduitT i o m r -> ConduitT i o m ( Either e r) Source #
A version of
try
for use within a pipeline. See the comments in
catchC
for more details.
Since 1.0.11
Generalized conduit types
type Producer m o = forall i. ConduitT i o m () Source #
Deprecated: Use ConduitT directly
A component which produces a stream of output values, regardless of the
input stream. A
Producer
is a generalization of a
Source
, and can be
used as either a
Source
or a
Conduit
.
Since 1.0.0
type Consumer i m r = forall o. ConduitT i o m r Source #
Deprecated: Use ConduitT directly
A component which consumes a stream of input values and produces a final
result, regardless of the output stream. A
Consumer
is a generalization of
a
Sink
, and can be used as either a
Sink
or a
Conduit
.
Since 1.0.0
Utility functions
awaitForever :: Monad m => (i -> ConduitT i o m r) -> ConduitT i o m () Source #
Wait for input forever, calling the given inner component for each piece of new input.
This function is provided as a convenience for the common pattern of
await
ing input, checking if it's
Just
and then looping.
Since 0.5.0
transPipe :: Monad m => ( forall a. m a -> n a) -> ConduitT i o m r -> ConduitT i o n r Source #
Transform the monad that a
ConduitT
lives in.
Note that the monad transforming function will be run multiple times, resulting in unintuitive behavior in some cases. For a fuller treatment, please see:
https://github.com/snoyberg/conduit/wiki/Dealing-with-monad-transformers
Since 0.4.0
mapOutput :: Monad m => (o1 -> o2) -> ConduitT i o1 m r -> ConduitT i o2 m r Source #
Apply a function to all the output values of a
ConduitT
.
This mimics the behavior of
fmap
for a
Source
and
Conduit
in pre-0.4
days. It can also be simulated by fusing with the
map
conduit from
Data.Conduit.List
.
Since 0.4.1
mapOutputMaybe :: Monad m => (o1 -> Maybe o2) -> ConduitT i o1 m r -> ConduitT i o2 m r Source #
Same as
mapOutput
, but use a function that returns
Maybe
values.
Since 0.5.0
:: Monad m | |
=> (i1 -> i2) |
map initial input to new input |
-> (i2 -> Maybe i1) |
map new leftovers to initial leftovers |
-> ConduitT i2 o m r | |
-> ConduitT i1 o m r |
Apply a function to all the input values of a
ConduitT
.
Since 0.5.0
:: Monad m | |
=> (i1 -> m i2) |
map initial input to new input |
-> (i2 -> m ( Maybe i1)) |
map new leftovers to initial leftovers |
-> ConduitT i2 o m r | |
-> ConduitT i1 o m r |
Apply a monadic action to all the input values of a
ConduitT
.
Since 1.3.2
mergeSource :: Monad m => ConduitT () i m () -> ConduitT a (i, a) m () Source #
Merge a
Source
into a
Conduit
.
The new conduit will stop processing once either source or upstream have been exhausted.
Turn a
Sink
into a
Conduit
in the following way:
-
All input passed to the
Sink
is yielded downstream. -
When the
Sink
finishes processing, the result is passed to the provided to the finalizer function.
Note that the
Sink
will stop receiving input as soon as the downstream it
is connected to shuts down.
An example usage would be to write the result of a
Sink
to some mutable
variable while allowing other processing to continue.
Since 1.1.0
sourceToList :: Monad m => ConduitT () a m () -> m [a] Source #
Convert a
Source
into a list. The basic functionality can be explained as:
sourceToList src = src $$ Data.Conduit.List.consume
However,
sourceToList
is able to produce its results lazily, which cannot
be done when running a conduit pipeline in general. Unlike the
Data.Conduit.Lazy
module (in conduit-extra), this function performs no
unsafe I/O operations, and therefore can only be as lazy as the
underlying monad.
Since 1.2.6
Connect-and-resume
data SealedConduitT i o m r Source #
In order to provide for efficient monadic composition, the
ConduitT
type is implemented internally using a technique known
as the codensity transform. This allows for cheap appending, but
makes one case much more expensive: partially running a
ConduitT
and that capturing the new state.
This data type is the same as
ConduitT
, but does not use the
codensity transform technique.
Since: 1.3.0
sealConduitT :: ConduitT i o m r -> SealedConduitT i o m r Source #
unsealConduitT :: Monad m => SealedConduitT i o m r -> ConduitT i o m r Source #
($$+) :: Monad m => ConduitT () a m () -> ConduitT a Void m b -> m ( SealedConduitT () a m (), b) infixr 0 Source #
The connect-and-resume operator. This does not close the
Source
, but
instead returns it to be used again. This allows a
Source
to be used
incrementally in a large program, without forcing the entire program to live
in the
Sink
monad.
Mnemonic: connect + do more.
Since 0.5.0
($$++) :: Monad m => SealedConduitT () a m () -> ConduitT a Void m b -> m ( SealedConduitT () a m (), b) infixr 0 Source #
Continue processing after usage of
$$+
.
Since 0.5.0
($$+-) :: Monad m => SealedConduitT () a m () -> ConduitT a Void m b -> m b infixr 0 Source #
Same as
$$++
and
connectResume
, but doesn't include the
updated
SealedConduitT
.
NOTE In previous versions, this would cause finalizers to run. Since version 1.3.0, there are no finalizers in conduit.
Since 0.5.0
($=+) :: Monad m => SealedConduitT () a m () -> ConduitT a b m () -> SealedConduitT () b m () infixl 1 Source #
Left fusion for a sealed source.
Since 1.0.16
For
Conduit
s
(=$$+) :: Monad m => ConduitT a b m () -> ConduitT b Void m r -> ConduitT a Void m ( SealedConduitT a b m (), r) infixr 0 Source #
The connect-and-resume operator. This does not close the
Conduit
, but
instead returns it to be used again. This allows a
Conduit
to be used
incrementally in a large program, without forcing the entire program to live
in the
Sink
monad.
Leftover data returned from the
Sink
will be discarded.
Mnemonic: connect + do more.
Since 1.0.17
(=$$++) :: Monad m => SealedConduitT i o m () -> ConduitT o Void m r -> ConduitT i Void m ( SealedConduitT i o m (), r) infixr 0 Source #
Continue processing after usage of
=$$+
. Connect a
SealedConduitT
to
a sink and return the output of the sink together with a new
SealedConduitT
.
Since 1.0.17
(=$$+-) :: Monad m => SealedConduitT i o m () -> ConduitT o Void m r -> ConduitT i Void m r infixr 0 Source #
Same as
=$$++
, but doesn't include the updated
SealedConduitT
.
NOTE In previous versions, this would cause finalizers to run. Since version 1.3.0, there are no finalizers in conduit.
Since 1.0.17
Fusion with leftovers
fuseLeftovers :: Monad m => ([b] -> [a]) -> ConduitT a b m () -> ConduitT b c m r -> ConduitT a c m r Source #
Similar to
fuseReturnLeftovers
, but use the provided function to convert
downstream leftovers to upstream leftovers.
Since 1.0.17
fuseReturnLeftovers :: Monad m => ConduitT a b m () -> ConduitT b c m r -> ConduitT a c m (r, [b]) Source #
Same as normal fusion (e.g.
=$=
), except instead of discarding leftovers
from the downstream component, return them.
Since 1.0.17
Flushing
Provide for a stream of data that can be flushed.
A number of
Conduit
s (e.g., zlib compression) need the ability to flush
the stream at some point. This provides a single wrapper datatype to be used
in all such circumstances.
Since 0.3.0
Instances
Functor Flush Source # | |
Eq a => Eq ( Flush a) Source # | |
Ord a => Ord ( Flush a) Source # | |
Defined in Data.Conduit.Internal.Conduit |
|
Show a => Show ( Flush a) Source # | |
Newtype wrappers
ZipSource
newtype ZipSource m o Source #
A wrapper for defining an
Applicative
instance for
Source
s which allows
to combine sources together, generalizing
zipSources
. A combined source
will take input yielded from each of its
Source
s until any of them stop
producing output.
Since 1.0.13
ZipSource | |
|
Instances
Monad m => Functor ( ZipSource m) Source # | |
Monad m => Applicative ( ZipSource m) Source # | |
Defined in Data.Conduit.Internal.Conduit pure :: a -> ZipSource m a Source # (<*>) :: ZipSource m (a -> b) -> ZipSource m a -> ZipSource m b Source # liftA2 :: (a -> b -> c) -> ZipSource m a -> ZipSource m b -> ZipSource m c Source # (*>) :: ZipSource m a -> ZipSource m b -> ZipSource m b Source # (<*) :: ZipSource m a -> ZipSource m b -> ZipSource m a Source # |
sequenceSources :: ( Traversable f, Monad m) => f ( ConduitT () o m ()) -> ConduitT () (f o) m () Source #
Coalesce all values yielded by all of the
Source
s.
Implemented on top of
ZipSource
and as such, it exhibits the same
short-circuiting behavior as
ZipSource
. See that data type for more
details. If you want to create a source that yields *all* values from
multiple sources, use
sequence_
.
Since 1.0.13
ZipSink
newtype ZipSink i m r Source #
A wrapper for defining an
Applicative
instance for
Sink
s which allows
to combine sinks together, generalizing
zipSinks
. A combined sink
distributes the input to all its participants and when all finish, produces
the result. This allows to define functions like
sequenceSinks :: (Monad m) => [ConduitT i Void m r] -> ConduitT i Void m [r] sequenceSinks = getZipSink . sequenceA . fmap ZipSink
Note that the standard
Applicative
instance for conduits works
differently. It feeds one sink with input until it finishes, then switches
to another, etc., and at the end combines their results.
This newtype is in fact a type constrained version of
ZipConduit
, and has
the same behavior. It's presented as a separate type since (1) it
historically predates
ZipConduit
, and (2) the type constraining can make
your code clearer (and thereby make your error messages more easily
understood).
Since 1.0.13
ZipSink | |
|
Instances
Monad m => Functor ( ZipSink i m) Source # | |
Monad m => Applicative ( ZipSink i m) Source # | |
Defined in Data.Conduit.Internal.Conduit pure :: a -> ZipSink i m a Source # (<*>) :: ZipSink i m (a -> b) -> ZipSink i m a -> ZipSink i m b Source # liftA2 :: (a -> b -> c) -> ZipSink i m a -> ZipSink i m b -> ZipSink i m c Source # (*>) :: ZipSink i m a -> ZipSink i m b -> ZipSink i m b Source # (<*) :: ZipSink i m a -> ZipSink i m b -> ZipSink i m a Source # |
sequenceSinks :: ( Traversable f, Monad m) => f ( ConduitT i Void m r) -> ConduitT i Void m (f r) Source #
Send incoming values to all of the
Sink
providing, and ultimately
coalesce together all return values.
Implemented on top of
ZipSink
, see that data type for more details.
Since 1.0.13
ZipConduit
newtype ZipConduit i o m r Source #
Provides an alternative
Applicative
instance for
ConduitT
. In this instance,
every incoming value is provided to all
ConduitT
s, and output is coalesced together.
Leftovers from individual
ConduitT
s will be used within that component, and then discarded
at the end of their computation. Output and finalizers will both be handled in a left-biased manner.
As an example, take the following program:
main :: IO () main = do let src = mapM_ yield [1..3 :: Int] conduit1 = CL.map (+1) conduit2 = CL.concatMap (replicate 2) conduit = getZipConduit $ ZipConduit conduit1 <* ZipConduit conduit2 sink = CL.mapM_ print src $$ conduit =$ sink
It will produce the output: 2, 1, 1, 3, 2, 2, 4, 3, 3
Since 1.0.17
ZipConduit | |
|
Instances
Functor ( ZipConduit i o m) Source # | |
Defined in Data.Conduit.Internal.Conduit fmap :: (a -> b) -> ZipConduit i o m a -> ZipConduit i o m b Source # (<$) :: a -> ZipConduit i o m b -> ZipConduit i o m a Source # |
|
Monad m => Applicative ( ZipConduit i o m) Source # | |
Defined in Data.Conduit.Internal.Conduit pure :: a -> ZipConduit i o m a Source # (<*>) :: ZipConduit i o m (a -> b) -> ZipConduit i o m a -> ZipConduit i o m b Source # liftA2 :: (a -> b -> c) -> ZipConduit i o m a -> ZipConduit i o m b -> ZipConduit i o m c Source # (*>) :: ZipConduit i o m a -> ZipConduit i o m b -> ZipConduit i o m b Source # (<*) :: ZipConduit i o m a -> ZipConduit i o m b -> ZipConduit i o m a Source # |
sequenceConduits :: ( Traversable f, Monad m) => f ( ConduitT i o m r) -> ConduitT i o m (f r) Source #
Provide identical input to all of the
Conduit
s and combine their outputs
into a single stream.
Implemented on top of
ZipConduit
, see that data type for more details.
Since 1.0.17
Convenience reexports
Uninhabited data type
Since: base-4.8.0.0
Instances
Eq Void |
Since: base-4.8.0.0 |
Data Void |
Since: base-4.8.0.0 |
Defined in Data.Void gfoldl :: ( forall d b. Data d => c (d -> b) -> d -> c b) -> ( forall g. g -> c g) -> Void -> c Void Source # gunfold :: ( forall b r. Data b => c (b -> r) -> c r) -> ( forall r. r -> c r) -> Constr -> c Void Source # toConstr :: Void -> Constr Source # dataTypeOf :: Void -> DataType Source # dataCast1 :: Typeable t => ( forall d. Data d => c (t d)) -> Maybe (c Void ) Source # dataCast2 :: Typeable t => ( forall d e. ( Data d, Data e) => c (t d e)) -> Maybe (c Void ) Source # gmapT :: ( forall b. Data b => b -> b) -> Void -> Void Source # gmapQl :: (r -> r' -> r) -> r -> ( forall d. Data d => d -> r') -> Void -> r Source # gmapQr :: forall r r'. (r' -> r -> r) -> r -> ( forall d. Data d => d -> r') -> Void -> r Source # gmapQ :: ( forall d. Data d => d -> u) -> Void -> [u] Source # gmapQi :: Int -> ( forall d. Data d => d -> u) -> Void -> u Source # gmapM :: Monad m => ( forall d. Data d => d -> m d) -> Void -> m Void Source # gmapMp :: MonadPlus m => ( forall d. Data d => d -> m d) -> Void -> m Void Source # gmapMo :: MonadPlus m => ( forall d. Data d => d -> m d) -> Void -> m Void Source # |
|
Ord Void |
Since: base-4.8.0.0 |
Read Void |
Reading a
Since: base-4.8.0.0 |
Show Void |
Since: base-4.8.0.0 |
Ix Void |
Since: base-4.8.0.0 |
Defined in Data.Void |
|
Generic Void |
Since: base-4.8.0.0 |
Semigroup Void |
Since: base-4.9.0.0 |
Exception Void |
Since: base-4.8.0.0 |
Defined in Data.Void toException :: Void -> SomeException Source # fromException :: SomeException -> Maybe Void Source # displayException :: Void -> String Source # |
|
Hashable Void | |
Lift Void |
Since: template-haskell-2.15.0.0 |
type Rep Void | |