.class abstract Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber; .super Ljava/util/concurrent/atomic/AtomicInteger; .source "ParallelRunOn.java" # interfaces .implements Lkh/o; .implements Lok/e; .implements Ljava/lang/Runnable; # annotations .annotation system Ldalvik/annotation/EnclosingClass; value = Lio/reactivex/internal/operators/parallel/ParallelRunOn; .end annotation .annotation system Ldalvik/annotation/InnerClass; accessFlags = 0x409 name = "BaseRunOnSubscriber" .end annotation .annotation system Ldalvik/annotation/Signature; value = { "", "Ljava/util/concurrent/atomic/AtomicInteger;", "Lkh/o<", "TT;>;", "Lok/e;", "Ljava/lang/Runnable;" } .end annotation # static fields .field private static final serialVersionUID:J = 0x7ffc3440018b78e6L # instance fields .field public volatile cancelled:Z .field public consumed:I .field public volatile done:Z .field public error:Ljava/lang/Throwable; .field public final limit:I .field public final prefetch:I .field public final queue:Lio/reactivex/internal/queue/SpscArrayQueue; .annotation system Ldalvik/annotation/Signature; value = { "Lio/reactivex/internal/queue/SpscArrayQueue<", "TT;>;" } .end annotation .end field .field public final requested:Ljava/util/concurrent/atomic/AtomicLong; .field public upstream:Lok/e; .field public final worker:Lkh/h0$c; # direct methods .method public constructor (ILio/reactivex/internal/queue/SpscArrayQueue;Lkh/h0$c;)V .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(I", "Lio/reactivex/internal/queue/SpscArrayQueue<", "TT;>;", "Lkh/h0$c;", ")V" } .end annotation .line 1 invoke-direct {p0}, Ljava/util/concurrent/atomic/AtomicInteger;->()V .line 2 new-instance v0, Ljava/util/concurrent/atomic/AtomicLong; invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicLong;->()V iput-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->requested:Ljava/util/concurrent/atomic/AtomicLong; .line 3 iput p1, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->prefetch:I .line 4 iput-object p2, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->queue:Lio/reactivex/internal/queue/SpscArrayQueue; shr-int/lit8 p2, p1, 0x2 sub-int/2addr p1, p2 .line 5 iput p1, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->limit:I .line 6 iput-object p3, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->worker:Lkh/h0$c; return-void .end method # virtual methods .method public final cancel()V .locals 1 .line 1 iget-boolean v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->cancelled:Z if-nez v0, :cond_0 const/4 v0, 0x1 .line 2 iput-boolean v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->cancelled:Z .line 3 iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->upstream:Lok/e; invoke-interface {v0}, Lok/e;->cancel()V .line 4 iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->worker:Lkh/h0$c; invoke-interface {v0}, Lio/reactivex/disposables/b;->dispose()V .line 5 invoke-virtual {p0}, Ljava/util/concurrent/atomic/AtomicInteger;->getAndIncrement()I move-result v0 if-nez v0, :cond_0 .line 6 iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->queue:Lio/reactivex/internal/queue/SpscArrayQueue; invoke-virtual {v0}, Lio/reactivex/internal/queue/SpscArrayQueue;->clear()V :cond_0 return-void .end method .method public final onComplete()V .locals 1 .line 1 iget-boolean v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->done:Z if-eqz v0, :cond_0 return-void :cond_0 const/4 v0, 0x1 .line 2 iput-boolean v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->done:Z .line 3 invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->schedule()V return-void .end method .method public final onError(Ljava/lang/Throwable;)V .locals 1 .line 1 iget-boolean v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->done:Z if-eqz v0, :cond_0 .line 2 invoke-static {p1}, Lwh/a;->Y(Ljava/lang/Throwable;)V return-void .line 3 :cond_0 iput-object p1, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->error:Ljava/lang/Throwable; const/4 p1, 0x1 .line 4 iput-boolean p1, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->done:Z .line 5 invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->schedule()V return-void .end method .method public final onNext(Ljava/lang/Object;)V .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(TT;)V" } .end annotation .line 1 iget-boolean v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->done:Z if-eqz v0, :cond_0 return-void .line 2 :cond_0 iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->queue:Lio/reactivex/internal/queue/SpscArrayQueue; invoke-virtual {v0, p1}, Lio/reactivex/internal/queue/SpscArrayQueue;->offer(Ljava/lang/Object;)Z move-result p1 if-nez p1, :cond_1 .line 3 iget-object p1, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->upstream:Lok/e; invoke-interface {p1}, Lok/e;->cancel()V .line 4 new-instance p1, Lio/reactivex/exceptions/MissingBackpressureException; const-string v0, "Queue is full?!" invoke-direct {p1, v0}, Lio/reactivex/exceptions/MissingBackpressureException;->(Ljava/lang/String;)V invoke-virtual {p0, p1}, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->onError(Ljava/lang/Throwable;)V return-void .line 5 :cond_1 invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->schedule()V return-void .end method .method public final request(J)V .locals 1 .line 1 invoke-static {p1, p2}, Lio/reactivex/internal/subscriptions/SubscriptionHelper;->validate(J)Z move-result v0 if-eqz v0, :cond_0 .line 2 iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->requested:Ljava/util/concurrent/atomic/AtomicLong; invoke-static {v0, p1, p2}, Lio/reactivex/internal/util/b;->a(Ljava/util/concurrent/atomic/AtomicLong;J)J .line 3 invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->schedule()V :cond_0 return-void .end method .method public final schedule()V .locals 1 .line 1 invoke-virtual {p0}, Ljava/util/concurrent/atomic/AtomicInteger;->getAndIncrement()I move-result v0 if-nez v0, :cond_0 .line 2 iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber;->worker:Lkh/h0$c; invoke-virtual {v0, p0}, Lkh/h0$c;->b(Ljava/lang/Runnable;)Lio/reactivex/disposables/b; :cond_0 return-void .end method