trait
ZPipeline[+LowerEnv, -UpperEnv, +LowerErr, -UpperErr, +LowerElem, -UpperElem] extends ZPipelineVersionSpecific[LowerEnv, UpperEnv, LowerErr, UpperErr, LowerElem, UpperElem]
Type Members
-
abstract
type
OutElem[Elem]
-
abstract
type
OutEnv[Env]
-
abstract
type
OutErr[Err]
Abstract Value Members
-
abstract
def
apply[Env >: LowerEnv <: UpperEnv, Err >: LowerErr <: UpperErr, Elem >: LowerElem <: UpperElem](stream: ZStream[Env, Err, Elem])(implicit trace: ZTraceElement): ZStream[OutEnv[Env], OutErr[Err], OutElem[Elem]]
Concrete Value Members
-
final
def
!=(arg0: Any): Boolean
-
final
def
##(): Int
-
def
<<<[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2](that: ZPipeline[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2])(implicit composeEnv: ZCompose[LowerEnv2, UpperEnv2, OutEnv, LowerEnv, UpperEnv, OutEnv], composeErr: ZCompose[LowerErr2, UpperErr2, OutErr, LowerErr, UpperErr, OutErr], composeElem: ZCompose[LowerElem2, UpperElem2, OutElem, LowerElem, UpperElem, OutElem]): WithOut[Lower, Upper, Lower, Upper, Lower, Upper, Out, Out, Out]
-
final
def
==(arg0: Any): Boolean
-
def
>>>[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2](that: ZPipeline[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2])(implicit composeEnv: ZCompose[LowerEnv, UpperEnv, OutEnv, LowerEnv2, UpperEnv2, OutEnv], composeErr: ZCompose[LowerErr, UpperErr, OutErr, LowerErr2, UpperErr2, OutErr], composeElem: ZCompose[LowerElem, UpperElem, OutElem, LowerElem2, UpperElem2, OutElem]): WithOut[Lower, Upper, Lower, Upper, Lower, Upper, Out, Out, Out]
-
def
@@[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2](that: ZPipeline[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2])(implicit composeEnv: ZCompose[LowerEnv, UpperEnv, OutEnv, LowerEnv2, UpperEnv2, OutEnv], composeErr: ZCompose[LowerErr, UpperErr, OutErr, LowerErr2, UpperErr2, OutErr], composeElem: ZCompose[LowerElem, UpperElem, OutElem, LowerElem2, UpperElem2, OutElem]): WithOut[Lower, Upper, Lower, Upper, Lower, Upper, Out, Out, Out]
-
def
andThen[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2](that: ZPipeline[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2])(implicit composeEnv: ZCompose[LowerEnv, UpperEnv, OutEnv, LowerEnv2, UpperEnv2, OutEnv], composeErr: ZCompose[LowerErr, UpperErr, OutErr, LowerErr2, UpperErr2, OutErr], composeElem: ZCompose[LowerElem, UpperElem, OutElem, LowerElem2, UpperElem2, OutElem]): WithOut[Lower, Upper, Lower, Upper, Lower, Upper, Out, Out, Out]
-
final
def
asInstanceOf[T0]: T0
-
def
clone(): AnyRef
-
def
compose[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2](that: ZPipeline[LowerEnv2, UpperEnv2, LowerErr2, UpperErr2, LowerElem2, UpperElem2])(implicit composeEnv: ZCompose[LowerEnv2, UpperEnv2, OutEnv, LowerEnv, UpperEnv, OutEnv], composeErr: ZCompose[LowerErr2, UpperErr2, OutErr, LowerErr, UpperErr, OutErr], composeElem: ZCompose[LowerElem2, UpperElem2, OutElem, LowerElem, UpperElem, OutElem]): WithOut[Lower, Upper, Lower, Upper, Lower, Upper, Out, Out, Out]
-
final
def
eq(arg0: AnyRef): Boolean
-
def
equals(arg0: Any): Boolean
-
def
finalize(): Unit
-
final
def
getClass(): Class[_]
-
def
hashCode(): Int
-
final
def
isInstanceOf[T0]: Boolean
-
final
def
ne(arg0: AnyRef): Boolean
-
final
def
notify(): Unit
-
final
def
notifyAll(): Unit
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
-
def
toString(): String
-
final
def
wait(): Unit
-
final
def
wait(arg0: Long, arg1: Int): Unit
-
final
def
wait(arg0: Long): Unit
Inherited from AnyRef
Inherited from Any
A
ZPipeline
is a polymorphic stream transformer. Pipelines accept a stream as input, and return the transformed stream as output.Pipelines can be thought of as a recipe for calling a bunch of methods on a source stream, to yield a new (transformed) stream. A nice mental model is the following type alias:
This encoding of a pipeline with a type alias is not used because it does not infer well. In its place, this trait captures the polymorphism inherent to many pipelines, which can therefore be more flexible about the environment and error types of the streams they transform.
There is no fundamental requirement for pipelines to exist, because everything pipelines do can be done directly on a stream. However, because pipelines separate the stream transformation from the source stream itself, it becomes possible to abstract over stream transformations at the level of values, creating, storing, and passing around reusable transformation pipelines that can be applied to many different streams.
The most common way to create a pipeline is to convert a sink into a pipeline (in general, transforming elements of a stream requires the power of a sink). However, the companion object has lots of other pipeline constructors based on the methods of stream.