Packages

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

Wraps an underlying Subscriber into an implementation that caches all events until the call to connect() happens. After being connected, the buffer is drained into the underlying observer, after which all subsequent events are pushed directly.

Self Type
CacheUntilConnectSubscriber[A]
Source
CacheUntilConnectSubscriber.scala
Linear Supertypes
Subscriber[A], Observer[A], Serializable, Serializable, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. CacheUntilConnectSubscriber
  2. Subscriber
  3. Observer
  4. Serializable
  5. Serializable
  6. AnyRef
  7. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Value Members

  1. def connect(): CancelableFuture[Ack]

    Connects the underling observer to the upstream publisher.

    Connects the underling observer to the upstream publisher.

    Until this call happens, the underlying observer will not receive any events. Instead all incoming events are cached. And after connect the cached events will be fed in the underlying subscriber and afterwards we connect the underlying subscriber directly to the upstream source.

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

  2. 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 cached events to be drained.

    Definition Classes
    CacheUntilConnectSubscriberObserver
  3. 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 cached events to be drained.

    Definition Classes
    CacheUntilConnectSubscriberObserver
  4. 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 cached events have been drained.

    Definition Classes
    CacheUntilConnectSubscriberObserver
  5. implicit val scheduler: Scheduler