149 lines
4.7 KiB
Java
149 lines
4.7 KiB
Java
package io.reactivex.internal.operators.observable;
|
|
|
|
import io.reactivex.ObservableSource;
|
|
import io.reactivex.Observer;
|
|
import io.reactivex.Scheduler;
|
|
import io.reactivex.disposables.Disposable;
|
|
import io.reactivex.internal.disposables.DisposableHelper;
|
|
import io.reactivex.internal.queue.SpscLinkedArrayQueue;
|
|
import java.util.concurrent.TimeUnit;
|
|
import java.util.concurrent.atomic.AtomicInteger;
|
|
|
|
/* loaded from: classes2.dex */
|
|
public final class ObservableSkipLastTimed<T> extends AbstractObservableWithUpstream<T, T> {
|
|
final long b;
|
|
final TimeUnit c;
|
|
final Scheduler d;
|
|
final int e;
|
|
final boolean f;
|
|
|
|
static final class SkipLastTimedObserver<T> extends AtomicInteger implements Observer<T>, Disposable {
|
|
final Observer<? super T> a;
|
|
final long b;
|
|
final TimeUnit c;
|
|
final Scheduler d;
|
|
final SpscLinkedArrayQueue<Object> e;
|
|
final boolean f;
|
|
Disposable g;
|
|
volatile boolean h;
|
|
volatile boolean i;
|
|
Throwable j;
|
|
|
|
SkipLastTimedObserver(Observer<? super T> observer, long j, TimeUnit timeUnit, Scheduler scheduler, int i, boolean z) {
|
|
this.a = observer;
|
|
this.b = j;
|
|
this.c = timeUnit;
|
|
this.d = scheduler;
|
|
this.e = new SpscLinkedArrayQueue<>(i);
|
|
this.f = z;
|
|
}
|
|
|
|
void a() {
|
|
if (getAndIncrement() != 0) {
|
|
return;
|
|
}
|
|
Observer<? super T> observer = this.a;
|
|
SpscLinkedArrayQueue<Object> spscLinkedArrayQueue = this.e;
|
|
boolean z = this.f;
|
|
TimeUnit timeUnit = this.c;
|
|
Scheduler scheduler = this.d;
|
|
long j = this.b;
|
|
int i = 1;
|
|
while (!this.h) {
|
|
boolean z2 = this.i;
|
|
Long l = (Long) spscLinkedArrayQueue.a();
|
|
boolean z3 = l == null;
|
|
long a = scheduler.a(timeUnit);
|
|
if (!z3 && l.longValue() > a - j) {
|
|
z3 = true;
|
|
}
|
|
if (z2) {
|
|
if (!z) {
|
|
Throwable th = this.j;
|
|
if (th != null) {
|
|
this.e.clear();
|
|
observer.onError(th);
|
|
return;
|
|
} else if (z3) {
|
|
observer.onComplete();
|
|
return;
|
|
}
|
|
} else if (z3) {
|
|
Throwable th2 = this.j;
|
|
if (th2 != null) {
|
|
observer.onError(th2);
|
|
return;
|
|
} else {
|
|
observer.onComplete();
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
if (z3) {
|
|
i = addAndGet(-i);
|
|
if (i == 0) {
|
|
return;
|
|
}
|
|
} else {
|
|
spscLinkedArrayQueue.poll();
|
|
observer.onNext(spscLinkedArrayQueue.poll());
|
|
}
|
|
}
|
|
this.e.clear();
|
|
}
|
|
|
|
@Override // io.reactivex.disposables.Disposable
|
|
public void dispose() {
|
|
if (this.h) {
|
|
return;
|
|
}
|
|
this.h = true;
|
|
this.g.dispose();
|
|
if (getAndIncrement() == 0) {
|
|
this.e.clear();
|
|
}
|
|
}
|
|
|
|
@Override // io.reactivex.Observer
|
|
public void onComplete() {
|
|
this.i = true;
|
|
a();
|
|
}
|
|
|
|
@Override // io.reactivex.Observer
|
|
public void onError(Throwable th) {
|
|
this.j = th;
|
|
this.i = true;
|
|
a();
|
|
}
|
|
|
|
@Override // io.reactivex.Observer
|
|
public void onNext(T t) {
|
|
this.e.a(Long.valueOf(this.d.a(this.c)), (Long) t);
|
|
a();
|
|
}
|
|
|
|
@Override // io.reactivex.Observer
|
|
public void onSubscribe(Disposable disposable) {
|
|
if (DisposableHelper.validate(this.g, disposable)) {
|
|
this.g = disposable;
|
|
this.a.onSubscribe(this);
|
|
}
|
|
}
|
|
}
|
|
|
|
public ObservableSkipLastTimed(ObservableSource<T> observableSource, long j, TimeUnit timeUnit, Scheduler scheduler, int i, boolean z) {
|
|
super(observableSource);
|
|
this.b = j;
|
|
this.c = timeUnit;
|
|
this.d = scheduler;
|
|
this.e = i;
|
|
this.f = z;
|
|
}
|
|
|
|
@Override // io.reactivex.Observable
|
|
public void subscribeActual(Observer<? super T> observer) {
|
|
this.a.subscribe(new SkipLastTimedObserver(observer, this.b, this.c, this.d, this.e, this.f));
|
|
}
|
|
}
|