Class/Object

org.squbs.pattern.stream

BroadcastBufferAtLeastOnce

Related Docs: object BroadcastBufferAtLeastOnce | package stream

Permalink

class BroadcastBufferAtLeastOnce[T] extends BroadcastBufferBase[T, Event[T]]

Fan-out the stream to several streams emitting each incoming upstream element to all downstream consumers.

Emits when one of the inputs has an element available

Does not back-pressure upstream when downstream back-pressures, instead buffers the stream element to memory mapped queue

Completes when upstream completes and all downstream finish consuming stream elements

Cancels when downstream cancels

A commit guarantee can be ensured to avoid data lost while consuming stream elements by adding a commit stage after downstream consumer.

Linear Supertypes
BroadcastBufferBase[T, Event[T]], GraphStage[UniformFanOutShape[T, Event[T]]], GraphStageWithMaterializedValue[UniformFanOutShape[T, Event[T]], NotUsed], Graph[UniformFanOutShape[T, Event[T]], NotUsed], AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. BroadcastBufferAtLeastOnce
  2. BroadcastBufferBase
  3. GraphStage
  4. GraphStageWithMaterializedValue
  5. Graph
  6. AnyRef
  7. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new BroadcastBufferAtLeastOnce(persistDir: File)(implicit serializer: QueueSerializer[T], system: ActorSystem)

    Permalink
  2. new BroadcastBufferAtLeastOnce(config: Config)(implicit serializer: QueueSerializer[T], system: ActorSystem)

    Permalink

Type Members

  1. type Shape = UniformFanOutShape[T, Event[T]]

    Permalink
    Definition Classes
    Graph

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. def addAttributes(attr: Attributes): Graph[UniformFanOutShape[T, Event[T]], NotUsed]

    Permalink
    Definition Classes
    Graph
  5. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  6. def async: Graph[UniformFanOutShape[T, Event[T]], NotUsed]

    Permalink
    Definition Classes
    Graph
  7. def autoCommit(outputPortId: Int, index: Long): Unit

    Permalink
    Attributes
    protected
    Definition Classes
    BroadcastBufferBase
  8. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  9. def commit[U]: Flow[Event[U], Event[U], NotUsed]

    Permalink
  10. def createLogic(inheritedAttributes: Attributes): GraphStageLogic

    Permalink
    Definition Classes
    BroadcastBufferBase → GraphStage
  11. final def createLogicAndMaterializedValue(inheritedAttributes: Attributes): (GraphStageLogic, NotUsed)

    Permalink
    Definition Classes
    GraphStage → GraphStageWithMaterializedValue
  12. def elementOut(e: Event[T]): Event[T]

    Permalink
    Attributes
    protected
    Definition Classes
    BroadcastBufferAtLeastOnceBroadcastBufferBase
  13. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  14. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  15. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  16. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  17. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  18. def initialAttributes: Attributes

    Permalink
    Attributes
    protected
    Definition Classes
    GraphStageWithMaterializedValue
  19. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  20. final lazy val module: Module

    Permalink
    Definition Classes
    GraphStageWithMaterializedValue → Graph
  21. def named(name: String): Graph[UniformFanOutShape[T, Event[T]], NotUsed]

    Permalink
    Definition Classes
    Graph
  22. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  23. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  24. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  25. val queueCloserActor: ActorRef

    Permalink
    Attributes
    protected
    Definition Classes
    BroadcastBufferBase
  26. val shape: UniformFanOutShape[T, Event[T]]

    Permalink
    Definition Classes
    BroadcastBufferBase → Graph
  27. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  28. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  29. var upstreamFailed: Boolean

    Permalink
    Attributes
    protected
    Definition Classes
    BroadcastBufferBase
  30. var upstreamFinished: Boolean

    Permalink
    Attributes
    protected
    Definition Classes
    BroadcastBufferBase
  31. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  32. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  33. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  34. final def withAttributes(attr: Attributes): Graph[UniformFanOutShape[T, Event[T]], NotUsed]

    Permalink
    Definition Classes
    GraphStageWithMaterializedValue → Graph
  35. def withOnCommitCallback(onCommitCallback: (Int) ⇒ Unit): BroadcastBufferAtLeastOnce[T]

    Permalink
  36. def withOnPushCallback(onPushCallback: () ⇒ Unit): BroadcastBufferAtLeastOnce[T]

    Permalink

Inherited from BroadcastBufferBase[T, Event[T]]

Inherited from GraphStage[UniformFanOutShape[T, Event[T]]]

Inherited from GraphStageWithMaterializedValue[UniformFanOutShape[T, Event[T]], NotUsed]

Inherited from Graph[UniformFanOutShape[T, Event[T]], NotUsed]

Inherited from AnyRef

Inherited from Any

Ungrouped