Channel overview
Added in v2.0.0
Table of contents
- combinators
- constructors
- acquireReleaseOut
- acquireUseRelease
- buffer
- bufferChunk
- concatAll
- concatAllWith
- fail
- failCause
- failCauseSync
- failSync
- fromEffect
- fromEither
- fromInput
- fromOption
- fromPubSub
- fromPubSubScoped
- fromQueue
- identity
- never
- read
- readOrFail
- readWith
- readWithCause
- scoped
- scopedWith
- succeed
- suspend
- sync
- unwrap
- unwrapScoped
- unwrapScopedWith
- void
- write
- writeAll
- writeChunk
- context
- destructors
- error handling
- errors
- mapping
- models
- refinements
- sequencing
- symbols
- tracing
- utils
- Channel (namespace)
- collect
- concatMap
- concatMapWith
- concatMapWithCustom
- concatOut
- doneCollect
- drain
- embedInput
- emitCollect
- ensuring
- ensuringWith
- foldCauseChannel
- foldChannel
- interruptWhen
- interruptWhenDeferred
- mapInput
- mapInputEffect
- mapInputError
- mapInputErrorEffect
- mapInputIn
- mapInputInEffect
- mergeAll
- mergeAllUnbounded
- mergeAllUnboundedWith
- mergeAllWith
- mergeOut
- mergeOutWith
- mergeWith
- pipeTo
- pipeToOrFail
- repeated
- zipping
combinators
splitLines
Splits strings on newlines. Handles both Windows newlines (\r\n
) and UNIX newlines (\n
).
Signature
export declare const splitLines: <Err, Done>() => Channel<
Chunk.Chunk<string>,
Chunk.Chunk<string>,
Err,
Err,
Done,
Done,
never
>
Added in v2.0.0
constructors
acquireReleaseOut
Signature
export declare const acquireReleaseOut: {
<Z, R2>(
release: (z: Z, e: Exit.Exit<unknown, unknown>) => Effect.Effect<unknown, never, R2>
): <E, R>(self: Effect.Effect<Z, E, R>) => Channel<Z, unknown, E, unknown, void, unknown, R2 | R>
<Z, E, R, R2>(
self: Effect.Effect<Z, E, R>,
release: (z: Z, e: Exit.Exit<unknown, unknown>) => Effect.Effect<unknown, never, R2>
): Channel<Z, unknown, E, unknown, void, unknown, R | R2>
}
Added in v2.0.0
acquireUseRelease
Signature
export declare const acquireUseRelease: <Acquired, OutErr, Env, OutElem1, InElem, InErr, OutDone, InDone>(
acquire: Effect.Effect<Acquired, OutErr, Env>,
use: (a: Acquired) => Channel<OutElem1, InElem, OutErr, InErr, OutDone, InDone, Env>,
release: (a: Acquired, exit: Exit.Exit<OutDone, OutErr>) => Effect.Effect<any, never, Env>
) => Channel<OutElem1, InElem, OutErr, InErr, OutDone, InDone, Env>
Added in v2.0.0
buffer
Creates a channel backed by a buffer. When the buffer is empty, the channel will simply passthrough its input as output. However, when the buffer is non-empty, the value inside the buffer will be passed along as output.
Signature
export declare const buffer: <InElem, InErr, InDone>(options: {
readonly empty: InElem
readonly isEmpty: Predicate<InElem>
readonly ref: Ref.Ref<InElem>
}) => Channel<InElem, InElem, InErr, InErr, InDone, InDone, never>
Added in v2.0.0
bufferChunk
Signature
export declare const bufferChunk: <InElem, InErr, InDone>(
ref: Ref.Ref<Chunk.Chunk<InElem>>
) => Channel<Chunk.Chunk<InElem>, Chunk.Chunk<InElem>, InErr, InErr, InDone, InDone>
Added in v2.0.0
concatAll
Concat sequentially a channel of channels.
Signature
export declare const concatAll: <OutElem, InElem, OutErr, InErr, InDone, Env>(
channels: Channel<Channel<OutElem, InElem, OutErr, InErr, any, InDone, Env>, InElem, OutErr, InErr, any, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, any, InDone, Env>
Added in v2.0.0
concatAllWith
Concat sequentially a channel of channels.
Signature
export declare const concatAllWith: <
OutElem,
InElem2,
OutErr2,
InErr2,
OutDone,
InDone2,
Env2,
InElem,
OutErr,
InErr,
OutDone2,
InDone,
Env,
OutDone3
>(
channels: Channel<
Channel<OutElem, InElem2, OutErr2, InErr2, OutDone, InDone2, Env2>,
InElem,
OutErr,
InErr,
OutDone2,
InDone,
Env
>,
f: (o: OutDone, o1: OutDone) => OutDone,
g: (o: OutDone, o2: OutDone2) => OutDone3
) => Channel<OutElem, InElem & InElem2, OutErr2 | OutErr, InErr & InErr2, OutDone3, InDone & InDone2, Env2 | Env>
Added in v2.0.0
fail
Constructs a channel that fails immediately with the specified error.
Signature
export declare const fail: <E>(error: E) => Channel<never, unknown, E, unknown, never, unknown>
Added in v2.0.0
failCause
Constructs a channel that fails immediately with the specified Cause
.
Signature
export declare const failCause: <E>(cause: Cause.Cause<E>) => Channel<never, unknown, E, unknown, never, unknown>
Added in v2.0.0
failCauseSync
Constructs a channel that succeeds immediately with the specified lazily evaluated Cause
.
Signature
export declare const failCauseSync: <E>(
evaluate: LazyArg<Cause.Cause<E>>
) => Channel<never, unknown, E, unknown, never, unknown>
Added in v2.0.0
failSync
Constructs a channel that succeeds immediately with the specified lazily evaluated value.
Signature
export declare const failSync: <E>(evaluate: LazyArg<E>) => Channel<never, unknown, E, unknown, never, unknown>
Added in v2.0.0
fromEffect
Use an effect to end a channel.
Signature
export declare const fromEffect: <A, E, R>(
effect: Effect.Effect<A, E, R>
) => Channel<never, unknown, E, unknown, A, unknown, R>
Added in v2.0.0
fromEither
Constructs a channel from an Either
.
Signature
export declare const fromEither: <R, L>(either: Either.Either<R, L>) => Channel<never, unknown, L, unknown, R, unknown>
Added in v2.0.0
fromInput
Construct a Channel
from an AsyncInputConsumer
.
Signature
export declare const fromInput: <Err, Elem, Done>(
input: SingleProducerAsyncInput.AsyncInputConsumer<Err, Elem, Done>
) => Channel<Elem, unknown, Err, unknown, Done, unknown>
Added in v2.0.0
fromOption
Construct a Channel
from an Option
.
Signature
export declare const fromOption: <A>(
option: Option.Option<A>
) => Channel<never, unknown, Option.Option<never>, unknown, A, unknown>
Added in v2.0.0
fromPubSub
Construct a Channel
from a PubSub
.
Signature
export declare const fromPubSub: <Done, Err, Elem>(
pubsub: PubSub.PubSub<Either.Either<Elem, Exit.Exit<Done, Err>>>
) => Channel<Elem, unknown, Err, unknown, Done, unknown>
Added in v2.0.0
fromPubSubScoped
Construct a Channel
from a PubSub
within a scoped effect.
Signature
export declare const fromPubSubScoped: <Done, Err, Elem>(
pubsub: PubSub.PubSub<Either.Either<Elem, Exit.Exit<Done, Err>>>
) => Effect.Effect<Channel<Elem, unknown, Err, unknown, Done, unknown>, never, Scope.Scope>
Added in v2.0.0
fromQueue
Construct a Channel
from a Queue
.
Signature
export declare const fromQueue: <Done, Err, Elem>(
queue: Queue.Dequeue<Either.Either<Elem, Exit.Exit<Done, Err>>>
) => Channel<Elem, unknown, Err, unknown, Done, unknown>
Added in v2.0.0
identity
Signature
export declare const identity: <Elem, Err, Done>() => Channel<Elem, Elem, Err, Err, Done, Done>
Added in v2.0.0
never
Returns a channel that never completes
Signature
export declare const never: Channel<never, unknown, never, unknown, never, unknown, never>
Added in v2.0.0
read
Signature
export declare const read: <In>() => Channel<never, In, Option.Option<never>, unknown, In, unknown>
Added in v2.0.0
readOrFail
Signature
export declare const readOrFail: <E, In = unknown>(error: E) => Channel<never, In, E, unknown, In, unknown>
Added in v2.0.0
readWith
Signature
export declare const readWith: <
InElem,
OutElem,
OutErr,
InErr,
OutDone,
InDone,
Env,
OutElem2,
OutErr2,
OutDone2,
Env2,
OutElem3,
OutErr3,
OutDone3,
Env3
>(options: {
readonly onInput: (input: InElem) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
readonly onFailure: (error: InErr) => Channel<OutElem2, InElem, OutErr2, InErr, OutDone2, InDone, Env2>
readonly onDone: (done: InDone) => Channel<OutElem3, InElem, OutErr3, InErr, OutDone3, InDone, Env3>
}) => Channel<
OutElem | OutElem2 | OutElem3,
InElem,
OutErr | OutErr2 | OutErr3,
InErr,
OutDone | OutDone2 | OutDone3,
InDone,
Env | Env2 | Env3
>
Added in v2.0.0
readWithCause
Signature
export declare const readWithCause: <
InElem,
OutElem,
OutErr,
InErr,
OutDone,
InDone,
Env,
OutElem2,
OutErr2,
OutDone2,
Env2,
OutElem3,
OutErr3,
OutDone3,
Env3
>(options: {
readonly onInput: (input: InElem) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
readonly onFailure: (cause: Cause.Cause<InErr>) => Channel<OutElem2, InElem, OutErr2, InErr, OutDone2, InDone, Env2>
readonly onDone: (done: InDone) => Channel<OutElem3, InElem, OutErr3, InErr, OutDone3, InDone, Env3>
}) => Channel<
OutElem | OutElem2 | OutElem3,
InElem,
OutErr | OutErr2 | OutErr3,
InErr,
OutDone | OutDone2 | OutDone3,
InDone,
Env | Env2 | Env3
>
Added in v2.0.0
scoped
Use a scoped effect to emit an output element.
Signature
export declare const scoped: <A, E, R>(
effect: Effect.Effect<A, E, R>
) => Channel<A, unknown, E, unknown, unknown, unknown, Exclude<R, Scope.Scope>>
Added in v2.0.0
scopedWith
Use a function that receives a scope and returns an effect to emit an output element. The output element will be the result of the returned effect, if successful.
Signature
export declare const scopedWith: <A, E, R>(
f: (scope: Scope.Scope) => Effect.Effect<A, E, R>
) => Channel<A, unknown, E, unknown, unknown, unknown, R>
Added in v3.11.0
succeed
Constructs a channel that succeeds immediately with the specified value.
Signature
export declare const succeed: <A>(value: A) => Channel<never, unknown, never, unknown, A, unknown>
Added in v2.0.0
suspend
Lazily constructs a channel from the given side effect.
Signature
export declare const suspend: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
evaluate: LazyArg<Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
Added in v2.0.0
sync
Constructs a channel that succeeds immediately with the specified lazy value.
Signature
export declare const sync: <OutDone>(
evaluate: LazyArg<OutDone>
) => Channel<never, unknown, never, unknown, OutDone, unknown>
Added in v2.0.0
unwrap
Constructs a Channel
from an effect that will result in a Channel
if successful.
Signature
export declare const unwrap: <OutElem, InElem, OutErr, InErr, OutDone, InDone, R2, E, R>(
channel: Effect.Effect<Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, R2>, E, R>
) => Channel<OutElem, InElem, E | OutErr, InErr, OutDone, InDone, R | R2>
Added in v2.0.0
unwrapScoped
Constructs a Channel
from a scoped effect that will result in a Channel
if successful.
Signature
export declare const unwrapScoped: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, E, R>(
self: Effect.Effect<Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>, E, R>
) => Channel<OutElem, InElem, E | OutErr, InErr, OutDone, InDone, Env | Exclude<R, Scope.Scope>>
Added in v2.0.0
unwrapScopedWith
Constructs a Channel
from a function which receives a Scope
and returns an effect that will result in a Channel
if successful.
Signature
export declare const unwrapScopedWith: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, E, R>(
f: (scope: Scope.Scope) => Effect.Effect<Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>, E, R>
) => Channel<OutElem, InElem, E | OutErr, InErr, OutDone, InDone, R | Env>
Added in v3.11.0
void
Signature
export declare const void: Channel<never, unknown, never, unknown, void, unknown, never>
Added in v2.0.0
write
Writes a single value to the channel.
Signature
export declare const write: <OutElem>(out: OutElem) => Channel<OutElem>
Added in v2.0.0
writeAll
Writes a sequence of values to the channel.
Signature
export declare const writeAll: <OutElems extends Array<any>>(...outs: OutElems) => Channel<OutElems[number]>
Added in v2.0.0
writeChunk
Writes a Chunk
of values to the channel.
Signature
export declare const writeChunk: <OutElem>(outs: Chunk.Chunk<OutElem>) => Channel<OutElem>
Added in v2.0.0
context
context
Accesses the whole context of the channel.
Signature
export declare const context: <Env>() => Channel<never, unknown, never, unknown, Context.Context<Env>, unknown, Env>
Added in v2.0.0
contextWith
Accesses the context of the channel with the specified function.
Signature
export declare const contextWith: <Env, OutDone>(
f: (env: Context.Context<Env>) => OutDone
) => Channel<never, unknown, never, unknown, OutDone, unknown, Env>
Added in v2.0.0
contextWithChannel
Accesses the context of the channel in the context of a channel.
Signature
export declare const contextWithChannel: <Env, OutElem, InElem, OutErr, InErr, OutDone, InDone, Env1>(
f: (env: Context.Context<Env>) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env1>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env | Env1>
Added in v2.0.0
contextWithEffect
Accesses the context of the channel in the context of an effect.
Signature
export declare const contextWithEffect: <Env, OutDone, OutErr, Env1>(
f: (env: Context.Context<Env>) => Effect.Effect<OutDone, OutErr, Env1>
) => Channel<never, unknown, OutErr, unknown, OutDone, unknown, Env | Env1>
Added in v2.0.0
mapInputContext
Transforms the context being provided to the channel with the specified function.
Signature
export declare const mapInputContext: {
<Env0, Env>(
f: (env: Context.Context<Env0>) => Context.Context<Env>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env0>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, Env0>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (env: Context.Context<Env0>) => Context.Context<Env>
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env0>
}
Added in v2.0.0
provideContext
Provides the channel with its required context, which eliminates its dependency on Env
.
Signature
export declare const provideContext: {
<Env>(
env: Context.Context<Env>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, never>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
env: Context.Context<Env>
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, never>
}
Added in v2.0.0
provideLayer
Provides a layer to the channel, which translates it to another level.
Signature
export declare const provideLayer: {
<Env, OutErr2, Env0>(
layer: Layer.Layer<Env, OutErr2, Env0>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr2 | OutErr, InErr, OutDone, InDone, Env0>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutErr2, Env0>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
layer: Layer.Layer<Env, OutErr2, Env0>
): Channel<OutElem, InElem, OutErr | OutErr2, InErr, OutDone, InDone, Env0>
}
Added in v2.0.0
provideService
Provides the effect with the single service it requires. If the effect requires more than one service use provideContext
instead.
Signature
export declare const provideService: {
<T extends Context.Tag<any, any>>(
tag: T,
service: Context.Tag.Service<T>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Exclude<Env, Context.Tag.Identifier<T>>>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, T extends Context.Tag<any, any>>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
tag: T,
service: Context.Tag.Service<T>
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Exclude<Env, Context.Tag.Identifier<T>>>
}
Added in v2.0.0
provideSomeLayer
Splits the context into two parts, providing one part using the specified layer and leaving the remainder Env0
.
Signature
export declare const provideSomeLayer: {
<R2, OutErr2, Env0>(
layer: Layer.Layer<R2, OutErr2, Env0>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, R>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, R>
) => Channel<OutElem, InElem, OutErr2 | OutErr, InErr, OutDone, InDone, Env0 | Exclude<R, R2>>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, R, R2, OutErr2, Env0>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, R>,
layer: Layer.Layer<R2, OutErr2, Env0>
): Channel<OutElem, InElem, OutErr | OutErr2, InErr, OutDone, InDone, Env0 | Exclude<R, R2>>
}
Added in v2.0.0
updateService
Updates a service in the context of this channel.
Signature
export declare const updateService: {
<T extends Context.Tag<any, any>>(
tag: T,
f: (resource: Context.Tag.Service<T>) => Context.Tag.Service<T>
): <OutElem, OutErr, InErr, OutDone, InDone, R>(
self: Channel<OutElem, unknown, OutErr, InErr, OutDone, InDone, R>
) => Channel<OutElem, unknown, OutErr, InErr, OutDone, InDone, T | R>
<OutElem, OutErr, InErr, OutDone, InDone, R, T extends Context.Tag<any, any>>(
self: Channel<OutElem, unknown, OutErr, InErr, OutDone, InDone, R>,
tag: T,
f: (resource: Context.Tag.Service<T>) => Context.Tag.Service<T>
): Channel<OutElem, unknown, OutErr, InErr, OutDone, InDone, R | T>
}
Added in v2.0.0
destructors
run
Runs a channel until the end is received.
Signature
export declare const run: <OutErr, InErr, OutDone, InDone, Env>(
self: Channel<never, unknown, OutErr, InErr, OutDone, InDone, Env>
) => Effect.Effect<OutDone, OutErr, Env>
Added in v2.0.0
runCollect
Run the channel until it finishes with a done value or fails with an error and collects its emitted output elements.
The channel must not read any input.
Signature
export declare const runCollect: <OutElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, unknown, OutErr, InErr, OutDone, InDone, Env>
) => Effect.Effect<[Chunk.Chunk<OutElem>, OutDone], OutErr, Env>
Added in v2.0.0
runDrain
Runs a channel until the end is received.
Signature
export declare const runDrain: <OutElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, unknown, OutErr, InErr, OutDone, InDone, Env>
) => Effect.Effect<OutDone, OutErr, Env>
Added in v2.0.0
runScoped
Run the channel until it finishes with a done value or fails with an error. The channel must not read any input or write any output.
Closing the channel, which includes execution of all the finalizers attached to the channel will be added to the current scope as a finalizer.
Signature
export declare const runScoped: <OutErr, InErr, OutDone, InDone, Env>(
self: Channel<never, unknown, OutErr, InErr, OutDone, InDone, Env>
) => Effect.Effect<OutDone, OutErr, Env | Scope.Scope>
Added in v3.11.0
toPubSub
Converts a Channel
to a PubSub
.
Signature
export declare const toPubSub: <Done, Err, Elem>(
pubsub: PubSub.PubSub<Either.Either<Elem, Exit.Exit<Done, Err>>>
) => Channel<never, Elem, never, Err, unknown, Done>
Added in v2.0.0
toPull
Returns a scoped Effect
that can be used to repeatedly pull elements from the constructed Channel
. The pull effect fails with the channel’s failure in case the channel fails, or returns either the channel’s done value or an emitted element.
Signature
export declare const toPull: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Effect.Effect<Effect.Effect<Either.Either<OutElem, OutDone>, OutErr, Env>, never, Scope.Scope | Env>
Added in v2.0.0
toPullIn
Returns an Effect
that can be used to repeatedly pull elements from the constructed Channel
within the provided Scope
. The pull effect fails with the channel’s failure in case the channel fails, or returns either the channel’s done value or an emitted element.
Signature
export declare const toPullIn: {
(
scope: Scope.Scope
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Effect.Effect<Effect.Effect<Either.Either<OutElem, OutDone>, OutErr, Env>, never, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
scope: Scope.Scope
): Effect.Effect<Effect.Effect<Either.Either<OutElem, OutDone>, OutErr, Env>, never, Env>
}
Added in v3.11.0
toQueue
Converts a Channel
to a Queue
.
Signature
export declare const toQueue: <Done, Err, Elem>(
queue: Queue.Enqueue<Either.Either<Elem, Exit.Exit<Done, Err>>>
) => Channel<never, Elem, never, Err, unknown, Done>
Added in v2.0.0
toSink
Converts this channel to a Sink
.
Signature
export declare const toSink: <OutElem, InElem, OutErr, InErr, OutDone, Env>(
self: Channel<Chunk.Chunk<OutElem>, Chunk.Chunk<InElem>, OutErr, InErr, OutDone, unknown, Env>
) => Sink.Sink<OutDone, InElem, OutElem, OutErr, Env>
Added in v2.0.0
toStream
Converts this channel to a Stream
.
Signature
export declare const toStream: <OutElem, OutErr, OutDone, Env>(
self: Channel<Chunk.Chunk<OutElem>, unknown, OutErr, unknown, OutDone, unknown, Env>
) => Stream.Stream<OutElem, OutErr, Env>
Added in v2.0.0
error handling
catchAll
Returns a new channel that is the same as this one, except if this channel errors for any typed error, then the returned channel will switch over to using the fallback channel returned by the specified error handler.
Signature
export declare const catchAll: {
<OutErr, OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
f: (error: OutErr) => Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>
): <OutElem, InElem, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem,
InElem & InElem1,
OutErr1,
InErr & InErr1,
OutDone1 | OutDone,
InDone & InDone1,
Env1 | Env
>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (error: OutErr) => Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>
): Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr1,
InErr & InErr1,
OutDone | OutDone1,
InDone & InDone1,
Env | Env1
>
}
Added in v2.0.0
catchAllCause
Returns a new channel that is the same as this one, except if this channel errors for any typed error, then the returned channel will switch over to using the fallback channel returned by the specified error handler.
Signature
export declare const catchAllCause: {
<OutErr, OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
f: (cause: Cause.Cause<OutErr>) => Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>
): <OutElem, InElem, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem,
InElem & InElem1,
OutErr1,
InErr & InErr1,
OutDone1 | OutDone,
InDone & InDone1,
Env1 | Env
>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (cause: Cause.Cause<OutErr>) => Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>
): Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr1,
InErr & InErr1,
OutDone | OutDone1,
InDone & InDone1,
Env | Env1
>
}
Added in v2.0.0
orDie
Translates channel failure into death of the fiber, making all failures unchecked and not a part of the type of the channel.
Signature
export declare const orDie: {
<E>(
error: LazyArg<E>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, never, InErr, OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, E>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
error: LazyArg<E>
): Channel<OutElem, InElem, never, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
orDieWith
Keeps none of the errors, and terminates the fiber with them, using the specified function to convert the OutErr
into a defect.
Signature
export declare const orDieWith: {
<OutErr>(
f: (e: OutErr) => unknown
): <OutElem, InElem, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, never, InErr, OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (e: OutErr) => unknown
): Channel<OutElem, InElem, never, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
orElse
Returns a new channel that will perform the operations of this one, until failure, and then it will switch over to the operations of the specified fallback channel.
Signature
export declare const orElse: {
<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
that: LazyArg<Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem,
InElem & InElem1,
OutErr1,
InErr & InErr1,
OutDone1 | OutDone,
InDone & InDone1,
Env1 | Env
>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
that: LazyArg<Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>>
): Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr1,
InErr & InErr1,
OutDone | OutDone1,
InDone & InDone1,
Env | Env1
>
}
Added in v2.0.0
errors
ChannelException
Represents a generic checked exception which occurs when a Channel
is executed.
Signature
export declare const ChannelException: <E>(error: E) => ChannelException<E>
Added in v2.0.0
mapping
as
Returns a new channel that is the same as this one, except the terminal value of the channel is the specified constant value.
This method produces the same result as mapping this channel to the specified constant value.
Signature
export declare const as: {
<OutDone2>(
value: OutDone2
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone2, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutDone2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
value: OutDone2
): Channel<OutElem, InElem, OutErr, InErr, OutDone2, InDone, Env>
}
Added in v2.0.0
asVoid
Signature
export declare const asVoid: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, void, InDone, Env>
Added in v2.0.0
map
Returns a new channel, which is the same as this one, except the terminal value of the returned channel is created by applying the specified function to the terminal value of this channel.
Signature
export declare const map: {
<OutDone, OutDone2>(
f: (out: OutDone) => OutDone2
): <OutElem, InElem, OutErr, InErr, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone2, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutDone2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (out: OutDone) => OutDone2
): Channel<OutElem, InElem, OutErr, InErr, OutDone2, InDone, Env>
}
Added in v2.0.0
mapEffect
Returns a new channel, which is the same as this one, except the terminal value of the returned channel is created by applying the specified effectful function to the terminal value of this channel.
Signature
export declare const mapEffect: {
<OutDone, OutDone1, OutErr1, Env1>(
f: (o: OutDone) => Effect.Effect<OutDone1, OutErr1, Env1>
): <OutElem, InElem, OutErr, InErr, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr1 | OutErr, InErr, OutDone1, InDone, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutDone1, OutErr1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (o: OutDone) => Effect.Effect<OutDone1, OutErr1, Env1>
): Channel<OutElem, InElem, OutErr | OutErr1, InErr, OutDone1, InDone, Env | Env1>
}
Added in v2.0.0
mapError
Returns a new channel, which is the same as this one, except the failure value of the returned channel is created by applying the specified function to the failure value of this channel.
Signature
export declare const mapError: {
<OutErr, OutErr2>(
f: (err: OutErr) => OutErr2
): <OutElem, InElem, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr2, InErr, OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutErr2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (err: OutErr) => OutErr2
): Channel<OutElem, InElem, OutErr2, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
mapErrorCause
A more powerful version of mapError
which also surfaces the Cause
of the channel failure.
Signature
export declare const mapErrorCause: {
<OutErr, OutErr2>(
f: (cause: Cause.Cause<OutErr>) => Cause.Cause<OutErr2>
): <OutElem, InElem, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr2, InErr, OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutErr2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (cause: Cause.Cause<OutErr>) => Cause.Cause<OutErr2>
): Channel<OutElem, InElem, OutErr2, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
mapOut
Maps the output of this channel using the specified function.
Signature
export declare const mapOut: {
<OutElem, OutElem2>(
f: (o: OutElem) => OutElem2
): <InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem2, InElem, OutErr, InErr, OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (o: OutElem) => OutElem2
): Channel<OutElem2, InElem, OutErr, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
mapOutEffect
Creates a channel that is like this channel but the given effectful function gets applied to each emitted output element.
Signature
export declare const mapOutEffect: {
<OutElem, OutElem1, OutErr1, Env1>(
f: (o: OutElem) => Effect.Effect<OutElem1, OutErr1, Env1>
): <InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem1, InElem, OutErr1 | OutErr, InErr, OutDone, InDone, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, OutErr1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (o: OutElem) => Effect.Effect<OutElem1, OutErr1, Env1>
): Channel<OutElem1, InElem, OutErr | OutErr1, InErr, OutDone, InDone, Env | Env1>
}
Added in v2.0.0
mapOutEffectPar
Creates a channel that is like this channel but the given ZIO function gets applied to each emitted output element, taking n
elements at once and mapping them in parallel.
Signature
export declare const mapOutEffectPar: {
<OutElem, OutElem1, OutErr1, Env1>(
f: (o: OutElem) => Effect.Effect<OutElem1, OutErr1, Env1>,
n: number
): <InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem1, InElem, OutErr1 | OutErr, InErr, OutDone, InDone, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, OutErr1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (o: OutElem) => Effect.Effect<OutElem1, OutErr1, Env1>,
n: number
): Channel<OutElem1, InElem, OutErr | OutErr1, InErr, OutDone, InDone, Env | Env1>
}
Added in v2.0.0
mergeMap
Returns a new channel which creates a new channel for each emitted element and merges some of them together. Different merge strategies control what happens if there are more than the given maximum number of channels gets created. See Channel.mergeAll
.
Signature
export declare const mergeMap: {
<OutElem, OutElem1, InElem1, OutErr1, InErr1, Z, InDone1, Env1>(
f: (outElem: OutElem) => Channel<OutElem1, InElem1, OutErr1, InErr1, Z, InDone1, Env1>,
options: {
readonly concurrency: number | "unbounded"
readonly bufferSize?: number | undefined
readonly mergeStrategy?: MergeStrategy.MergeStrategy | undefined
}
): <InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem1, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, unknown, InDone & InDone1, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, InElem1, OutErr1, InErr1, Z, InDone1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (outElem: OutElem) => Channel<OutElem1, InElem1, OutErr1, InErr1, Z, InDone1, Env1>,
options: {
readonly concurrency: number | "unbounded"
readonly bufferSize?: number | undefined
readonly mergeStrategy?: MergeStrategy.MergeStrategy | undefined
}
): Channel<OutElem1, InElem & InElem1, OutErr | OutErr1, InErr & InErr1, unknown, InDone & InDone1, Env | Env1>
}
Added in v2.0.0
models
Channel (interface)
A Channel
is a nexus of I/O operations, which supports both reading and writing. A channel may read values of type InElem
and write values of type OutElem
. When the channel finishes, it yields a value of type OutDone
. A channel may fail with a value of type OutErr
.
Channels are the foundation of Streams: both streams and sinks are built on channels. Most users shouldn’t have to use channels directly, as streams and sinks are much more convenient and cover all common use cases. However, when adding new stream and sink operators, or doing something highly specialized, it may be useful to use channels directly.
Channels compose in a variety of ways:
- Piping: One channel can be piped to another channel, assuming the input type of the second is the same as the output type of the first.
- Sequencing: The terminal value of one channel can be used to create another channel, and both the first channel and the function that makes the second channel can be composed into a channel.
- Concatenating: The output of one channel can be used to create other channels, which are all concatenated together. The first channel and the function that makes the other channels can be composed into a channel.
Signature
export interface Channel<
out OutElem,
in InElem = unknown,
out OutErr = never,
in InErr = unknown,
out OutDone = void,
in InDone = unknown,
out Env = never
> extends Channel.Variance<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
Pipeable {
[Unify.typeSymbol]?: unknown
[Unify.unifySymbol]?: ChannelUnify<this>
[Unify.ignoreSymbol]?: ChannelUnifyIgnore
}
Added in v2.0.0
ChannelException (interface)
Represents a generic checked exception which occurs when a Channel
is executed.
Signature
export interface ChannelException<out E> {
readonly _tag: "ChannelException"
readonly [ChannelExceptionTypeId]: ChannelExceptionTypeId
readonly error: E
}
Added in v2.0.0
ChannelUnify (interface)
Signature
export interface ChannelUnify<A extends { [Unify.typeSymbol]?: any }> extends Effect.EffectUnify<A> {
Channel?: () => A[Unify.typeSymbol] extends
| Channel<infer OutElem, infer InElem, infer OutErr, infer InErr, infer OutDone, infer InDone, infer Env>
| infer _
? Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
: never
}
Added in v2.0.0
ChannelUnifyIgnore (interface)
Signature
export interface ChannelUnifyIgnore extends Effect.EffectUnifyIgnore {
Channel?: true
}
Added in v2.0.0
refinements
isChannel
Signature
export declare const isChannel: (
u: unknown
) => u is Channel<unknown, unknown, unknown, unknown, unknown, unknown, unknown>
Added in v3.5.4
isChannelException
Returns true
if the specified value is an ChannelException
, false
otherwise.
Signature
export declare const isChannelException: (u: unknown) => u is ChannelException<unknown>
Added in v2.0.0
sequencing
flatMap
Returns a new channel, which sequentially combines this channel, together with the provided factory function, which creates a second channel based on the terminal value of this channel. The result is a channel that will first perform the functions of this channel, before performing the functions of the created channel (including yielding its terminal value).
Signature
export declare const flatMap: {
<OutDone, OutElem1, InElem1, OutErr1, InErr1, OutDone2, InDone1, Env1>(
f: (d: OutDone) => Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone2, InDone1, Env1>
): <OutElem, InElem, OutErr, InErr, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem,
InElem & InElem1,
OutErr1 | OutErr,
InErr & InErr1,
OutDone2,
InDone & InDone1,
Env1 | Env
>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, InElem1, OutErr1, InErr1, OutDone2, InDone1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (d: OutDone) => Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone2, InDone1, Env1>
): Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr | OutErr1,
InErr & InErr1,
OutDone2,
InDone & InDone1,
Env | Env1
>
}
Added in v2.0.0
flatten
Returns a new channel, which flattens the terminal value of this channel. This function may only be called if the terminal value of this channel is another channel of compatible types.
Signature
export declare const flatten: <
OutElem,
InElem,
OutErr,
InErr,
OutElem1,
InElem1,
OutErr1,
InErr1,
OutDone2,
InDone1,
Env1,
InDone,
Env
>(
self: Channel<
OutElem,
InElem,
OutErr,
InErr,
Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone2, InDone1, Env1>,
InDone,
Env
>
) => Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr | OutErr1,
InErr & InErr1,
OutDone2,
InDone & InDone1,
Env1 | Env
>
Added in v2.0.0
symbols
ChannelExceptionTypeId
Signature
export declare const ChannelExceptionTypeId: typeof ChannelExceptionTypeId
Added in v2.0.0
ChannelExceptionTypeId (type alias)
Signature
export type ChannelExceptionTypeId = typeof ChannelExceptionTypeId
Added in v2.0.0
ChannelTypeId
Signature
export declare const ChannelTypeId: typeof ChannelTypeId
Added in v2.0.0
ChannelTypeId (type alias)
Signature
export type ChannelTypeId = typeof ChannelTypeId
Added in v2.0.0
tracing
withSpan
Wraps the channel with a new span for tracing.
Signature
export declare const withSpan: {
(
name: string,
options?: Tracer.SpanOptions | undefined
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Exclude<Env, Tracer.ParentSpan>>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
name: string,
options?: Tracer.SpanOptions | undefined
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Exclude<Env, Tracer.ParentSpan>>
}
Added in v2.0.0
utils
Channel (namespace)
Added in v2.0.0
Variance (interface)
Signature
export interface Variance<out OutElem, in InElem, out OutErr, in InErr, out OutDone, in InDone, out Env> {
readonly [ChannelTypeId]: VarianceStruct<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
VarianceStruct (interface)
Signature
export interface VarianceStruct<out OutElem, in InElem, out OutErr, in InErr, out OutDone, in InDone, out Env> {
_Env: Types.Covariant<Env>
_InErr: Types.Contravariant<InErr>
_InElem: Types.Contravariant<InElem>
_InDone: Types.Contravariant<InDone>
_OutErr: Types.Covariant<OutErr>
_OutElem: Types.Covariant<OutElem>
_OutDone: Types.Covariant<OutDone>
}
Added in v2.0.0
collect
Returns a new channel, which is the same as this one, except its outputs are filtered and transformed by the specified partial function.
Signature
export declare const collect: {
<OutElem, OutElem2>(
pf: (o: OutElem) => Option.Option<OutElem2>
): <InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, unknown, never, unknown, void, unknown, never>
) => Channel<OutElem2, InElem, OutErr, InErr, OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
pf: (o: OutElem) => Option.Option<OutElem2>
): Channel<OutElem2, InElem, OutErr, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
concatMap
Returns a new channel whose outputs are fed to the specified factory function, which creates new channels in response. These new channels are sequentially concatenated together, and all their outputs appear as outputs of the newly returned channel.
Signature
export declare const concatMap: {
<OutElem, OutElem2, InElem2, OutErr2, InErr2, X, InDone2, Env2>(
f: (o: OutElem) => Channel<OutElem2, InElem2, OutErr2, InErr2, X, InDone2, Env2>
): <Env, InErr, InElem, InDone, OutErr, OutDone>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem2, InElem & InElem2, OutErr2 | OutErr, InErr & InErr2, unknown, InDone & InDone2, Env2 | Env>
<Env, InErr, InElem, InDone, OutErr, OutDone, OutElem, OutElem2, Env2, InErr2, InElem2, InDone2, OutErr2, X>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (o: OutElem) => Channel<OutElem2, InElem2, OutErr2, InErr2, X, InDone2, Env2>
): Channel<OutElem2, InElem & InElem2, OutErr | OutErr2, InErr & InErr2, unknown, InDone & InDone2, Env | Env2>
}
Added in v2.0.0
concatMapWith
Returns a new channel whose outputs are fed to the specified factory function, which creates new channels in response. These new channels are sequentially concatenated together, and all their outputs appear as outputs of the newly returned channel. The provided merging function is used to merge the terminal values of all channels into the single terminal value of the returned channel.
Signature
export declare const concatMapWith: {
<OutElem, OutElem2, InElem2, OutErr2, InErr2, OutDone, InDone2, Env2, OutDone2, OutDone3>(
f: (o: OutElem) => Channel<OutElem2, InElem2, OutErr2, InErr2, OutDone, InDone2, Env2>,
g: (o: OutDone, o1: OutDone) => OutDone,
h: (o: OutDone, o2: OutDone2) => OutDone3
): <Env, InErr, InElem, InDone, OutErr>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone2, InDone, Env>
) => Channel<OutElem2, InElem & InElem2, OutErr2 | OutErr, InErr & InErr2, OutDone3, InDone & InDone2, Env2 | Env>
<
OutElem,
InElem,
OutErr,
InErr,
OutDone2,
InDone,
Env,
OutElem2,
InElem2,
OutErr2,
InErr2,
OutDone,
InDone2,
Env2,
OutDone3
>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone2, InDone, Env>,
f: (o: OutElem) => Channel<OutElem2, InElem2, OutErr2, InErr2, OutDone, InDone2, Env2>,
g: (o: OutDone, o1: OutDone) => OutDone,
h: (o: OutDone, o2: OutDone2) => OutDone3
): Channel<OutElem2, InElem & InElem2, OutErr | OutErr2, InErr & InErr2, OutDone3, InDone & InDone2, Env | Env2>
}
Added in v2.0.0
concatMapWithCustom
Returns a new channel whose outputs are fed to the specified factory function, which creates new channels in response. These new channels are sequentially concatenated together, and all their outputs appear as outputs of the newly returned channel. The provided merging function is used to merge the terminal values of all channels into the single terminal value of the returned channel.
Signature
export declare const concatMapWithCustom: {
<OutElem, OutElem2, InElem2, OutErr2, InErr2, OutDone, InDone2, Env2, OutDone2, OutDone3>(
f: (o: OutElem) => Channel<OutElem2, InElem2, OutErr2, InErr2, OutDone, InDone2, Env2>,
g: (o: OutDone, o1: OutDone) => OutDone,
h: (o: OutDone, o2: OutDone2) => OutDone3,
onPull: (
upstreamPullRequest: UpstreamPullRequest.UpstreamPullRequest<OutElem>
) => UpstreamPullStrategy.UpstreamPullStrategy<OutElem2>,
onEmit: (elem: OutElem2) => ChildExecutorDecision.ChildExecutorDecision
): <Env, InErr, InElem, InDone, OutErr>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone2, InDone, Env>
) => Channel<OutElem2, InElem & InElem2, OutErr2 | OutErr, InErr & InErr2, OutDone3, InDone & InDone2, Env2 | Env>
<
OutElem,
InElem,
OutErr,
InErr,
OutDone2,
InDone,
Env,
OutElem2,
InElem2,
OutErr2,
InErr2,
OutDone,
InDone2,
Env2,
OutDone3
>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone2, InDone, Env>,
f: (o: OutElem) => Channel<OutElem2, InElem2, OutErr2, InErr2, OutDone, InDone2, Env2>,
g: (o: OutDone, o1: OutDone) => OutDone,
h: (o: OutDone, o2: OutDone2) => OutDone3,
onPull: (
upstreamPullRequest: UpstreamPullRequest.UpstreamPullRequest<OutElem>
) => UpstreamPullStrategy.UpstreamPullStrategy<OutElem2>,
onEmit: (elem: OutElem2) => ChildExecutorDecision.ChildExecutorDecision
): Channel<OutElem2, InElem & InElem2, OutErr | OutErr2, InErr & InErr2, OutDone3, InDone & InDone2, Env | Env2>
}
Added in v2.0.0
concatOut
Returns a new channel, which is the concatenation of all the channels that are written out by this channel. This method may only be called on channels that output other channels.
Signature
export declare const concatOut: <OutElem, InElem, OutErr, InErr, InDone, Env, OutDone>(
self: Channel<
Channel<OutElem, InElem, OutErr, InErr, unknown, InDone, Env>,
InElem,
OutErr,
InErr,
OutDone,
InDone,
Env
>
) => Channel<OutElem, InElem, OutErr, InErr, unknown, InDone, Env>
Added in v2.0.0
doneCollect
Returns a new channel, which is the same as this one, except that all the outputs are collected and bundled into a tuple together with the terminal value of this channel.
As the channel returned from this channel collects all of this channel’s output into an in- memory chunk, it is not safe to call this method on channels that output a large or unbounded number of values.
Signature
export declare const doneCollect: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<never, InElem, OutErr, InErr, [Chunk.Chunk<OutElem>, OutDone], InDone, Env>
Added in v2.0.0
drain
Returns a new channel which reads all the elements from upstream’s output channel and ignores them, then terminates with the upstream result value.
Signature
export declare const drain: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<never, InElem, OutErr, InErr, OutDone, InDone, Env>
Added in v2.0.0
embedInput
Returns a new channel which connects the given AsyncInputProducer
as this channel’s input.
Signature
export declare const embedInput: {
<InErr, InElem, InDone>(
input: SingleProducerAsyncInput.AsyncInputProducer<InErr, InElem, InDone>
): <OutElem, OutErr, OutDone, Env>(
self: Channel<OutElem, unknown, OutErr, unknown, OutDone, unknown, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
<OutElem, OutErr, OutDone, Env, InErr, InElem, InDone>(
self: Channel<OutElem, unknown, OutErr, unknown, OutDone, unknown, Env>,
input: SingleProducerAsyncInput.AsyncInputProducer<InErr, InElem, InDone>
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
emitCollect
Returns a new channel that collects the output and terminal value of this channel, which it then writes as output of the returned channel.
Signature
export declare const emitCollect: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<[Chunk.Chunk<OutElem>, OutDone], InElem, OutErr, InErr, void, InDone, Env>
Added in v2.0.0
ensuring
Returns a new channel with an attached finalizer. The finalizer is guaranteed to be executed so long as the channel begins execution (and regardless of whether or not it completes).
Signature
export declare const ensuring: {
<Z, Env1>(
finalizer: Effect.Effect<Z, never, Env1>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, Z, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
finalizer: Effect.Effect<Z, never, Env1>
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env | Env1>
}
Added in v2.0.0
ensuringWith
Returns a new channel with an attached finalizer. The finalizer is guaranteed to be executed so long as the channel begins execution (and regardless of whether or not it completes).
Signature
export declare const ensuringWith: {
<OutDone, OutErr, Env2>(
finalizer: (e: Exit.Exit<OutDone, OutErr>) => Effect.Effect<unknown, never, Env2>
): <OutElem, InElem, InErr, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env2 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, Env2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
finalizer: (e: Exit.Exit<OutDone, OutErr>) => Effect.Effect<unknown, never, Env2>
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env | Env2>
}
Added in v2.0.0
foldCauseChannel
Folds over the result of this channel including any cause of termination.
Signature
export declare const foldCauseChannel: {
<
OutErr,
OutElem1,
InElem1,
OutErr2,
InErr1,
OutDone2,
InDone1,
Env1,
OutDone,
OutElem2,
InElem2,
OutErr3,
InErr2,
OutDone3,
InDone2,
Env2
>(options: {
readonly onFailure: (c: Cause.Cause<OutErr>) => Channel<OutElem1, InElem1, OutErr2, InErr1, OutDone2, InDone1, Env1>
readonly onSuccess: (o: OutDone) => Channel<OutElem2, InElem2, OutErr3, InErr2, OutDone3, InDone2, Env2>
}): <Env, InErr, InElem, InDone, OutElem>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem2 | OutElem,
InElem & InElem1 & InElem2,
OutErr2 | OutErr3,
InErr & InErr1 & InErr2,
OutDone2 | OutDone3,
InDone & InDone1 & InDone2,
Env1 | Env2 | Env
>
<
OutElem,
InElem,
OutErr,
InErr,
OutDone,
InDone,
Env,
OutElem1,
InElem1,
OutErr2,
InErr1,
OutDone2,
InDone1,
Env1,
OutElem2,
InElem2,
OutErr3,
InErr2,
OutDone3,
InDone2,
Env2
>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
options: {
readonly onFailure: (
c: Cause.Cause<OutErr>
) => Channel<OutElem1, InElem1, OutErr2, InErr1, OutDone2, InDone1, Env1>
readonly onSuccess: (o: OutDone) => Channel<OutElem2, InElem2, OutErr3, InErr2, OutDone3, InDone2, Env2>
}
): Channel<
OutElem | OutElem1 | OutElem2,
InElem & InElem1 & InElem2,
OutErr2 | OutErr3,
InErr & InErr1 & InErr2,
OutDone2 | OutDone3,
InDone & InDone1 & InDone2,
Env | Env1 | Env2
>
}
Added in v2.0.0
foldChannel
Folds over the result of this channel.
Signature
export declare const foldChannel: {
<
OutErr,
OutElem1,
InElem1,
OutErr1,
InErr1,
OutDone1,
InDone1,
Env1,
OutDone,
OutElem2,
InElem2,
OutErr2,
InErr2,
OutDone2,
InDone2,
Env2
>(options: {
readonly onFailure: (error: OutErr) => Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>
readonly onSuccess: (done: OutDone) => Channel<OutElem2, InElem2, OutErr2, InErr2, OutDone2, InDone2, Env2>
}): <Env, InErr, InElem, InDone, OutElem>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem2 | OutElem,
InElem & InElem1 & InElem2,
OutErr1 | OutErr2,
InErr & InErr1 & InErr2,
OutDone1 | OutDone2,
InDone & InDone1 & InDone2,
Env1 | Env2 | Env
>
<
OutElem,
InElem,
OutErr,
InErr,
OutDone,
InDone,
Env,
OutElem1,
InElem1,
OutErr1,
InErr1,
OutDone1,
InDone1,
Env1,
OutElem2,
InElem2,
OutErr2,
InErr2,
OutDone2,
InDone2,
Env2
>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
options: {
readonly onFailure: (error: OutErr) => Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>
readonly onSuccess: (done: OutDone) => Channel<OutElem2, InElem2, OutErr2, InErr2, OutDone2, InDone2, Env2>
}
): Channel<
OutElem | OutElem1 | OutElem2,
InElem & InElem1 & InElem2,
OutErr1 | OutErr2,
InErr & InErr1 & InErr2,
OutDone1 | OutDone2,
InDone & InDone1 & InDone2,
Env | Env1 | Env2
>
}
Added in v2.0.0
interruptWhen
Returns a new channel, which is the same as this one, except it will be interrupted when the specified effect completes. If the effect completes successfully before the underlying channel is done, then the returned channel will yield the success value of the effect as its terminal value. On the other hand, if the underlying channel finishes first, then the returned channel will yield the success value of the underlying channel as its terminal value.
Signature
export declare const interruptWhen: {
<OutDone1, OutErr1, Env1>(
effect: Effect.Effect<OutDone1, OutErr1, Env1>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr1 | OutErr, InErr, OutDone1 | OutDone, InDone, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutDone1, OutErr1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
effect: Effect.Effect<OutDone1, OutErr1, Env1>
): Channel<OutElem, InElem, OutErr | OutErr1, InErr, OutDone | OutDone1, InDone, Env | Env1>
}
Added in v2.0.0
interruptWhenDeferred
Returns a new channel, which is the same as this one, except it will be interrupted when the specified deferred is completed. If the deferred is completed before the underlying channel is done, then the returned channel will yield the value of the deferred. Otherwise, if the underlying channel finishes first, then the returned channel will yield the value of the underlying channel.
Signature
export declare const interruptWhenDeferred: {
<OutDone1, OutErr1>(
deferred: Deferred.Deferred<OutDone1, OutErr1>
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr1 | OutErr, InErr, OutDone1 | OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutDone1, OutErr1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
deferred: Deferred.Deferred<OutDone1, OutErr1>
): Channel<OutElem, InElem, OutErr | OutErr1, InErr, OutDone | OutDone1, InDone, Env>
}
Added in v2.0.0
mapInput
Returns a new channel which is the same as this one but applies the given function to the input channel’s done value.
Signature
export declare const mapInput: {
<InDone0, InDone>(
f: (a: InDone0) => InDone
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone0, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, InDone0>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (a: InDone0) => InDone
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone0, Env>
}
Added in v2.0.0
mapInputEffect
Returns a new channel which is the same as this one but applies the given effectual function to the input channel’s done value.
Signature
export declare const mapInputEffect: {
<InDone0, InDone, InErr, Env1>(
f: (i: InDone0) => Effect.Effect<InDone, InErr, Env1>
): <OutElem, InElem, OutErr, OutDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone0, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, InDone0, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (i: InDone0) => Effect.Effect<InDone, InErr, Env1>
): Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone0, Env | Env1>
}
Added in v2.0.0
mapInputError
Returns a new channel which is the same as this one but applies the given function to the input channel’s error value.
Signature
export declare const mapInputError: {
<InErr0, InErr>(
f: (a: InErr0) => InErr
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr0, OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, InErr0>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (a: InErr0) => InErr
): Channel<OutElem, InElem, OutErr, InErr0, OutDone, InDone, Env>
}
Added in v2.0.0
mapInputErrorEffect
Returns a new channel which is the same as this one but applies the given effectual function to the input channel’s error value.
Signature
export declare const mapInputErrorEffect: {
<InErr0, InDone, InErr, Env1>(
f: (error: InErr0) => Effect.Effect<InDone, InErr, Env1>
): <OutElem, InElem, OutErr, OutDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr0, OutDone, InDone, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, InErr0, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (error: InErr0) => Effect.Effect<InDone, InErr, Env1>
): Channel<OutElem, InElem, OutErr, InErr0, OutDone, InDone, Env | Env1>
}
Added in v2.0.0
mapInputIn
Returns a new channel which is the same as this one but applies the given function to the input channel’s output elements.
Signature
export declare const mapInputIn: {
<InElem0, InElem>(
f: (a: InElem0) => InElem
): <OutElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem0, OutErr, InErr, OutDone, InDone, Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, InElem0>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (a: InElem0) => InElem
): Channel<OutElem, InElem0, OutErr, InErr, OutDone, InDone, Env>
}
Added in v2.0.0
mapInputInEffect
Returns a new channel which is the same as this one but applies the given effectual function to the input channel’s output elements.
Signature
export declare const mapInputInEffect: {
<InElem0, InElem, InErr, Env1>(
f: (a: InElem0) => Effect.Effect<InElem, InErr, Env1>
): <OutElem, OutErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem0, OutErr, InErr, OutDone, InDone, Env1 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, InElem0, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
f: (a: InElem0) => Effect.Effect<InElem, InErr, Env1>
): Channel<OutElem, InElem0, OutErr, InErr, OutDone, InDone, Env | Env1>
}
Added in v2.0.0
mergeAll
Signature
export declare const mergeAll: (options: {
readonly concurrency: number | "unbounded"
readonly bufferSize?: number | undefined
readonly mergeStrategy?: MergeStrategy.MergeStrategy | undefined
}) => <OutElem, InElem1, OutErr1, InErr1, InDone1, Env1, InElem, OutErr, InErr, InDone, Env>(
channels: Channel<
Channel<OutElem, InElem1, OutErr1, InErr1, unknown, InDone1, Env1>,
InElem,
OutErr,
InErr,
unknown,
InDone,
Env
>
) => Channel<OutElem, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, unknown, InDone & InDone1, Env1 | Env>
Added in v2.0.0
mergeAllUnbounded
Signature
export declare const mergeAllUnbounded: <
OutElem,
InElem1,
OutErr1,
InErr1,
InDone1,
Env1,
InElem,
OutErr,
InErr,
InDone,
Env
>(
channels: Channel<
Channel<OutElem, InElem1, OutErr1, InErr1, unknown, InDone1, Env1>,
InElem,
OutErr,
InErr,
unknown,
InDone,
Env
>
) => Channel<OutElem, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, unknown, InDone & InDone1, Env1 | Env>
Added in v2.0.0
mergeAllUnboundedWith
Signature
export declare const mergeAllUnboundedWith: <
OutElem,
InElem1,
OutErr1,
InErr1,
OutDone,
InDone1,
Env1,
InElem,
OutErr,
InErr,
InDone,
Env
>(
channels: Channel<
Channel<OutElem, InElem1, OutErr1, InErr1, OutDone, InDone1, Env1>,
InElem,
OutErr,
InErr,
OutDone,
InDone,
Env
>,
f: (o1: OutDone, o2: OutDone) => OutDone
) => Channel<OutElem, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, OutDone, InDone & InDone1, Env1 | Env>
Added in v2.0.0
mergeAllWith
Signature
export declare const mergeAllWith: ({
bufferSize,
concurrency,
mergeStrategy
}: {
readonly concurrency: number | "unbounded"
readonly bufferSize?: number | undefined
readonly mergeStrategy?: MergeStrategy.MergeStrategy | undefined
}) => <OutElem, InElem1, OutErr1, InErr1, OutDone, InDone1, Env1, InElem, OutErr, InErr, InDone, Env>(
channels: Channel<
Channel<OutElem, InElem1, OutErr1, InErr1, OutDone, InDone1, Env1>,
InElem,
OutErr,
InErr,
OutDone,
InDone,
Env
>,
f: (o1: OutDone, o2: OutDone) => OutDone
) => Channel<OutElem, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, OutDone, InDone & InDone1, Env1 | Env>
Added in v2.0.0
mergeOut
Returns a new channel which merges a number of channels emitted by this channel using the back pressuring merge strategy. See Channel.mergeAll
.
Signature
export declare const mergeOut: {
(
n: number
): <OutElem1, InElem1, OutErr1, InErr1, Z, InDone1, Env1, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<
Channel<OutElem1, InElem1, OutErr1, InErr1, Z, InDone1, Env1>,
InElem,
OutErr,
InErr,
OutDone,
InDone,
Env
>
) => Channel<OutElem1, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, unknown, InDone & InDone1, Env1 | Env>
<OutElem1, InElem1, OutErr1, InErr1, Z, InDone1, Env1, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<
Channel<OutElem1, InElem1, OutErr1, InErr1, Z, InDone1, Env1>,
InElem,
OutErr,
InErr,
OutDone,
InDone,
Env
>,
n: number
): Channel<OutElem1, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, unknown, InDone & InDone1, Env1 | Env>
}
Added in v2.0.0
mergeOutWith
Returns a new channel which merges a number of channels emitted by this channel using the back pressuring merge strategy and uses a given function to merge each completed subchannel’s result value. See Channel.mergeAll
.
Signature
export declare const mergeOutWith: {
<OutDone1>(
n: number,
f: (o1: OutDone1, o2: OutDone1) => OutDone1
): <OutElem1, InElem1, OutErr1, InErr1, InDone1, Env1, InElem, OutErr, InErr, InDone, Env>(
self: Channel<
Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>,
InElem,
OutErr,
InErr,
OutDone1,
InDone,
Env
>
) => Channel<OutElem1, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, OutDone1, InDone & InDone1, Env1 | Env>
<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1, InElem, OutErr, InErr, InDone, Env>(
self: Channel<
Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>,
InElem,
OutErr,
InErr,
OutDone1,
InDone,
Env
>,
n: number,
f: (o1: OutDone1, o2: OutDone1) => OutDone1
): Channel<OutElem1, InElem & InElem1, OutErr1 | OutErr, InErr & InErr1, OutDone1, InDone & InDone1, Env1 | Env>
}
Added in v2.0.0
mergeWith
Returns a new channel, which is the merge of this channel and the specified channel, where the behavior of the returned channel on left or right early termination is decided by the specified leftDone
and rightDone
merge decisions.
Signature
export declare const mergeWith: {
<
OutElem1,
InElem1,
OutErr1,
InErr1,
OutDone1,
InDone1,
Env1,
OutDone,
OutErr,
OutErr2,
OutDone2,
OutErr3,
OutDone3
>(options: {
readonly other: Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>
readonly onSelfDone: (
exit: Exit.Exit<OutDone, OutErr>
) => MergeDecision.MergeDecision<Env1, OutErr1, OutDone1, OutErr2, OutDone2>
readonly onOtherDone: (
ex: Exit.Exit<OutDone1, OutErr1>
) => MergeDecision.MergeDecision<Env1, OutErr, OutDone, OutErr3, OutDone3>
}): <Env, InErr, InElem, InDone, OutElem>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem,
InElem & InElem1,
OutErr2 | OutErr3,
InErr & InErr1,
OutDone2 | OutDone3,
InDone & InDone1,
Env1 | Env
>
<
OutElem,
InElem,
OutErr,
InErr,
OutDone,
InDone,
Env,
OutElem1,
InElem1,
OutErr1,
InErr1,
OutDone1,
InDone1,
Env1,
OutErr2,
OutDone2,
OutErr3,
OutDone3
>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
options: {
readonly other: Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>
readonly onSelfDone: (
exit: Exit.Exit<OutDone, OutErr>
) => MergeDecision.MergeDecision<Env1, OutErr1, OutDone1, OutErr2, OutDone2>
readonly onOtherDone: (
ex: Exit.Exit<OutDone1, OutErr1>
) => MergeDecision.MergeDecision<Env1, OutErr, OutDone, OutErr3, OutDone3>
}
): Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr2 | OutErr3,
InErr & InErr1,
OutDone2 | OutDone3,
InDone & InDone1,
Env | Env1
>
}
Added in v2.0.0
pipeTo
Returns a new channel that pipes the output of this channel into the specified channel. The returned channel has the input type of this channel, and the output type of the specified channel, terminating with the value of the specified channel.
Signature
export declare const pipeTo: {
<OutElem2, OutElem, OutErr2, OutErr, OutDone2, OutDone, Env2>(
that: Channel<OutElem2, OutElem, OutErr2, OutErr, OutDone2, OutDone, Env2>
): <InElem, InErr, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem2, InElem, OutErr2, InErr, OutDone2, InDone, Env2 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem2, OutErr2, OutDone2, Env2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
that: Channel<OutElem2, OutElem, OutErr2, OutErr, OutDone2, OutDone, Env2>
): Channel<OutElem2, InElem, OutErr2, InErr, OutDone2, InDone, Env | Env2>
}
Added in v2.0.0
pipeToOrFail
Returns a new channel that pipes the output of this channel into the specified channel and preserves this channel’s failures without providing them to the other channel for observation.
Signature
export declare const pipeToOrFail: {
<OutElem2, OutElem, OutErr2, OutDone2, OutDone, Env2>(
that: Channel<OutElem2, OutElem, OutErr2, never, OutDone2, OutDone, Env2>
): <InElem, OutErr, InErr, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem2, InElem, OutErr2 | OutErr, InErr, OutDone2, InDone, Env2 | Env>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem2, OutErr2, OutDone2, Env2>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
that: Channel<OutElem2, OutElem, OutErr2, never, OutDone2, OutDone, Env2>
): Channel<OutElem2, InElem, OutErr | OutErr2, InErr, OutDone2, InDone, Env | Env2>
}
Added in v2.0.0
repeated
Creates a channel which repeatedly runs this channel.
Signature
export declare const repeated: <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
Added in v2.0.0
zipping
zip
Returns a new channel that is the sequential composition of this channel and the specified channel. The returned channel terminates with a tuple of the terminal values of both channels.
Signature
export declare const zip: {
<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
that: Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>,
options?: { readonly concurrent?: boolean | undefined } | undefined
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem,
InElem & InElem1,
OutErr1 | OutErr,
InErr & InErr1,
readonly [OutDone, OutDone1],
InDone & InDone1,
Env1 | Env
>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
that: Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>,
options?: { readonly concurrent?: boolean | undefined } | undefined
): Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr | OutErr1,
InErr & InErr1,
readonly [OutDone, OutDone1],
InDone & InDone1,
Env | Env1
>
}
Added in v2.0.0
zipLeft
Returns a new channel that is the sequential composition of this channel and the specified channel. The returned channel terminates with the terminal value of this channel.
Signature
export declare const zipLeft: {
<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
that: Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>,
options?: { readonly concurrent?: boolean | undefined } | undefined
): <OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem,
InElem & InElem1,
OutErr1 | OutErr,
InErr & InErr1,
OutDone,
InDone & InDone1,
Env1 | Env
>
<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env, OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
that: Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>,
options?: { readonly concurrent?: boolean | undefined } | undefined
): Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr | OutErr1,
InErr & InErr1,
OutDone,
InDone & InDone1,
Env | Env1
>
}
Added in v2.0.0
zipRight
Returns a new channel that is the sequential composition of this channel and the specified channel. The returned channel terminates with the terminal value of that channel.
Signature
export declare const zipRight: {
<Env1, InErr1, InElem1, InDone1, OutErr1, OutElem1, OutDone1>(
that: Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>,
options?: { readonly concurrent?: boolean | undefined }
): <Env, InErr, InElem, InDone, OutErr, OutElem, OutDone>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>
) => Channel<
OutElem1 | OutElem,
InElem & InElem1,
OutErr1 | OutErr,
InErr & InErr1,
OutDone1,
InDone & InDone1,
Env1 | Env
>
<Env, InErr, InElem, InDone, OutErr, OutElem, OutDone, Env1, InErr1, InElem1, InDone1, OutErr1, OutElem1, OutDone1>(
self: Channel<OutElem, InElem, OutErr, InErr, OutDone, InDone, Env>,
that: Channel<OutElem1, InElem1, OutErr1, InErr1, OutDone1, InDone1, Env1>,
options?: { readonly concurrent?: boolean | undefined }
): Channel<
OutElem | OutElem1,
InElem & InElem1,
OutErr | OutErr1,
InErr & InErr1,
OutDone1,
InDone & InDone1,
Env | Env1
>
}
Added in v2.0.0