public abstract class Completable extends java.lang.Object implements CompletableSource
Constructor and Description |
---|
Completable() |
Modifier and Type | Method and Description |
---|---|
static Completable |
amb(java.lang.Iterable<? extends CompletableSource> sources)
Returns a Completable which terminates as soon as one of the source Completables
terminates (normally or with an error) and cancels all other Completables.
|
static Completable |
ambArray(CompletableSource... sources)
Returns a Completable which terminates as soon as one of the source Completables
terminates (normally or with an error) and cancels all other Completables.
|
Completable |
ambWith(CompletableSource other)
Returns a Completable that emits the a terminated event of either this Completable
or the other Completable whichever fires first.
|
Completable |
andThen(CompletableSource next)
Returns a Completable that first runs this Completable
and then the other completable.
|
<T> Maybe<T> |
andThen(MaybeSource<T> next)
Returns a
Maybe which will subscribe to this Completable and once that is completed then
will subscribe to the next MaybeSource. |
<T> Observable<T> |
andThen(ObservableSource<T> next)
Returns an Observable which will subscribe to this Completable and once that is completed then
will subscribe to the
next ObservableSource. |
<T> Flowable<T> |
andThen(org.reactivestreams.Publisher<T> next)
Returns a Flowable which will subscribe to this Completable and once that is completed then
will subscribe to the
next Flowable. |
<T> Single<T> |
andThen(SingleSource<T> next)
Returns a Single which will subscribe to this Completable and once that is completed then
will subscribe to the
next SingleSource. |
void |
blockingAwait()
Subscribes to and awaits the termination of this Completable instance in a blocking manner and
rethrows any exception emitted.
|
boolean |
blockingAwait(long timeout,
java.util.concurrent.TimeUnit unit)
Subscribes to and awaits the termination of this Completable instance in a blocking manner
with a specific timeout and rethrows any exception emitted within the timeout window.
|
java.lang.Throwable |
blockingGet()
Subscribes to this Completable instance and blocks until it terminates, then returns null or
the emitted exception if any.
|
java.lang.Throwable |
blockingGet(long timeout,
java.util.concurrent.TimeUnit unit)
Subscribes to this Completable instance and blocks until it terminates or the specified timeout
elapses, then returns null for normal termination or the emitted exception if any.
|
Completable |
cache()
Subscribes to this Completable only once, when the first CompletableObserver
subscribes to the result Completable, caches its terminal event
and relays/replays it to observers.
|
static Completable |
complete()
Returns a Completable instance that completes immediately when subscribed to.
|
Completable |
compose(CompletableTransformer transformer)
Calls the given transformer function with this instance and returns the function's resulting
Completable.
|
static Completable |
concat(java.lang.Iterable<? extends CompletableSource> sources)
Returns a Completable which completes only when all sources complete, one after another.
|
static Completable |
concat(org.reactivestreams.Publisher<? extends CompletableSource> sources)
Returns a Completable which completes only when all sources complete, one after another.
|
static Completable |
concat(org.reactivestreams.Publisher<? extends CompletableSource> sources,
int prefetch)
Returns a Completable which completes only when all sources complete, one after another.
|
static Completable |
concatArray(CompletableSource... sources)
Returns a Completable which completes only when all sources complete, one after another.
|
Completable |
concatWith(CompletableSource other)
Concatenates this Completable with another Completable.
|
static Completable |
create(CompletableOnSubscribe source)
Provides an API (via a cold Completable) that bridges the reactive world with the callback-style world.
|
static Completable |
defer(java.util.concurrent.Callable<? extends CompletableSource> completableSupplier)
Defers the subscription to a Completable instance returned by a supplier.
|
Completable |
delay(long delay,
java.util.concurrent.TimeUnit unit)
Returns a Completable which delays the emission of the completion event by the given time.
|
Completable |
delay(long delay,
java.util.concurrent.TimeUnit unit,
Scheduler scheduler)
Returns a Completable which delays the emission of the completion event by the given time while
running on the specified scheduler.
|
Completable |
delay(long delay,
java.util.concurrent.TimeUnit unit,
Scheduler scheduler,
boolean delayError)
Returns a Completable which delays the emission of the completion event, and optionally the error as well, by the given time while
running on the specified scheduler.
|
Completable |
doAfterTerminate(Action onAfterTerminate)
Returns a Completable instance that calls the given onTerminate callback after this Completable
completes normally or with an exception
Scheduler:
doAfterTerminate does not operate by default on a particular Scheduler .
|
Completable |
doFinally(Action onFinally)
Calls the specified action after this Completable signals onError or onComplete or gets disposed by
the downstream.
|
Completable |
doOnComplete(Action onComplete)
Returns a Completable which calls the given onComplete callback if this Completable completes.
|
Completable |
doOnDispose(Action onDispose)
Returns a Completable which calls the given onDispose callback if the child subscriber cancels
the subscription.
|
Completable |
doOnError(Consumer<? super java.lang.Throwable> onError)
Returns a Completable which calls the given onError callback if this Completable emits an error.
|
Completable |
doOnEvent(Consumer<? super java.lang.Throwable> onEvent)
Returns a Completable which calls the given onEvent callback with the (throwable) for an onError
or (null) for an onComplete signal from this Completable before delivering said signal to the downstream.
|
Completable |
doOnSubscribe(Consumer<? super Disposable> onSubscribe)
Returns a Completable instance that calls the given onSubscribe callback with the disposable
that child subscribers receive on subscription.
|
Completable |
doOnTerminate(Action onTerminate)
Returns a Completable instance that calls the given onTerminate callback just before this Completable
completes normally or with an exception
Scheduler:
doOnTerminate does not operate by default on a particular Scheduler .
|
static Completable |
error(java.util.concurrent.Callable<? extends java.lang.Throwable> errorSupplier)
Creates a Completable which calls the given error supplier for each subscriber
and emits its returned Throwable.
|
static Completable |
error(java.lang.Throwable error)
Creates a Completable instance that emits the given Throwable exception to subscribers.
|
static Completable |
fromAction(Action run)
Returns a Completable instance that runs the given Action for each subscriber and
emits either an unchecked exception or simply completes.
|
static Completable |
fromCallable(java.util.concurrent.Callable<?> callable)
Returns a Completable which when subscribed, executes the callable function, ignores its
normal result and emits onError or onComplete only.
|
static Completable |
fromFuture(java.util.concurrent.Future<?> future)
Returns a Completable instance that reacts to the termination of the given Future in a blocking fashion.
|
static <T> Completable |
fromObservable(ObservableSource<T> observable)
Returns a Completable instance that subscribes to the given Observable, ignores all values and
emits only the terminal event.
|
static <T> Completable |
fromPublisher(org.reactivestreams.Publisher<T> publisher)
Returns a Completable instance that subscribes to the given publisher, ignores all values and
emits only the terminal event.
|
static Completable |
fromRunnable(java.lang.Runnable run)
Returns a Completable instance that runs the given Runnable for each subscriber and
emits either its exception or simply completes.
|
static <T> Completable |
fromSingle(SingleSource<T> single)
Returns a Completable instance that when subscribed to, subscribes to the Single instance and
emits a completion event if the single emits onSuccess or forwards any onError events.
|
Completable |
hide()
Hides the identity of this Completable and its Disposable.
|
Completable |
lift(CompletableOperator onLift)
Advanced use without safeguards: lifts a CompletableOperator
transformation into the chain of Completables.
|
static Completable |
merge(java.lang.Iterable<? extends CompletableSource> sources)
Returns a Completable instance that subscribes to all sources at once and
completes only when all source Completables complete or one of them emits an error.
|
static Completable |
merge(org.reactivestreams.Publisher<? extends CompletableSource> sources)
Returns a Completable instance that subscribes to all sources at once and
completes only when all source Completables complete or one of them emits an error.
|
static Completable |
merge(org.reactivestreams.Publisher<? extends CompletableSource> sources,
int maxConcurrency)
Returns a Completable instance that keeps subscriptions to a limited number of sources at once and
completes only when all source Completables complete or one of them emits an error.
|
static Completable |
mergeArray(CompletableSource... sources)
Returns a Completable instance that subscribes to all sources at once and
completes only when all source Completables complete or one of them emits an error.
|
static Completable |
mergeArrayDelayError(CompletableSource... sources)
Returns a CompletableConsumable that subscribes to all Completables in the source array and delays
any error emitted by either the sources observable or any of the inner Completables until all of
them terminate in a way or another.
|
static Completable |
mergeDelayError(java.lang.Iterable<? extends CompletableSource> sources)
Returns a Completable that subscribes to all Completables in the source sequence and delays
any error emitted by either the sources observable or any of the inner Completables until all of
them terminate in a way or another.
|
static Completable |
mergeDelayError(org.reactivestreams.Publisher<? extends CompletableSource> sources)
Returns a Completable that subscribes to all Completables in the source sequence and delays
any error emitted by either the sources observable or any of the inner Completables until all of
them terminate in a way or another.
|
static Completable |
mergeDelayError(org.reactivestreams.Publisher<? extends CompletableSource> sources,
int maxConcurrency)
Returns a Completable that subscribes to a limited number of inner Completables at once in
the source sequence and delays any error emitted by either the sources
observable or any of the inner Completables until all of
them terminate in a way or another.
|
Completable |
mergeWith(CompletableSource other)
Returns a Completable which subscribes to this and the other Completable and completes
when both of them complete or one emits an error.
|
static Completable |
never()
Returns a Completable that never calls onError or onComplete.
|
Completable |
observeOn(Scheduler scheduler)
Returns a Completable which emits the terminal events from the thread of the specified scheduler.
|
Completable |
onErrorComplete()
Returns a Completable instance that if this Completable emits an error, it will emit an onComplete
and swallow the throwable.
|
Completable |
onErrorComplete(Predicate<? super java.lang.Throwable> predicate)
Returns a Completable instance that if this Completable emits an error and the predicate returns
true, it will emit an onComplete and swallow the throwable.
|
Completable |
onErrorResumeNext(Function<? super java.lang.Throwable,? extends CompletableSource> errorMapper)
Returns a Completable instance that when encounters an error from this Completable, calls the
specified mapper function that returns another Completable instance for it and resumes the
execution with it.
|
Completable |
repeat()
Returns a Completable that repeatedly subscribes to this Completable until cancelled.
|
Completable |
repeat(long times)
Returns a Completable that subscribes repeatedly at most the given times to this Completable.
|
Completable |
repeatUntil(BooleanSupplier stop)
Returns a Completable that repeatedly subscribes to this Completable so long as the given
stop supplier returns false.
|
Completable |
repeatWhen(Function<? super Flowable<java.lang.Object>,? extends org.reactivestreams.Publisher<java.lang.Object>> handler)
Returns a Completable instance that repeats when the Publisher returned by the handler
emits an item or completes when this Publisher emits a completed event.
|
Completable |
retry()
Returns a Completable that retries this Completable as long as it emits an onError event.
|
Completable |
retry(BiPredicate<? super java.lang.Integer,? super java.lang.Throwable> predicate)
Returns a Completable that retries this Completable in case of an error as long as the predicate
returns true.
|
Completable |
retry(long times)
Returns a Completable that when this Completable emits an error, retries at most the given
number of times before giving up and emitting the last error.
|
Completable |
retry(Predicate<? super java.lang.Throwable> predicate)
Returns a Completable that when this Completable emits an error, calls the given predicate with
the latest exception to decide whether to resubscribe to this or not.
|
Completable |
retryWhen(Function<? super Flowable<java.lang.Throwable>,? extends org.reactivestreams.Publisher<java.lang.Object>> handler)
Returns a Completable which given a Publisher and when this Completable emits an error, delivers
that error through a Flowable and the Publisher should signal a value indicating a retry in response
or a terminal event indicating a termination.
|
Completable |
startWith(CompletableSource other)
Returns a Completable which first runs the other Completable
then this completable if the other completed normally.
|
<T> Observable<T> |
startWith(Observable<T> other)
Returns an Observable which first delivers the events
of the other Observable then runs this CompletableConsumable.
|
<T> Flowable<T> |
startWith(org.reactivestreams.Publisher<T> other)
Returns a Flowable which first delivers the events
of the other Publisher then runs this Completable.
|
Disposable |
subscribe()
Subscribes to this CompletableConsumable and returns a Disposable which can be used to cancel
the subscription.
|
Disposable |
subscribe(Action onComplete)
Subscribes to this Completable and calls the given Action when this Completable
completes normally.
|
Disposable |
subscribe(Action onComplete,
Consumer<? super java.lang.Throwable> onError)
Subscribes to this Completable and calls back either the onError or onComplete functions.
|
void |
subscribe(CompletableObserver s)
Subscribes the given CompletableObserver to this CompletableSource instance.
|
protected abstract void |
subscribeActual(CompletableObserver s)
Implement this to handle the incoming CompletableObserver and
perform the business logic in your operator.
|
Completable |
subscribeOn(Scheduler scheduler)
Returns a Completable which subscribes the child subscriber on the specified scheduler, making
sure the subscription side-effects happen on that specific thread of the scheduler.
|
<E extends CompletableObserver> |
subscribeWith(E observer)
Subscribes a given CompletableObserver (subclass) to this Completable and returns the given
CompletableObserver as is.
|
TestObserver<java.lang.Void> |
test()
Creates a TestObserver and subscribes
it to this Completable.
|
TestObserver<java.lang.Void> |
test(boolean cancelled)
Creates a TestObserver optionally in cancelled state, then subscribes it to this Completable.
|
Completable |
timeout(long timeout,
java.util.concurrent.TimeUnit unit)
Returns a Completable that runs this Completable and emits a TimeoutException in case
this Completable doesn't complete within the given time.
|
Completable |
timeout(long timeout,
java.util.concurrent.TimeUnit unit,
CompletableSource other)
Returns a Completable that runs this Completable and switches to the other Completable
in case this Completable doesn't complete within the given time.
|
Completable |
timeout(long timeout,
java.util.concurrent.TimeUnit unit,
Scheduler scheduler)
Returns a Completable that runs this Completable and emits a TimeoutException in case
this Completable doesn't complete within the given time while "waiting" on the specified
Scheduler.
|
Completable |
timeout(long timeout,
java.util.concurrent.TimeUnit unit,
Scheduler scheduler,
CompletableSource other)
Returns a Completable that runs this Completable and switches to the other Completable
in case this Completable doesn't complete within the given time while "waiting" on
the specified scheduler.
|
static Completable |
timer(long delay,
java.util.concurrent.TimeUnit unit)
Returns a Completable instance that fires its onComplete event after the given delay elapsed.
|
static Completable |
timer(long delay,
java.util.concurrent.TimeUnit unit,
Scheduler scheduler)
Returns a Completable instance that fires its onComplete event after the given delay elapsed
by using the supplied scheduler.
|
<U> U |
to(Function<? super Completable,U> converter)
Allows fluent conversion to another type via a function callback.
|
<T> Flowable<T> |
toFlowable()
Returns a Flowable which when subscribed to subscribes to this Completable and
relays the terminal events to the subscriber.
|
<T> Maybe<T> |
toMaybe()
Converts this Completable into a
Maybe . |
<T> Observable<T> |
toObservable()
Returns an Observable which when subscribed to subscribes to this Completable and
relays the terminal events to the subscriber.
|
<T> Single<T> |
toSingle(java.util.concurrent.Callable<? extends T> completionValueSupplier)
Converts this Completable into a Single which when this Completable completes normally,
calls the given supplier and emits its returned value through onSuccess.
|
<T> Single<T> |
toSingleDefault(T completionValue)
Converts this Completable into a Single which when this Completable completes normally,
emits the given value through onSuccess.
|
static Completable |
unsafeCreate(CompletableSource source)
Constructs a Completable instance by wrapping the given source callback
without any safeguards; you should manage the lifecycle and response
to downstream cancellation/dispose.
|
Completable |
unsubscribeOn(Scheduler scheduler)
Returns a Completable which makes sure when a subscriber cancels the subscription, the
dispose is called on the specified scheduler
Scheduler:
unsubscribeOn calls dispose() of the upstream on the Scheduler you specify.
|
static <R> Completable |
using(java.util.concurrent.Callable<R> resourceSupplier,
Function<? super R,? extends CompletableSource> completableFunction,
Consumer<? super R> disposer)
Returns a Completable instance which manages a resource along
with a custom Completable instance while the subscription is active.
|
static <R> Completable |
using(java.util.concurrent.Callable<R> resourceSupplier,
Function<? super R,? extends CompletableSource> completableFunction,
Consumer<? super R> disposer,
boolean eager)
Returns a Completable instance which manages a resource along
with a custom Completable instance while the subscription is active and performs eager or lazy
resource disposition.
|
static Completable |
wrap(CompletableSource source)
Wraps the given CompletableSource into a Completable
if not already Completable.
|
@CheckReturnValue @SchedulerSupport(value="none") public static Completable ambArray(CompletableSource... sources)
ambArray
does not operate by default on a particular Scheduler
.sources
- the array of source Completables. A subscription to each source will
occur in the same order as in this array.java.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable amb(java.lang.Iterable<? extends CompletableSource> sources)
amb
does not operate by default on a particular Scheduler
.sources
- the array of source Completables. A subscription to each source will
occur in the same order as in this Iterable.java.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable complete()
complete
does not operate by default on a particular Scheduler
.@CheckReturnValue @SchedulerSupport(value="none") public static Completable concatArray(CompletableSource... sources)
concatArray
does not operate by default on a particular Scheduler
.sources
- the sources to concatenatejava.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable concat(java.lang.Iterable<? extends CompletableSource> sources)
concat
does not operate by default on a particular Scheduler
.sources
- the sources to concatenatejava.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") @BackpressureSupport(value=FULL) public static Completable concat(org.reactivestreams.Publisher<? extends CompletableSource> sources)
Completable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.concat
does not operate by default on a particular Scheduler
.sources
- the sources to concatenatejava.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") @BackpressureSupport(value=FULL) public static Completable concat(org.reactivestreams.Publisher<? extends CompletableSource> sources, int prefetch)
Completable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.concat
does not operate by default on a particular Scheduler
.sources
- the sources to concatenateprefetch
- the number of sources to prefetch from the sourcesjava.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable create(CompletableOnSubscribe source)
Example:
Completable.create(emitter -> {
Callback listener = new Callback() {
@Override
public void onEvent(Event e) {
emitter.onComplete();
}
@Override
public void onFailure(Exception e) {
emitter.onError(e);
}
};
AutoCloseable c = api.someMethod(listener);
emitter.setCancellable(c::close);
});
create
does not operate by default on a particular Scheduler
.source
- the emitter that is called when a CompletableObserver subscribes to the returned Completable
CompletableOnSubscribe
,
Cancellable
@CheckReturnValue @SchedulerSupport(value="none") public static Completable unsafeCreate(CompletableSource source)
unsafeCreate
does not operate by default on a particular Scheduler
.source
- the callback which will receive the CompletableObserver instances
when the Completable is subscribed to.java.lang.NullPointerException
- if source is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable defer(java.util.concurrent.Callable<? extends CompletableSource> completableSupplier)
defer
does not operate by default on a particular Scheduler
.completableSupplier
- the supplier that returns the Completable that will be subscribed to.@CheckReturnValue @SchedulerSupport(value="none") public static Completable error(java.util.concurrent.Callable<? extends java.lang.Throwable> errorSupplier)
If the errorSupplier returns null, the child CompletableObservers will receive a NullPointerException.
error
does not operate by default on a particular Scheduler
.errorSupplier
- the error supplier, not nulljava.lang.NullPointerException
- if errorSupplier is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable error(java.lang.Throwable error)
error
does not operate by default on a particular Scheduler
.error
- the Throwable instance to emit, not nulljava.lang.NullPointerException
- if error is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable fromAction(Action run)
fromAction
does not operate by default on a particular Scheduler
.run
- the runnable to run for each subscriberjava.lang.NullPointerException
- if run is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable fromCallable(java.util.concurrent.Callable<?> callable)
fromCallable
does not operate by default on a particular Scheduler
.callable
- the callable instance to execute for each subscriber@CheckReturnValue @SchedulerSupport(value="none") public static Completable fromFuture(java.util.concurrent.Future<?> future)
Note that cancellation from any of the subscribers to this Completable will cancel the future.
fromFuture
does not operate by default on a particular Scheduler
.future
- the future to react to@CheckReturnValue @SchedulerSupport(value="none") public static Completable fromRunnable(java.lang.Runnable run)
fromRunnable
does not operate by default on a particular Scheduler
.run
- the runnable to run for each subscriberjava.lang.NullPointerException
- if run is null@CheckReturnValue @SchedulerSupport(value="none") public static <T> Completable fromObservable(ObservableSource<T> observable)
fromObservable
does not operate by default on a particular Scheduler
.T
- the type of the Observableobservable
- the Observable instance to subscribe to, not nulljava.lang.NullPointerException
- if flowable is null@CheckReturnValue @BackpressureSupport(value=UNBOUNDED_IN) @SchedulerSupport(value="none") public static <T> Completable fromPublisher(org.reactivestreams.Publisher<T> publisher)
Completable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.fromPublisher
does not operate by default on a particular Scheduler
.T
- the type of the publisherpublisher
- the Publisher instance to subscribe to, not nulljava.lang.NullPointerException
- if publisher is null@CheckReturnValue @SchedulerSupport(value="none") public static <T> Completable fromSingle(SingleSource<T> single)
fromSingle
does not operate by default on a particular Scheduler
.T
- the value type of the Singlesingle
- the Single instance to subscribe to, not nulljava.lang.NullPointerException
- if single is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable mergeArray(CompletableSource... sources)
mergeArray
does not operate by default on a particular Scheduler
.sources
- the iterable sequence of sources.java.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable merge(java.lang.Iterable<? extends CompletableSource> sources)
merge
does not operate by default on a particular Scheduler
.sources
- the iterable sequence of sources.java.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") @BackpressureSupport(value=UNBOUNDED_IN) public static Completable merge(org.reactivestreams.Publisher<? extends CompletableSource> sources)
Completable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.merge
does not operate by default on a particular Scheduler
.sources
- the iterable sequence of sources.java.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") @BackpressureSupport(value=FULL) public static Completable merge(org.reactivestreams.Publisher<? extends CompletableSource> sources, int maxConcurrency)
Completable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.merge
does not operate by default on a particular Scheduler
.sources
- the iterable sequence of sources.maxConcurrency
- the maximum number of concurrent subscriptionsjava.lang.NullPointerException
- if sources is nulljava.lang.IllegalArgumentException
- if maxConcurrency is less than 1@CheckReturnValue @SchedulerSupport(value="none") public static Completable mergeArrayDelayError(CompletableSource... sources)
mergeArrayDelayError
does not operate by default on a particular Scheduler
.sources
- the array of Completablesjava.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable mergeDelayError(java.lang.Iterable<? extends CompletableSource> sources)
mergeDelayError
does not operate by default on a particular Scheduler
.sources
- the sequence of Completablesjava.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") @BackpressureSupport(value=UNBOUNDED_IN) public static Completable mergeDelayError(org.reactivestreams.Publisher<? extends CompletableSource> sources)
Completable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.mergeDelayError
does not operate by default on a particular Scheduler
.sources
- the sequence of Completablesjava.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") @BackpressureSupport(value=FULL) public static Completable mergeDelayError(org.reactivestreams.Publisher<? extends CompletableSource> sources, int maxConcurrency)
Completable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.mergeDelayError
does not operate by default on a particular Scheduler
.sources
- the sequence of CompletablesmaxConcurrency
- the maximum number of concurrent subscriptions to Completablesjava.lang.NullPointerException
- if sources is null@CheckReturnValue @SchedulerSupport(value="none") public static Completable never()
never
does not operate by default on a particular Scheduler
.@CheckReturnValue @SchedulerSupport(value="io.reactivex:computation") public static Completable timer(long delay, java.util.concurrent.TimeUnit unit)
timer
does operate by default on the computation
Scheduler
.delay
- the delay timeunit
- the delay unit@CheckReturnValue @SchedulerSupport(value="custom") public static Completable timer(long delay, java.util.concurrent.TimeUnit unit, Scheduler scheduler)
timer
operates on the Scheduler
you specify.delay
- the delay timeunit
- the delay unitscheduler
- the scheduler where to emit the complete event@CheckReturnValue @SchedulerSupport(value="none") public static <R> Completable using(java.util.concurrent.Callable<R> resourceSupplier, Function<? super R,? extends CompletableSource> completableFunction, Consumer<? super R> disposer)
This overload disposes eagerly before the terminal event is emitted.
using
does not operate by default on a particular Scheduler
.R
- the resource typeresourceSupplier
- the supplier that returns a resource to be managed.completableFunction
- the function that given a resource returns a Completable instance that will be subscribed todisposer
- the consumer that disposes the resource created by the resource supplier@CheckReturnValue @SchedulerSupport(value="none") public static <R> Completable using(java.util.concurrent.Callable<R> resourceSupplier, Function<? super R,? extends CompletableSource> completableFunction, Consumer<? super R> disposer, boolean eager)
If this overload performs a lazy cancellation after the terminal event is emitted. Exceptions thrown at this time will be delivered to RxJavaPlugins only.
using
does not operate by default on a particular Scheduler
.R
- the resource typeresourceSupplier
- the supplier that returns a resource to be managedcompletableFunction
- the function that given a resource returns a non-null
Completable instance that will be subscribed todisposer
- the consumer that disposes the resource created by the resource suppliereager
- if true, the resource is disposed before the terminal event is emitted, if false, the
resource is disposed after the terminal event has been emitted@CheckReturnValue @SchedulerSupport(value="none") public static Completable wrap(CompletableSource source)
wrap
does not operate by default on a particular Scheduler
.source
- the source to wrapjava.lang.NullPointerException
- if source is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable ambWith(CompletableSource other)
ambWith
does not operate by default on a particular Scheduler
.other
- the other Completable, not null. A subscription to this provided source will occur after subscribing
to the current source.java.lang.NullPointerException
- if other is null@CheckReturnValue @SchedulerSupport(value="none") public final <T> Observable<T> andThen(ObservableSource<T> next)
next
ObservableSource. An error event from this Completable will be
propagated to the downstream subscriber and will result in skipping the subscription of the
Observable.
andThen
does not operate by default on a particular Scheduler
.T
- the value type of the next ObservableSourcenext
- the Observable to subscribe after this Completable is completed, not nulljava.lang.NullPointerException
- if next is null@CheckReturnValue @BackpressureSupport(value=FULL) @SchedulerSupport(value="none") public final <T> Flowable<T> andThen(org.reactivestreams.Publisher<T> next)
next
Flowable. An error event from this Completable will be
propagated to the downstream subscriber and will result in skipping the subscription of the
Publisher.
Flowable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.andThen
does not operate by default on a particular Scheduler
.T
- the value type of the next Publishernext
- the Publisher to subscribe after this Completable is completed, not nulljava.lang.NullPointerException
- if next is null@CheckReturnValue @SchedulerSupport(value="none") public final <T> Single<T> andThen(SingleSource<T> next)
next
SingleSource. An error event from this Completable will be
propagated to the downstream subscriber and will result in skipping the subscription of the
Single.
andThen
does not operate by default on a particular Scheduler
.T
- the value type of the next SingleSourcenext
- the Single to subscribe after this Completable is completed, not null@CheckReturnValue @SchedulerSupport(value="none") public final <T> Maybe<T> andThen(MaybeSource<T> next)
Maybe
which will subscribe to this Completable and once that is completed then
will subscribe to the next
MaybeSource. An error event from this Completable will be
propagated to the downstream subscriber and will result in skipping the subscription of the
Maybe.
andThen
does not operate by default on a particular Scheduler
.T
- the value type of the next MaybeSourcenext
- the Maybe to subscribe after this Completable is completed, not null@CheckReturnValue @SchedulerSupport(value="none") public final Completable andThen(CompletableSource next)
This is an alias for concatWith(CompletableSource)
.
andThen
does not operate by default on a particular Scheduler
.next
- the other Completable, not nulljava.lang.NullPointerException
- if other is null@SchedulerSupport(value="none") public final void blockingAwait()
blockingAwait
does not operate by default on a particular Scheduler
.java.lang.RuntimeException
- wrapping an InterruptedException if the current thread is interrupted@CheckReturnValue @SchedulerSupport(value="none") public final boolean blockingAwait(long timeout, java.util.concurrent.TimeUnit unit)
blockingAwait
does not operate by default on a particular Scheduler
.timeout
- the timeout valueunit
- the timeout unitjava.lang.RuntimeException
- wrapping an InterruptedException if the current thread is interrupted@CheckReturnValue @SchedulerSupport(value="none") public final java.lang.Throwable blockingGet()
blockingGet
does not operate by default on a particular Scheduler
.java.lang.RuntimeException
- that wraps an InterruptedException if the wait is interrupted@CheckReturnValue @SchedulerSupport(value="none") public final java.lang.Throwable blockingGet(long timeout, java.util.concurrent.TimeUnit unit)
blockingGet
does not operate by default on a particular Scheduler
.timeout
- the timeout valueunit
- the time unitjava.lang.RuntimeException
- that wraps an InterruptedException if the wait is interrupted or
TimeoutException if the specified timeout elapsed before it@CheckReturnValue @SchedulerSupport(value="none") public final Completable cache()
Note that this operator doesn't allow disposing the connection of the upstream source.
cache
does not operate by default on a particular Scheduler
.@CheckReturnValue @SchedulerSupport(value="none") public final Completable compose(CompletableTransformer transformer)
compose
does not operate by default on a particular Scheduler
.transformer
- the transformer function, not nulljava.lang.NullPointerException
- if transformer is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable concatWith(CompletableSource other)
concatWith
does not operate by default on a particular Scheduler
.other
- the other Completable, not nulljava.lang.NullPointerException
- if other is null@CheckReturnValue @SchedulerSupport(value="io.reactivex:computation") public final Completable delay(long delay, java.util.concurrent.TimeUnit unit)
delay
does operate by default on the computation
Scheduler
.delay
- the delay timeunit
- the delay unitjava.lang.NullPointerException
- if unit is null@CheckReturnValue @SchedulerSupport(value="custom") public final Completable delay(long delay, java.util.concurrent.TimeUnit unit, Scheduler scheduler)
delay
operates on the Scheduler
you specify.delay
- the delay timeunit
- the delay unitscheduler
- the scheduler to run the delayed completion onjava.lang.NullPointerException
- if unit or scheduler is null@CheckReturnValue @SchedulerSupport(value="custom") public final Completable delay(long delay, java.util.concurrent.TimeUnit unit, Scheduler scheduler, boolean delayError)
delay
operates on the Scheduler
you specify.delay
- the delay timeunit
- the delay unitscheduler
- the scheduler to run the delayed completion ondelayError
- delay the error emission as well?java.lang.NullPointerException
- if unit or scheduler is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable doOnComplete(Action onComplete)
doOnComplete
does not operate by default on a particular Scheduler
.onComplete
- the callback to call when this emits an onComplete eventjava.lang.NullPointerException
- if onComplete is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable doOnDispose(Action onDispose)
doOnDispose
does not operate by default on a particular Scheduler
.onDispose
- the callback to call when the child subscriber disposes the subscriptionjava.lang.NullPointerException
- if onDispose is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable doOnError(Consumer<? super java.lang.Throwable> onError)
doOnError
does not operate by default on a particular Scheduler
.onError
- the error callbackjava.lang.NullPointerException
- if onError is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable doOnEvent(Consumer<? super java.lang.Throwable> onEvent)
doOnEvent
does not operate by default on a particular Scheduler
.onEvent
- the event callbackjava.lang.NullPointerException
- if onEvent is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable doOnSubscribe(Consumer<? super Disposable> onSubscribe)
doOnSubscribe
does not operate by default on a particular Scheduler
.onSubscribe
- the callback called when a child subscriber subscribesjava.lang.NullPointerException
- if onSubscribe is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable doOnTerminate(Action onTerminate)
doOnTerminate
does not operate by default on a particular Scheduler
.onTerminate
- the callback to call just before this Completable terminates@CheckReturnValue @SchedulerSupport(value="none") public final Completable doAfterTerminate(Action onAfterTerminate)
doAfterTerminate
does not operate by default on a particular Scheduler
.onAfterTerminate
- the callback to call after this Completable terminates@CheckReturnValue @SchedulerSupport(value="none") public final Completable doFinally(Action onFinally)
In case of a race between a terminal event and a dispose call, the provided onFinally
action
is executed once per subscription.
Note that the onFinally
action is shared between subscriptions and as such
should be thread-safe.
doFinally
does not operate by default on a particular Scheduler
.onFinally
- the action called when this Completable terminates or gets cancelled@CheckReturnValue @SchedulerSupport(value="none") public final Completable lift(CompletableOperator onLift)
lift
does not operate by default on a particular Scheduler
.onLift
- the lifting function that transforms the child subscriber with a parent subscriber.java.lang.NullPointerException
- if onLift is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable mergeWith(CompletableSource other)
mergeWith
does not operate by default on a particular Scheduler
.other
- the other Completable instancejava.lang.NullPointerException
- if other is null@CheckReturnValue @SchedulerSupport(value="custom") public final Completable observeOn(Scheduler scheduler)
observeOn
operates on a Scheduler
you specify.scheduler
- the scheduler to emit terminal events onjava.lang.NullPointerException
- if scheduler is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable onErrorComplete()
onErrorComplete
does not operate by default on a particular Scheduler
.@CheckReturnValue @SchedulerSupport(value="none") public final Completable onErrorComplete(Predicate<? super java.lang.Throwable> predicate)
onErrorComplete
does not operate by default on a particular Scheduler
.predicate
- the predicate to call when an Throwable is emitted which should return true
if the Throwable should be swallowed and replaced with an onComplete.@CheckReturnValue @SchedulerSupport(value="none") public final Completable onErrorResumeNext(Function<? super java.lang.Throwable,? extends CompletableSource> errorMapper)
onErrorResumeNext
does not operate by default on a particular Scheduler
.errorMapper
- the mapper function that takes the error and should return a Completable as
continuation.@CheckReturnValue @SchedulerSupport(value="none") public final Completable repeat()
repeat
does not operate by default on a particular Scheduler
.@CheckReturnValue @SchedulerSupport(value="none") public final Completable repeat(long times)
repeat
does not operate by default on a particular Scheduler
.times
- the number of times the resubscription should happenjava.lang.IllegalArgumentException
- if times is less than zero@CheckReturnValue @SchedulerSupport(value="none") public final Completable repeatUntil(BooleanSupplier stop)
repeatUntil
does not operate by default on a particular Scheduler
.stop
- the supplier that should return true to stop resubscribing.java.lang.NullPointerException
- if stop is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable repeatWhen(Function<? super Flowable<java.lang.Object>,? extends org.reactivestreams.Publisher<java.lang.Object>> handler)
repeatWhen
does not operate by default on a particular Scheduler
.handler
- the function that transforms the stream of values indicating the completion of
this Completable and returns a Publisher that emits items for repeating or completes to indicate the
repetition should stopjava.lang.NullPointerException
- if stop is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable retry()
retry
does not operate by default on a particular Scheduler
.@CheckReturnValue @SchedulerSupport(value="none") public final Completable retry(BiPredicate<? super java.lang.Integer,? super java.lang.Throwable> predicate)
retry
does not operate by default on a particular Scheduler
.predicate
- the predicate called when this emits an error with the repeat count and the latest exception
and should return true to retry.@CheckReturnValue @SchedulerSupport(value="none") public final Completable retry(long times)
retry
does not operate by default on a particular Scheduler
.times
- the number of times the returned Completable should retry this Completablejava.lang.IllegalArgumentException
- if times is negative@CheckReturnValue @SchedulerSupport(value="none") public final Completable retry(Predicate<? super java.lang.Throwable> predicate)
retry
does not operate by default on a particular Scheduler
.predicate
- the predicate that is called with the latest throwable and should return
true to indicate the returned Completable should resubscribe to this Completable.java.lang.NullPointerException
- if predicate is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable retryWhen(Function<? super Flowable<java.lang.Throwable>,? extends org.reactivestreams.Publisher<java.lang.Object>> handler)
retryWhen
does not operate by default on a particular Scheduler
.handler
- the handler that receives a Flowable delivering Throwables and should return a Publisher that
emits items to indicate retries or emits terminal events to indicate termination.java.lang.NullPointerException
- if handler is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable startWith(CompletableSource other)
startWith
does not operate by default on a particular Scheduler
.other
- the other completable to run firstjava.lang.NullPointerException
- if other is null@CheckReturnValue @SchedulerSupport(value="none") public final <T> Observable<T> startWith(Observable<T> other)
startWith
does not operate by default on a particular Scheduler
.T
- the value typeother
- the other Observable to run firstjava.lang.NullPointerException
- if other is null@CheckReturnValue @BackpressureSupport(value=FULL) @SchedulerSupport(value="none") public final <T> Flowable<T> startWith(org.reactivestreams.Publisher<T> other)
Flowable
honors the backpressure of the downstream consumer
and expects the other Publisher
to honor it as well.startWith
does not operate by default on a particular Scheduler
.T
- the value typeother
- the other Publisher to run firstjava.lang.NullPointerException
- if other is null@CheckReturnValue @SchedulerSupport(value="none") public final Completable hide()
Allows preventing certain identity-based optimizations (fusion).
hide
does not operate by default on a particular Scheduler
.@SchedulerSupport(value="none") public final Disposable subscribe()
subscribe
does not operate by default on a particular Scheduler
.@SchedulerSupport(value="none") public final void subscribe(CompletableObserver s)
CompletableSource
subscribe
in interface CompletableSource
s
- the CompletableObserver, not nullprotected abstract void subscribeActual(CompletableObserver s)
s
- the CompletableObserver instance, never null@CheckReturnValue @SchedulerSupport(value="none") public final <E extends CompletableObserver> E subscribeWith(E observer)
Usage example:
Completable source = Completable.complete().delay(1, TimeUnit.SECONDS);
CompositeDisposable composite = new CompositeDisposable();
class ResourceCompletableObserver implements CompletableObserver, Disposable {
// ...
}
composite.add(source.subscribeWith(new ResourceCompletableObserver()));
subscribeWith
does not operate by default on a particular Scheduler
.E
- the type of the CompletableObserver to use and returnobserver
- the CompletableObserver (subclass) to use and return, not nullobserver
java.lang.NullPointerException
- if observer
is null@CheckReturnValue @SchedulerSupport(value="none") public final Disposable subscribe(Action onComplete, Consumer<? super java.lang.Throwable> onError)
subscribe
does not operate by default on a particular Scheduler
.onComplete
- the runnable that is called if the Completable completes normallyonError
- the consumer that is called if this Completable emits an errorjava.lang.NullPointerException
- if either callback is null@CheckReturnValue @SchedulerSupport(value="none") public final Disposable subscribe(Action onComplete)
If the Completable emits an error, it is wrapped into an
OnErrorNotImplementedException
and routed to the RxJavaPlugins.onError handler.
subscribe
does not operate by default on a particular Scheduler
.onComplete
- the runnable called when this Completable completes normally@CheckReturnValue @SchedulerSupport(value="custom") public final Completable subscribeOn(Scheduler scheduler)
subscribeOn
operates on a Scheduler
you specify.scheduler
- the Scheduler to subscribe onjava.lang.NullPointerException
- if scheduler is null@CheckReturnValue @SchedulerSupport(value="io.reactivex:computation") public final Completable timeout(long timeout, java.util.concurrent.TimeUnit unit)
timeout
signals the TimeoutException on the computation
Scheduler
.timeout
- the timeout valueunit
- the timeout unitjava.lang.NullPointerException
- if unit is null@CheckReturnValue @SchedulerSupport(value="io.reactivex:computation") public final Completable timeout(long timeout, java.util.concurrent.TimeUnit unit, CompletableSource other)
timeout
subscribes to the other CompletableSource on
the computation
Scheduler
.timeout
- the timeout valueunit
- the timeout unitother
- the other Completable instance to switch to in case of a timeoutjava.lang.NullPointerException
- if unit or other is null@CheckReturnValue @SchedulerSupport(value="custom") public final Completable timeout(long timeout, java.util.concurrent.TimeUnit unit, Scheduler scheduler)
timeout
signals the TimeoutException on the Scheduler
you specify.timeout
- the timeout valueunit
- the timeout unitscheduler
- the scheduler to use to wait for completionjava.lang.NullPointerException
- if unit or scheduler is null@CheckReturnValue @SchedulerSupport(value="custom") public final Completable timeout(long timeout, java.util.concurrent.TimeUnit unit, Scheduler scheduler, CompletableSource other)
timeout
subscribes to the other CompletableSource on
the Scheduler
you specify.timeout
- the timeout valueunit
- the timeout unitscheduler
- the scheduler to use to wait for completionother
- the other Completable instance to switch to in case of a timeoutjava.lang.NullPointerException
- if unit, scheduler or other is null@CheckReturnValue @SchedulerSupport(value="none") public final <U> U to(Function<? super Completable,U> converter)
to
does not operate by default on a particular Scheduler
.U
- the output typeconverter
- the function called with this which should return some other value.java.lang.NullPointerException
- if converter is null@CheckReturnValue @BackpressureSupport(value=FULL) @SchedulerSupport(value="none") public final <T> Flowable<T> toFlowable()
Flowable
honors the backpressure of the downstream consumer.toFlowable
does not operate by default on a particular Scheduler
.T
- the value type@CheckReturnValue @SchedulerSupport(value="none") public final <T> Maybe<T> toMaybe()
Maybe
.
toMaybe
does not operate by default on a particular Scheduler
.T
- the value typeMaybe
that emits a single item T or an error.@CheckReturnValue @SchedulerSupport(value="none") public final <T> Observable<T> toObservable()
toObservable
does not operate by default on a particular Scheduler
.T
- the value type@CheckReturnValue @SchedulerSupport(value="none") public final <T> Single<T> toSingle(java.util.concurrent.Callable<? extends T> completionValueSupplier)
toSingle
does not operate by default on a particular Scheduler
.T
- the value typecompletionValueSupplier
- the value supplier called when this Completable completes normallyjava.lang.NullPointerException
- if completionValueSupplier is null@CheckReturnValue @SchedulerSupport(value="none") public final <T> Single<T> toSingleDefault(T completionValue)
toSingleDefault
does not operate by default on a particular Scheduler
.T
- the value typecompletionValue
- the value to emit when this Completable completes normallyjava.lang.NullPointerException
- if completionValue is null@CheckReturnValue @SchedulerSupport(value="custom") public final Completable unsubscribeOn(Scheduler scheduler)
unsubscribeOn
calls dispose() of the upstream on the Scheduler
you specify.scheduler
- the target scheduler where to execute the cancellationjava.lang.NullPointerException
- if scheduler is null@CheckReturnValue @SchedulerSupport(value="none") public final TestObserver<java.lang.Void> test()
test
does not operate by default on a particular Scheduler
.@CheckReturnValue @SchedulerSupport(value="none") public final TestObserver<java.lang.Void> test(boolean cancelled)
cancelled
- if true, the TestObserver will be cancelled before subscribing to this
Completable.
test
does not operate by default on a particular Scheduler
.