monix.reactive.observers

ConnectableSubscriber

final class ConnectableSubscriber[-A] extends Subscriber[A]

Wraps a Subscriber into an implementation that abstains from emitting items until the call to connect() happens. Prior to connect() you can enqueue events for delivery once connect() happens, but before any items emitted by onNext / onComplete and onError.

Example:

val out = ConnectableSubscriber(subscriber)

// schedule onNext event, after connect()
out.onNext("c")

// schedule event "a" to be emitted first
out.pushFirst("a")
// schedule event "b" to be emitted second
out.pushFirst("b")

// underlying observer now gets events "a", "b", "c" in order
out.connect()

Example of an observer ended in error:

val out = ConnectableSubscriber(subscriber)

// schedule onNext event, after connect()
out.onNext("c")

out.pushFirst("a") // event "a" to be emitted first
out.pushFirst("b") // event "b" to be emitted second

// schedule an onError sent downstream, once connect()
// happens, but after "a" and "b"
out.pushError(new RuntimeException())

// underlying observer receives ...
// onNext("a") -> onNext("b") -> onError(RuntimeException)
out.connect()

// NOTE: that onNext("c") never happens
Self Type
ConnectableSubscriber[A]
Linear Supertypes
Subscriber[A], Observer[A], Serializable, Serializable, AnyRef, Any
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. ConnectableSubscriber
  2. Subscriber
  3. Observer
  4. Serializable
  5. Serializable
  6. AnyRef
  7. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Value Members

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

    Definition Classes
    AnyRef
  2. final def !=(arg0: Any): Boolean

    Definition Classes
    Any
  3. final def ##(): Int

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

    Definition Classes
    AnyRef
  5. final def ==(arg0: Any): Boolean

    Definition Classes
    Any
  6. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  7. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. def connect(): CancelableFuture[Ack]

    Connects the underling observer to the upstream publisher.

    Connects the underling observer to the upstream publisher.

    This function should be idempotent. Calling it multiple times should have the same effect as calling it once.

  9. final def eq(arg0: AnyRef): Boolean

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

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

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

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

    Definition Classes
    AnyRef → Any
  14. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  15. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  16. final def notify(): Unit

    Definition Classes
    AnyRef
  17. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  18. def onComplete(): Unit

    The Subscriber.onComplete method that pushes the complete event to the underlying observer.

    The Subscriber.onComplete method that pushes the complete event to the underlying observer.

    It will wait for connect to happen and the queue of scheduled events to be drained.

    Definition Classes
    ConnectableSubscriberObserver
  19. def onError(ex: Throwable): Unit

    The Subscriber.onError method that pushes an error event to the underlying observer.

    The Subscriber.onError method that pushes an error event to the underlying observer.

    It will wait for connect to happen and the queue of scheduled events to be drained.

    Definition Classes
    ConnectableSubscriberObserver
  20. def onNext(elem: A): Future[Ack]

    The Subscriber.onNext method that pushes events to the underlying subscriber.

    The Subscriber.onNext method that pushes events to the underlying subscriber.

    It will back-pressure by means of its Future[Ack] result until connect happens and the underlying queue of scheduled events have been drained.

    Definition Classes
    ConnectableSubscriberObserver
  21. def pushComplete(): Unit

    Schedule a complete event when connect happens, but before any elements scheduled with pushFirst or pushFirstAll.

    Schedule a complete event when connect happens, but before any elements scheduled with pushFirst or pushFirstAll.

    After pushComplete no more pushFirst or onNext events are accepted.

  22. def pushError(ex: Throwable): Unit

    Schedule an error event when connect happens, but before any elements scheduled with pushFirst or pushFirstAll.

    Schedule an error event when connect happens, but before any elements scheduled with pushFirst or pushFirstAll.

    After pushError no more pushFirst or onNext events are accepted.

  23. def pushFirst(elem: A): Unit

    Schedule one element to be pushed to the underlying subscriber when connect happens.

    Schedule one element to be pushed to the underlying subscriber when connect happens.

    The given elements are appended to a queue that will be drained on connect. Afterwards no more elements are allowed to be pushed in the queue.

    These elements are streamed before any elements that will eventually get streamed with onNext, because of the applied back-pressure from onNext.

  24. def pushFirstAll[U <: A](xs: TraversableOnce[U]): Unit

    Schedule elements to be pushed to the underlying subscriber when connect happens.

    Schedule elements to be pushed to the underlying subscriber when connect happens.

    The given elements are appended to a queue that will be drained on connect. Afterwards no more elements are allowed to be pushed in the queue.

    These elements are streamed before any elements that will eventually get streamed with onNext, because of the applied back-pressure from onNext.

  25. implicit val scheduler: Scheduler

    Definition Classes
    ConnectableSubscriberSubscriber
  26. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  27. def toString(): String

    Definition Classes
    AnyRef → Any
  28. final def wait(): Unit

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

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

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from Subscriber[A]

Inherited from Observer[A]

Inherited from Serializable

Inherited from Serializable

Inherited from AnyRef

Inherited from Any

Ungrouped