Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
hu.akarnokd.rxjava2.Observable Maven / Gradle / Ivy
/**
* Copyright 2015 David Karnok and Netflix, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is
* distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See
* the License for the specific language governing permissions and limitations under the License.
*/
package hu.akarnokd.rxjava2;
import java.util.*;
import java.util.concurrent.*;
import java.util.concurrent.atomic.AtomicReference;
import org.reactivestreams.*;
import hu.akarnokd.rxjava2.annotations.*;
import hu.akarnokd.rxjava2.disposables.Disposable;
import hu.akarnokd.rxjava2.functions.*;
import hu.akarnokd.rxjava2.internal.functions.Functions;
import hu.akarnokd.rxjava2.internal.functions.Objects;
import hu.akarnokd.rxjava2.internal.operators.*;
import hu.akarnokd.rxjava2.internal.subscribers.*;
import hu.akarnokd.rxjava2.internal.subscriptions.EmptySubscription;
import hu.akarnokd.rxjava2.observables.*;
import hu.akarnokd.rxjava2.plugins.RxJavaPlugins;
import hu.akarnokd.rxjava2.schedulers.*;
import hu.akarnokd.rxjava2.subscribers.*;
public class Observable implements Publisher {
/**
* Interface to map/wrap a downstream subscriber to an upstream subscriber.
*
* @param the value type of the downstream
* @param the value type of the upstream
*/
public interface Operator extends Function, Subscriber super Upstream>> {
}
/**
* Interface to compose observables.
*
* @param the upstream value type
* @param the downstream value type
*/
public interface Transformer extends Function, Publisher extends R>> {
}
/** The default buffer size. */
static final int BUFFER_SIZE;
static {
BUFFER_SIZE = Math.max(16, Integer.getInteger("rx2.buffer-size", 128));
}
/** An empty observable instance as there is no need to instantiate this more than once. */
static final Observable EMPTY = create(PublisherEmptySource.INSTANCE);
/** A never observable instance as there is no need to instantiate this more than once. */
static final Observable NEVER = create(new Publisher() {
@Override
public void subscribe(Subscriber super Object> s) {
s.onSubscribe(EmptySubscription.INSTANCE);
}
});
public static Observable amb(Iterable extends Publisher extends T>> sources) {
Objects.requireNonNull(sources, "sources is null");
return create(new PublisherAmb(null, sources));
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable amb(Publisher extends T>... sources) {
Objects.requireNonNull(sources, "sources is null");
int len = sources.length;
if (len == 0) {
return empty();
} else
if (len == 1) {
return fromPublisher(sources[0]);
}
return create(new PublisherAmb(sources, null));
}
public static int bufferSize() {
return BUFFER_SIZE;
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(Function super Object[], ? extends R> combiner, boolean delayError, int bufferSize, Publisher extends T>... sources) {
return combineLatest(sources, combiner, delayError, bufferSize);
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(Iterable extends Publisher extends T>> sources, Function super Object[], ? extends R> combiner) {
return combineLatest(sources, combiner, false, bufferSize());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(Iterable extends Publisher extends T>> sources, Function super Object[], ? extends R> combiner, boolean delayError) {
return combineLatest(sources, combiner, delayError, bufferSize());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(Iterable extends Publisher extends T>> sources, Function super Object[], ? extends R> combiner, boolean delayError, int bufferSize) {
Objects.requireNonNull(sources, "sources is null");
Objects.requireNonNull(combiner, "combiner is null");
validateBufferSize(bufferSize);
// the queue holds a pair of values so we need to double the capacity
int s = bufferSize << 1;
return create(new PublisherCombineLatest(null, sources, combiner, s, delayError));
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(Publisher extends T>[] sources, Function super Object[], ? extends R> combiner) {
return combineLatest(sources, combiner, false, bufferSize());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(Publisher extends T>[] sources, Function super Object[], ? extends R> combiner, boolean delayError) {
return combineLatest(sources, combiner, delayError, bufferSize());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(Publisher extends T>[] sources, Function super Object[], ? extends R> combiner, boolean delayError, int bufferSize) {
validateBufferSize(bufferSize);
Objects.requireNonNull(combiner, "combiner is null");
if (sources.length == 0) {
return empty();
}
// the queue holds a pair of values so we need to double the capacity
int s = bufferSize << 1;
return create(new PublisherCombineLatest(sources, null, combiner, s, delayError));
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(
Publisher extends T1> p1, Publisher extends T2> p2,
BiFunction super T1, ? super T2, ? extends R> combiner) {
Function f = Functions.toFunction(combiner);
return combineLatest(f, false, bufferSize(), p1, p2);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(
Publisher extends T1> p1, Publisher extends T2> p2,
Publisher extends T3> p3,
Function3 super T1, ? super T2, ? super T3, ? extends R> combiner) {
return combineLatest(Functions.toFunction(combiner), false, bufferSize(), p1, p2, p3);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(
Publisher extends T1> p1, Publisher extends T2> p2,
Publisher extends T3> p3, Publisher extends T4> p4,
Function4 super T1, ? super T2, ? super T3, ? super T4, ? extends R> combiner) {
return combineLatest(Functions.toFunction(combiner), false, bufferSize(), p1, p2, p3, p4);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(
Publisher extends T1> p1, Publisher extends T2> p2,
Publisher extends T3> p3, Publisher extends T4> p4,
Publisher extends T5> p5,
Function5 super T1, ? super T2, ? super T3, ? super T4, ? super T5, ? extends R> combiner) {
return combineLatest(Functions.toFunction(combiner), false, bufferSize(), p1, p2, p3, p4, p5);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(
Publisher extends T1> p1, Publisher extends T2> p2,
Publisher extends T3> p3, Publisher extends T4> p4,
Publisher extends T5> p5, Publisher extends T6> p6,
Function6 super T1, ? super T2, ? super T3, ? super T4, ? super T5, ? super T6, ? extends R> combiner) {
return combineLatest(Functions.toFunction(combiner), false, bufferSize(), p1, p2, p3, p4, p5, p6);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(
Publisher extends T1> p1, Publisher extends T2> p2,
Publisher extends T3> p3, Publisher extends T4> p4,
Publisher extends T5> p5, Publisher extends T6> p6,
Publisher extends T7> p7,
Function7 super T1, ? super T2, ? super T3, ? super T4, ? super T5, ? super T6, ? super T7, ? extends R> combiner) {
return combineLatest(Functions.toFunction(combiner), false, bufferSize(), p1, p2, p3, p4, p5, p6, p7);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(
Publisher extends T1> p1, Publisher extends T2> p2,
Publisher extends T3> p3, Publisher extends T4> p4,
Publisher extends T5> p5, Publisher extends T6> p6,
Publisher extends T7> p7, Publisher extends T8> p8,
Function8 super T1, ? super T2, ? super T3, ? super T4, ? super T5, ? super T6, ? super T7, ? super T8, ? extends R> combiner) {
return combineLatest(Functions.toFunction(combiner), false, bufferSize(), p1, p2, p3, p4, p5, p6, p7, p8);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable combineLatest(
Publisher extends T1> p1, Publisher extends T2> p2,
Publisher extends T3> p3, Publisher extends T4> p4,
Publisher extends T5> p5, Publisher extends T6> p6,
Publisher extends T7> p7, Publisher extends T8> p8,
Publisher extends T9> p9,
Function9 super T1, ? super T2, ? super T3, ? super T4, ? super T5, ? super T6, ? super T7, ? super T8, ? super T9, ? extends R> combiner) {
return combineLatest(Functions.toFunction(combiner), false, bufferSize(), p1, p2, p3, p4, p5, p6, p7, p8, p9);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(int prefetch, Iterable extends Publisher extends T>> sources) {
Objects.requireNonNull(sources, "sources is null");
return fromIterable(sources).concatMap((Function)Functions.identity(), prefetch);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(Iterable extends Publisher extends T>> sources) {
Objects.requireNonNull(sources, "sources is null");
return fromIterable(sources).concatMap((Function)Functions.identity());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable concat(Publisher extends Publisher extends T>> sources) {
return concat(sources, bufferSize());
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable concat(Publisher extends Publisher extends T>> sources, int bufferSize) {
return fromPublisher(sources).concatMap((Function)Functions.identity());
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(Publisher extends T> p1, Publisher extends T> p2) {
return concatArray(p1, p2);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3) {
return concatArray(p1, p2, p3);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3, Publisher extends T> p4) {
return concatArray(p1, p2, p3, p4);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3, Publisher extends T> p4,
Publisher extends T> p5
) {
return concatArray(p1, p2, p3, p4, p5);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3, Publisher extends T> p4,
Publisher extends T> p5, Publisher extends T> p6
) {
return concatArray(p1, p2, p3, p4, p5, p6);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3, Publisher extends T> p4,
Publisher extends T> p5, Publisher extends T> p6,
Publisher extends T> p7
) {
return concatArray(p1, p2, p3, p4, p5, p6, p7);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3, Publisher extends T> p4,
Publisher extends T> p5, Publisher extends T> p6,
Publisher extends T> p7, Publisher extends T> p8
) {
return concatArray(p1, p2, p3, p4, p5, p6, p7, p8);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concat(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3, Publisher extends T> p4,
Publisher extends T> p5, Publisher extends T> p6,
Publisher extends T> p7, Publisher extends T> p8,
Publisher extends T> p9
) {
return concatArray(p1, p2, p3, p4, p5, p6, p7, p8, p9);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concatArray(int prefetch, Publisher extends T>... sources) {
Objects.requireNonNull(sources, "sources is null");
return fromArray(sources).concatMap((Function)Functions.identity(), prefetch);
}
/**
* Concatenates a variable number of Observable sources.
*
* Note: named this way because of overload conflict with concat(NbpObservable<NbpObservable>)
* @param sources the array of sources
* @param the common base value type
* @return the new NbpObservable instance
* @throws NullPointerException if sources is null
*/
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable concatArray(Publisher extends T>... sources) {
if (sources.length == 0) {
return empty();
} else
if (sources.length == 1) {
return fromPublisher(sources[0]);
}
return fromArray(sources).concatMap((Function)Functions.identity());
}
@BackpressureSupport(BackpressureKind.NONE)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable create(Publisher onSubscribe) {
Objects.requireNonNull(onSubscribe, "onSubscribe is null");
onSubscribe = RxJavaPlugins.onCreate(onSubscribe);
return new Observable(onSubscribe);
}
@BackpressureSupport(BackpressureKind.PASS_THROUGH)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable defer(Supplier extends Publisher extends T>> supplier) {
Objects.requireNonNull(supplier, "supplier is null");
return create(new PublisherDefer(supplier));
}
@BackpressureSupport(BackpressureKind.PASS_THROUGH)
@SchedulerSupport(SchedulerKind.NONE)
@SuppressWarnings("unchecked")
public static Observable empty() {
return (Observable)EMPTY;
}
@BackpressureSupport(BackpressureKind.PASS_THROUGH)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable error(Supplier extends Throwable> errorSupplier) {
Objects.requireNonNull(errorSupplier, "errorSupplier is null");
return create(new PublisherErrorSource(errorSupplier));
}
@BackpressureSupport(BackpressureKind.PASS_THROUGH)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable error(final Throwable e) {
Objects.requireNonNull(e, "e is null");
return error(new Supplier() {
@Override
public Throwable get() {
return e;
}
});
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable fromArray(T... values) {
Objects.requireNonNull(values, "values is null");
if (values.length == 0) {
return empty();
} else
if (values.length == 1) {
return just(values[0]);
}
return create(new PublisherArraySource(values));
}
// TODO match naming with RxJava 1.x
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable fromCallable(Callable extends T> supplier) {
Objects.requireNonNull(supplier, "supplier is null");
return create(new PublisherScalarAsyncSource(supplier));
}
/*
* It doesn't add cancellation support by default like 1.x
* if necessary, one can use composition to achieve it:
* futureObservable.doOnCancel(() -> future.cancel(true));
*/
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable fromFuture(Future extends T> future) {
Objects.requireNonNull(future, "future is null");
Observable o = create(new PublisherFutureSource(future, 0L, null));
return o;
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable fromFuture(Future extends T> future, long timeout, TimeUnit unit) {
Objects.requireNonNull(future, "future is null");
Objects.requireNonNull(unit, "unit is null");
Observable o = create(new PublisherFutureSource(future, timeout, unit));
return o;
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.CUSTOM)
public static Observable fromFuture(Future extends T> future, long timeout, TimeUnit unit, Scheduler scheduler) {
Objects.requireNonNull(scheduler, "scheduler is null");
Observable o = fromFuture(future, timeout, unit);
return o.subscribeOn(scheduler);
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.IO)
public static Observable fromFuture(Future extends T> future, Scheduler scheduler) {
Objects.requireNonNull(scheduler, "scheduler is null");
Observable o = fromFuture(future);
return o.subscribeOn(Schedulers.io());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable fromIterable(Iterable extends T> source) {
Objects.requireNonNull(source, "source is null");
return create(new PublisherIterableSource(source));
}
@BackpressureSupport(BackpressureKind.PASS_THROUGH)
@SchedulerSupport(SchedulerKind.NONE)
@SuppressWarnings("unchecked")
public static Observable fromPublisher(final Publisher extends T> publisher) {
if (publisher instanceof Observable) {
return (Observable)publisher;
}
Objects.requireNonNull(publisher, "publisher is null");
return create(new Publisher() {
@Override
public void subscribe(Subscriber super T> s) {
publisher.subscribe(s);
}
});
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable generate(final Consumer> generator) {
Objects.requireNonNull(generator, "generator is null");
return generate(Functions.nullSupplier(),
new BiFunction, Object>() {
@Override
public Object apply(Object s, Subscriber o) {
generator.accept(o);
return s;
}
}, Functions.emptyConsumer());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable generate(Supplier initialState, final BiConsumer> generator) {
Objects.requireNonNull(generator, "generator is null");
return generate(initialState, new BiFunction, S>() {
@Override
public S apply(S s, Subscriber o) {
generator.accept(s, o);
return s;
}
}, Functions.emptyConsumer());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable generate(Supplier initialState, final BiConsumer> generator, Consumer super S> disposeState) {
Objects.requireNonNull(generator, "generator is null");
return generate(initialState, new BiFunction, S>() {
@Override
public S apply(S s, Subscriber o) {
generator.accept(s, o);
return s;
}
}, disposeState);
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable generate(Supplier initialState, BiFunction, S> generator) {
return generate(initialState, generator, Functions.emptyConsumer());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable generate(Supplier initialState, BiFunction, S> generator, Consumer super S> disposeState) {
Objects.requireNonNull(initialState, "initialState is null");
Objects.requireNonNull(generator, "generator is null");
Objects.requireNonNull(disposeState, "disposeState is null");
return create(new PublisherGenerate(initialState, generator, disposeState));
}
@BackpressureSupport(BackpressureKind.ERROR)
@SchedulerSupport(SchedulerKind.COMPUTATION)
public static Observable interval(long initialDelay, long period, TimeUnit unit) {
return interval(initialDelay, period, unit, Schedulers.computation());
}
@BackpressureSupport(BackpressureKind.ERROR)
@SchedulerSupport(SchedulerKind.CUSTOM)
public static Observable interval(long initialDelay, long period, TimeUnit unit, Scheduler scheduler) {
if (initialDelay < 0) {
initialDelay = 0L;
}
if (period < 0) {
period = 0L;
}
Objects.requireNonNull(unit, "unit is null");
Objects.requireNonNull(scheduler, "scheduler is null");
return create(new PublisherIntervalSource(initialDelay, period, unit, scheduler));
}
@BackpressureSupport(BackpressureKind.ERROR)
@SchedulerSupport(SchedulerKind.COMPUTATION)
public static Observable interval(long period, TimeUnit unit) {
return interval(period, period, unit, Schedulers.computation());
}
@BackpressureSupport(BackpressureKind.ERROR)
@SchedulerSupport(SchedulerKind.CUSTOM)
public static Observable interval(long period, TimeUnit unit, Scheduler scheduler) {
return interval(period, period, unit, scheduler);
}
@BackpressureSupport(BackpressureKind.ERROR)
@SchedulerSupport(SchedulerKind.COMPUTATION)
public static Observable intervalRange(long start, long count, long initialDelay, long period, TimeUnit unit) {
return intervalRange(start, count, initialDelay, period, unit, Schedulers.computation());
}
@BackpressureSupport(BackpressureKind.ERROR)
@SchedulerSupport(SchedulerKind.CUSTOM)
public static Observable intervalRange(long start, long count, long initialDelay, long period, TimeUnit unit, Scheduler scheduler) {
long end = start + (count - 1);
if (end < 0) {
throw new IllegalArgumentException("Overflow! start + count is bigger than Long.MAX_VALUE");
}
if (initialDelay < 0) {
initialDelay = 0L;
}
if (period < 0) {
period = 0L;
}
Objects.requireNonNull(unit, "unit is null");
Objects.requireNonNull(scheduler, "scheduler is null");
return create(new PublisherIntervalRangeSource(start, end, initialDelay, period, unit, scheduler));
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable just(T value) {
Objects.requireNonNull(value, "value is null");
return new ObservableScalarSource(value);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable just(T v1, T v2) {
Objects.requireNonNull(v1, "The first value is null");
Objects.requireNonNull(v2, "The second value is null");
return fromArray(v1, v2);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable just(T v1, T v2, T v3) {
Objects.requireNonNull(v1, "The first value is null");
Objects.requireNonNull(v2, "The second value is null");
Objects.requireNonNull(v3, "The third value is null");
return fromArray(v1, v2, v3);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable just(T v1, T v2, T v3, T v4) {
Objects.requireNonNull(v1, "The first value is null");
Objects.requireNonNull(v2, "The second value is null");
Objects.requireNonNull(v3, "The third value is null");
Objects.requireNonNull(v4, "The fourth value is null");
return fromArray(v1, v2, v3, v4);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable just(T v1, T v2, T v3, T v4, T v5) {
Objects.requireNonNull(v1, "The first value is null");
Objects.requireNonNull(v2, "The second value is null");
Objects.requireNonNull(v3, "The third value is null");
Objects.requireNonNull(v4, "The fourth value is null");
Objects.requireNonNull(v5, "The fifth value is null");
return fromArray(v1, v2, v3, v4, v5);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable just(T v1, T v2, T v3, T v4, T v5, T v6) {
Objects.requireNonNull(v1, "The first value is null");
Objects.requireNonNull(v2, "The second value is null");
Objects.requireNonNull(v3, "The third value is null");
Objects.requireNonNull(v4, "The fourth value is null");
Objects.requireNonNull(v5, "The fifth value is null");
Objects.requireNonNull(v6, "The sixth value is null");
return fromArray(v1, v2, v3, v4, v5, v6);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable just(T v1, T v2, T v3, T v4, T v5, T v6, T v7) {
Objects.requireNonNull(v1, "The first value is null");
Objects.requireNonNull(v2, "The second value is null");
Objects.requireNonNull(v3, "The third value is null");
Objects.requireNonNull(v4, "The fourth value is null");
Objects.requireNonNull(v5, "The fifth value is null");
Objects.requireNonNull(v6, "The sixth value is null");
Objects.requireNonNull(v7, "The seventh value is null");
return fromArray(v1, v2, v3, v4, v5, v6, v7);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable just(T v1, T v2, T v3, T v4, T v5, T v6, T v7, T v8) {
Objects.requireNonNull(v1, "The first value is null");
Objects.requireNonNull(v2, "The second value is null");
Objects.requireNonNull(v3, "The third value is null");
Objects.requireNonNull(v4, "The fourth value is null");
Objects.requireNonNull(v5, "The fifth value is null");
Objects.requireNonNull(v6, "The sixth value is null");
Objects.requireNonNull(v7, "The seventh value is null");
Objects.requireNonNull(v8, "The eigth value is null");
return fromArray(v1, v2, v3, v4, v5, v6, v7, v8);
}
@SuppressWarnings("unchecked")
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static final Observable just(T v1, T v2, T v3, T v4, T v5, T v6, T v7, T v8, T v9) {
Objects.requireNonNull(v1, "The first value is null");
Objects.requireNonNull(v2, "The second value is null");
Objects.requireNonNull(v3, "The third value is null");
Objects.requireNonNull(v4, "The fourth value is null");
Objects.requireNonNull(v5, "The fifth value is null");
Objects.requireNonNull(v6, "The sixth value is null");
Objects.requireNonNull(v7, "The seventh value is null");
Objects.requireNonNull(v8, "The eigth value is null");
Objects.requireNonNull(v9, "The ninth is null");
return fromArray(v1, v2, v3, v4, v5, v6, v7, v8, v9);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(int maxConcurrency, int bufferSize, Iterable extends Publisher extends T>> sources) {
return fromIterable(sources).flatMap((Function)Functions.identity(), false, maxConcurrency, bufferSize);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(int maxConcurrency, int bufferSize, Publisher extends T>... sources) {
return fromArray(sources).flatMap((Function)Functions.identity(), false, maxConcurrency, bufferSize);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(int maxConcurrency, Publisher extends T>... sources) {
return fromArray(sources).flatMap((Function)Functions.identity(), maxConcurrency);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(Iterable extends Publisher extends T>> sources) {
return fromIterable(sources).flatMap((Function)Functions.identity());
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(Iterable extends Publisher extends T>> sources, int maxConcurrency) {
return fromIterable(sources).flatMap((Function)Functions.identity(), maxConcurrency);
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(Publisher extends Publisher extends T>> sources) {
return merge(sources, bufferSize());
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(Publisher extends Publisher extends T>> sources, int maxConcurrency) {
return fromPublisher(sources).flatMap((Function)Functions.identity(), maxConcurrency);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(Publisher extends T>... sources) {
return fromArray(sources).flatMap((Function)Functions.identity(), sources.length);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(Publisher extends T> p1, Publisher extends T> p2) {
Objects.requireNonNull(p1, "p1 is null");
Objects.requireNonNull(p2, "p2 is null");
return fromArray(p1, p2).flatMap((Function)Functions.identity(), false, 2);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(Publisher extends T> p1, Publisher extends T> p2, Publisher extends T> p3) {
Objects.requireNonNull(p1, "p1 is null");
Objects.requireNonNull(p2, "p2 is null");
Objects.requireNonNull(p3, "p3 is null");
return fromArray(p1, p2, p3).flatMap((Function)Functions.identity(), false, 3);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable merge(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3, Publisher extends T> p4) {
Objects.requireNonNull(p1, "p1 is null");
Objects.requireNonNull(p2, "p2 is null");
Objects.requireNonNull(p3, "p3 is null");
Objects.requireNonNull(p4, "p4 is null");
return fromArray(p1, p2, p3, p4).flatMap((Function)Functions.identity(), false, 4);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(boolean delayErrors, Iterable extends Publisher extends T>> sources) {
return fromIterable(sources).flatMap((Function)Functions.identity(), true);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(int maxConcurrency, int bufferSize, Iterable extends Publisher extends T>> sources) {
return fromIterable(sources).flatMap((Function)Functions.identity(), true, maxConcurrency, bufferSize);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(int maxConcurrency, int bufferSize, Publisher extends T>... sources) {
return fromArray(sources).flatMap((Function)Functions.identity(), true, maxConcurrency, bufferSize);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(int maxConcurrency, Iterable extends Publisher extends T>> sources) {
return fromIterable(sources).flatMap((Function)Functions.identity(), true, maxConcurrency);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(int maxConcurrency, Publisher extends T>... sources) {
return fromArray(sources).flatMap((Function)Functions.identity(), true, maxConcurrency);
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(Publisher extends Publisher extends T>> sources) {
return mergeDelayError(sources, bufferSize());
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(Publisher extends Publisher extends T>> sources, int maxConcurrency) {
return fromPublisher(sources).flatMap((Function)Functions.identity(), true, maxConcurrency);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(Publisher extends T>... sources) {
return fromArray(sources).flatMap((Function)Functions.identity(), true, sources.length);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(Publisher extends T> p1, Publisher extends T> p2) {
Objects.requireNonNull(p1, "p1 is null");
Objects.requireNonNull(p2, "p2 is null");
return fromArray(p1, p2).flatMap((Function)Functions.identity(), true, 2);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(Publisher extends T> p1, Publisher extends T> p2, Publisher extends T> p3) {
Objects.requireNonNull(p1, "p1 is null");
Objects.requireNonNull(p2, "p2 is null");
Objects.requireNonNull(p3, "p3 is null");
return fromArray(p1, p2, p3).flatMap((Function)Functions.identity(), true, 3);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable mergeDelayError(
Publisher extends T> p1, Publisher extends T> p2,
Publisher extends T> p3, Publisher extends T> p4) {
Objects.requireNonNull(p1, "p1 is null");
Objects.requireNonNull(p2, "p2 is null");
Objects.requireNonNull(p3, "p3 is null");
Objects.requireNonNull(p4, "p4 is null");
return fromArray(p1, p2, p3, p4).flatMap((Function)Functions.identity(), true, 4);
}
@BackpressureSupport(BackpressureKind.PASS_THROUGH)
@SchedulerSupport(SchedulerKind.NONE)
@SuppressWarnings("unchecked")
public static Observable never() {
return (Observable)NEVER;
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable range(int start, int count) {
if (count < 0) {
throw new IllegalArgumentException("count >= required but it was " + count);
} else
if (count == 0) {
return empty();
} else
if (count == 1) {
return just(start);
} else
if ((long)start + (count - 1) > Integer.MAX_VALUE) {
throw new IllegalArgumentException("Integer overflow");
}
return create(new PublisherRangeSource(start, count));
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable sequenceEqual(Publisher extends T> p1, Publisher extends T> p2) {
return sequenceEqual(p1, p2, Objects.equalsPredicate(), bufferSize());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable sequenceEqual(Publisher extends T> p1, Publisher extends T> p2, BiPredicate super T, ? super T> isEqual) {
return sequenceEqual(p1, p2, isEqual, bufferSize());
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable sequenceEqual(Publisher extends T> p1, Publisher extends T> p2, BiPredicate super T, ? super T> isEqual, int bufferSize) {
Objects.requireNonNull(p1, "p1 is null");
Objects.requireNonNull(p2, "p2 is null");
Objects.requireNonNull(isEqual, "isEqual is null");
validateBufferSize(bufferSize);
return create(new PublisherSequenceEqual(p1, p2, isEqual, bufferSize));
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable sequenceEqual(Publisher extends T> p1, Publisher extends T> p2, int bufferSize) {
return sequenceEqual(p1, p2, Objects.equalsPredicate(), bufferSize);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable switchOnNext(int bufferSize, Publisher extends Publisher extends T>> sources) {
return fromPublisher(sources).switchMap((Function)Functions.identity(), bufferSize);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable switchOnNext(Publisher extends Publisher extends T>> sources) {
return fromPublisher(sources).switchMap((Function)Functions.identity());
}
@BackpressureSupport(BackpressureKind.ERROR)
@SchedulerSupport(SchedulerKind.COMPUTATION)
public static Observable timer(long delay, TimeUnit unit) {
return timer(delay, unit, Schedulers.computation());
}
@BackpressureSupport(BackpressureKind.ERROR)
@SchedulerSupport(SchedulerKind.CUSTOM)
public static Observable timer(long delay, TimeUnit unit, Scheduler scheduler) {
if (delay < 0) {
delay = 0L;
}
Objects.requireNonNull(unit, "unit is null");
Objects.requireNonNull(scheduler, "scheduler is null");
return create(new PublisherIntervalOnceSource(delay, unit, scheduler));
}
@BackpressureSupport(BackpressureKind.PASS_THROUGH)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable using(Supplier extends D> resourceSupplier, Function super D, ? extends Publisher extends T>> sourceSupplier, Consumer super D> disposer) {
return using(resourceSupplier, sourceSupplier, disposer, true);
}
@BackpressureSupport(BackpressureKind.PASS_THROUGH)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable using(Supplier extends D> resourceSupplier, Function super D, ? extends Publisher extends T>> sourceSupplier, Consumer super D> disposer, boolean eager) {
Objects.requireNonNull(resourceSupplier, "resourceSupplier is null");
Objects.requireNonNull(sourceSupplier, "sourceSupplier is null");
Objects.requireNonNull(disposer, "disposer is null");
return create(new PublisherUsing(resourceSupplier, sourceSupplier, disposer, eager));
}
private static void validateBufferSize(int bufferSize) {
if (bufferSize <= 0) {
throw new IllegalArgumentException("bufferSize > 0 required but it was " + bufferSize);
}
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable zip(Iterable extends Publisher extends T>> sources, Function super Object[], ? extends R> zipper) {
Objects.requireNonNull(zipper, "zipper is null");
Objects.requireNonNull(sources, "sources is null");
return create(new PublisherZip(null, sources, zipper, bufferSize(), false));
}
@BackpressureSupport(BackpressureKind.FULL)
@SchedulerSupport(SchedulerKind.NONE)
public static Observable zip(Publisher extends Publisher extends T>> sources, final Function super Object[], ? extends R> zipper) {
Objects.requireNonNull(zipper, "zipper is null");
return fromPublisher(sources).toList().flatMap(new Function>, Publisher extends R>>() {
@Override
public Publisher extends R> apply(List