Packages

final class Balance[T] extends GraphStage[UniformFanOutShape[T, T]]

Fan-out the stream to several streams. Each upstream element is emitted to the first available downstream consumer. It will not shut down until the subscriptions for at least two downstream subscribers have been established.

A Balance has one in port and 2 or more out ports.

Emits when any of the outputs stops backpressuring; emits the element to the first available output

Backpressures when all of the outputs backpressure

Completes when upstream completes

Cancels when If eagerCancel is enabled: when any downstream cancels; otherwise: when all downstreams cancel

Source
Graph.scala
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Balance
  2. GraphStage
  3. GraphStageWithMaterializedValue
  4. Graph
  5. AnyRef
  6. Any
Implicitly
  1. by any2stringadd
  2. by StringFormat
  3. by Ensuring
  4. by ArrowAssoc
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Balance(outputPorts: Int, waitForAllDownstreams: Boolean, eagerCancel: Boolean)
  2. new Balance(outputPorts: Int, waitForAllDownstreams: Boolean)
    Annotations
    @Deprecated @deprecated
    Deprecated

    (Since version 2.5.12) Use the constructor which also specifies the eagerCancel parameter

Type Members

  1. type Shape = UniformFanOutShape[T, T]

    Type-level accessor for the shape parameter of this graph.

    Type-level accessor for the shape parameter of this graph.

    Definition Classes
    Graph

Value Members

  1. def addAttributes(attr: Attributes): Graph[UniformFanOutShape[T, T], NotUsed]

    Add the given attributes to this Graph.

    Add the given attributes to this Graph. If the specific attribute was already present on this graph this means the added attribute will be more specific than the existing one. If this Source is a composite of multiple graphs, new attributes on the composite will be less specific than attributes set directly on the individual graphs of the composite.

    Definition Classes
    Graph
  2. def async(dispatcher: String, inputBufferSize: Int): Graph[UniformFanOutShape[T, T], NotUsed]

    Put an asynchronous boundary around this Graph

    Put an asynchronous boundary around this Graph

    dispatcher

    Run the graph on this dispatcher

    inputBufferSize

    Set the input buffer to this size for the graph

    Definition Classes
    Graph
  3. def async(dispatcher: String): Graph[UniformFanOutShape[T, T], NotUsed]

    Put an asynchronous boundary around this Graph

    Put an asynchronous boundary around this Graph

    dispatcher

    Run the graph on this dispatcher

    Definition Classes
    Graph
  4. def async: Graph[UniformFanOutShape[T, T], NotUsed]

    Put an asynchronous boundary around this Graph

    Put an asynchronous boundary around this Graph

    Definition Classes
    Graph
  5. def createLogic(inheritedAttributes: Attributes): GraphStageLogic
    Definition Classes
    BalanceGraphStage
  6. final def createLogicAndMaterializedValue(inheritedAttributes: Attributes): (GraphStageLogic, NotUsed)
  7. val eagerCancel: Boolean
  8. val in: Inlet[T]
  9. def initialAttributes: Attributes
  10. def named(name: String): Graph[UniformFanOutShape[T, T], NotUsed]
    Definition Classes
    Graph
  11. val out: IndexedSeq[Outlet[T]]
  12. val outputPorts: Int
  13. val shape: UniformFanOutShape[T, T]

    The shape of a graph is all that is externally visible: its inlets and outlets.

    The shape of a graph is all that is externally visible: its inlets and outlets.

    Definition Classes
    BalanceGraph
  14. def toString(): String
    Definition Classes
    Balance → AnyRef → Any
  15. val waitForAllDownstreams: Boolean
  16. final def withAttributes(attr: Attributes): Graph[UniformFanOutShape[T, T], NotUsed]
    Definition Classes
    GraphStageWithMaterializedValueGraph