ParallelJoin$JoinSubscription.smali
.class final Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;
.super Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscriptionBase;
.source "ParallelJoin.java"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lio/reactivex/internal/operators/parallel/ParallelJoin;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x18
name = "JoinSubscription"
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">",
"Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscriptionBase<",
"TT;>;"
}
.end annotation
# static fields
.field private static final serialVersionUID:J = 0x579a0f4f7e6bd483L
# direct methods
.method static constructor <clinit>()V
.registers 1
return-void
.end method
.method constructor <init>(Lorg/reactivestreams/Subscriber;II)V
.registers 4
.param p2, "n" # I
.param p3, "prefetch" # I
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lorg/reactivestreams/Subscriber<",
"-TT;>;II)V"
}
.end annotation
.line 140
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription<TT;>;"
.local p1, "actual":Lorg/reactivestreams/Subscriber;, "Lorg/reactivestreams/Subscriber<-TT;>;"
invoke-direct {p0, p1, p2, p3}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscriptionBase;-><init>(Lorg/reactivestreams/Subscriber;II)V
.line 141
return-void
.end method
# virtual methods
.method drain()V
.registers 2
.line 206
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription<TT;>;"
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->getAndIncrement()I
move-result v0
if-eqz v0, :cond_7
.line 207
return-void
.line 210
:cond_7
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->drainLoop()V
.line 211
return-void
.end method
.method drainLoop()V
.registers 21
.line 214
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription<TT;>;"
move-object/from16 v0, p0
const/4 v1, 0x1
.line 216
.local v1, "missed":I
iget-object v2, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->subscribers:[Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;
.line 217
.local v2, "s":[Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;, "[Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber<TT;>;"
array-length v3, v2
.line 218
.local v3, "n":I
iget-object v4, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->actual:Lorg/reactivestreams/Subscriber;
.line 222
.local v4, "a":Lorg/reactivestreams/Subscriber;, "Lorg/reactivestreams/Subscriber<-TT;>;"
:goto_8
iget-object v5, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->requested:Ljava/util/concurrent/atomic/AtomicLong;
invoke-virtual {v5}, Ljava/util/concurrent/atomic/AtomicLong;->get()J
move-result-wide v5
.line 223
.local v5, "r":J
const-wide/16 v7, 0x0
.line 226
.local v7, "e":J
:goto_10
cmp-long v11, v7, v5
if-eqz v11, :cond_6a
.line 227
iget-boolean v11, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cancelled:Z
if-eqz v11, :cond_1c
.line 228
invoke-virtual/range {p0 .. p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cleanup()V
.line 229
return-void
.line 232
:cond_1c
iget-object v11, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->errors:Lio/reactivex/internal/util/AtomicThrowable;
invoke-virtual {v11}, Lio/reactivex/internal/util/AtomicThrowable;->get()Ljava/lang/Object;
move-result-object v11
check-cast v11, Ljava/lang/Throwable;
.line 233
.local v11, "ex":Ljava/lang/Throwable;
if-eqz v11, :cond_2d
.line 234
invoke-virtual/range {p0 .. p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cleanup()V
.line 235
invoke-interface {v4, v11}, Lorg/reactivestreams/Subscriber;->onError(Ljava/lang/Throwable;)V
.line 236
return-void
.line 239
:cond_2d
iget-object v12, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->done:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v12}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I
move-result v12
if-nez v12, :cond_37
const/4 v12, 0x1
goto :goto_38
:cond_37
const/4 v12, 0x0
.line 241
.local v12, "d":Z
:goto_38
const/4 v13, 0x1
.line 243
.local v13, "empty":Z
const/4 v14, 0x0
.local v14, "i":I
:goto_3a
array-length v15, v2
if-ge v14, v15, :cond_5e
.line 244
aget-object v15, v2, v14
.line 245
.local v15, "inner":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber<TT;>;"
iget-object v9, v15, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;->queue:Lio/reactivex/internal/fuseable/SimplePlainQueue;
.line 246
.local v9, "q":Lio/reactivex/internal/fuseable/SimplePlainQueue;, "Lio/reactivex/internal/fuseable/SimplePlainQueue<TT;>;"
if-eqz v9, :cond_5b
.line 247
invoke-interface {v9}, Lio/reactivex/internal/fuseable/SimplePlainQueue;->poll()Ljava/lang/Object;
move-result-object v10
.line 249
.local v10, "v":Ljava/lang/Object;, "TT;"
if-eqz v10, :cond_5b
.line 250
const/4 v13, 0x0
.line 251
invoke-interface {v4, v10}, Lorg/reactivestreams/Subscriber;->onNext(Ljava/lang/Object;)V
.line 252
invoke-virtual {v15}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;->requestOne()V
.line 253
const-wide/16 v17, 0x1
add-long v17, v7, v17
move-wide/from16 v7, v17
cmp-long v19, v17, v5
if-nez v19, :cond_5b
.line 254
goto :goto_6a
.line 243
.end local v9 # "q":Lio/reactivex/internal/fuseable/SimplePlainQueue;, "Lio/reactivex/internal/fuseable/SimplePlainQueue<TT;>;"
.end local v10 # "v":Ljava/lang/Object;, "TT;"
.end local v15 # "inner":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber<TT;>;"
:cond_5b
add-int/lit8 v14, v14, 0x1
goto :goto_3a
.line 260
.end local v14 # "i":I
:cond_5e
if-eqz v12, :cond_66
if-eqz v13, :cond_66
.line 261
invoke-interface {v4}, Lorg/reactivestreams/Subscriber;->onComplete()V
.line 262
return-void
.line 265
:cond_66
if-eqz v13, :cond_69
.line 266
goto :goto_6a
.line 268
.end local v11 # "ex":Ljava/lang/Throwable;
.end local v12 # "d":Z
.end local v13 # "empty":Z
:cond_69
goto :goto_10
.line 270
:cond_6a
:goto_6a
cmp-long v9, v7, v5
if-nez v9, :cond_b3
.line 271
iget-boolean v9, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cancelled:Z
if-eqz v9, :cond_76
.line 272
invoke-virtual/range {p0 .. p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cleanup()V
.line 273
return-void
.line 276
:cond_76
iget-object v9, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->errors:Lio/reactivex/internal/util/AtomicThrowable;
invoke-virtual {v9}, Lio/reactivex/internal/util/AtomicThrowable;->get()Ljava/lang/Object;
move-result-object v9
check-cast v9, Ljava/lang/Throwable;
.line 277
.local v9, "ex":Ljava/lang/Throwable;
if-eqz v9, :cond_87
.line 278
invoke-virtual/range {p0 .. p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cleanup()V
.line 279
invoke-interface {v4, v9}, Lorg/reactivestreams/Subscriber;->onError(Ljava/lang/Throwable;)V
.line 280
return-void
.line 283
:cond_87
iget-object v10, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->done:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v10}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I
move-result v10
if-nez v10, :cond_92
const/16 v16, 0x1
goto :goto_94
:cond_92
const/16 v16, 0x0
:goto_94
move/from16 v10, v16
.line 285
.local v10, "d":Z
const/4 v11, 0x1
.line 287
.local v11, "empty":Z
const/4 v12, 0x0
.local v12, "i":I
:goto_98
if-ge v12, v3, :cond_ab
.line 288
aget-object v13, v2, v12
.line 290
.local v13, "inner":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber<TT;>;"
iget-object v14, v13, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;->queue:Lio/reactivex/internal/fuseable/SimplePlainQueue;
.line 291
.local v14, "q":Lio/reactivex/internal/fuseable/SimpleQueue;, "Lio/reactivex/internal/fuseable/SimpleQueue<TT;>;"
if-eqz v14, :cond_a8
invoke-interface {v14}, Lio/reactivex/internal/fuseable/SimpleQueue;->isEmpty()Z
move-result v15
if-nez v15, :cond_a8
.line 292
const/4 v11, 0x0
.line 293
goto :goto_ab
.line 287
.end local v13 # "inner":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber<TT;>;"
.end local v14 # "q":Lio/reactivex/internal/fuseable/SimpleQueue;, "Lio/reactivex/internal/fuseable/SimpleQueue<TT;>;"
:cond_a8
add-int/lit8 v12, v12, 0x1
goto :goto_98
.line 297
.end local v12 # "i":I
:cond_ab
:goto_ab
if-eqz v10, :cond_b3
if-eqz v11, :cond_b3
.line 298
invoke-interface {v4}, Lorg/reactivestreams/Subscriber;->onComplete()V
.line 299
return-void
.line 303
.end local v9 # "ex":Ljava/lang/Throwable;
.end local v10 # "d":Z
.end local v11 # "empty":Z
:cond_b3
const-wide/16 v9, 0x0
cmp-long v11, v7, v9
if-eqz v11, :cond_c8
const-wide v9, 0x7fffffffffffffffL
cmp-long v11, v5, v9
if-eqz v11, :cond_c8
.line 304
iget-object v9, v0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->requested:Ljava/util/concurrent/atomic/AtomicLong;
neg-long v10, v7
invoke-virtual {v9, v10, v11}, Ljava/util/concurrent/atomic/AtomicLong;->addAndGet(J)J
.line 307
:cond_c8
invoke-virtual/range {p0 .. p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->get()I
move-result v9
.line 308
.local v9, "w":I
if-ne v9, v1, :cond_d7
.line 309
neg-int v10, v1
invoke-virtual {v0, v10}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->addAndGet(I)I
move-result v1
.line 310
if-nez v1, :cond_d8
.line 311
nop
.line 317
.end local v5 # "r":J
.end local v7 # "e":J
.end local v9 # "w":I
return-void
.line 314
.restart local v5 # "r":J
.restart local v7 # "e":J
.restart local v9 # "w":I
:cond_d7
move v1, v9
.line 316
.end local v5 # "r":J
.end local v7 # "e":J
.end local v9 # "w":I
:cond_d8
goto/16 :goto_8
.end method
.method public onComplete()V
.registers 2
.line 200
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription<TT;>;"
iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->done:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicInteger;->decrementAndGet()I
.line 201
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->drain()V
.line 202
return-void
.end method
.method public onError(Ljava/lang/Throwable;)V
.registers 4
.param p1, "e" # Ljava/lang/Throwable;
.line 188
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription<TT;>;"
iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->errors:Lio/reactivex/internal/util/AtomicThrowable;
const/4 v1, 0x0
invoke-virtual {v0, v1, p1}, Lio/reactivex/internal/util/AtomicThrowable;->compareAndSet(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_10
.line 189
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cancelAll()V
.line 190
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->drain()V
goto :goto_1b
.line 192
:cond_10
iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->errors:Lio/reactivex/internal/util/AtomicThrowable;
invoke-virtual {v0}, Lio/reactivex/internal/util/AtomicThrowable;->get()Ljava/lang/Object;
move-result-object v0
if-eq p1, v0, :cond_1b
.line 193
invoke-static {p1}, Lio/reactivex/plugins/RxJavaPlugins;->onError(Ljava/lang/Throwable;)V
.line 196
:cond_1b
:goto_1b
return-void
.end method
.method public onNext(Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;Ljava/lang/Object;)V
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber<",
"TT;>;TT;)V"
}
.end annotation
.line 145
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription<TT;>;"
.local p1, "inner":Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;, "Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber<TT;>;"
.local p2, "value":Ljava/lang/Object;, "TT;"
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->get()I
move-result v0
const-string v1, "Queue full?!"
if-nez v0, :cond_68
const/4 v0, 0x0
const/4 v2, 0x1
invoke-virtual {p0, v0, v2}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->compareAndSet(II)Z
move-result v0
if-eqz v0, :cond_68
.line 146
iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->requested:Ljava/util/concurrent/atomic/AtomicLong;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicLong;->get()J
move-result-wide v2
const-wide/16 v4, 0x0
cmp-long v0, v2, v4
if-eqz v0, :cond_3b
.line 147
iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->actual:Lorg/reactivestreams/Subscriber;
invoke-interface {v0, p2}, Lorg/reactivestreams/Subscriber;->onNext(Ljava/lang/Object;)V
.line 148
iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->requested:Ljava/util/concurrent/atomic/AtomicLong;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicLong;->get()J
move-result-wide v0
const-wide v2, 0x7fffffffffffffffL
cmp-long v4, v0, v2
if-eqz v4, :cond_35
.line 149
iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->requested:Ljava/util/concurrent/atomic/AtomicLong;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicLong;->decrementAndGet()J
.line 151
:cond_35
const-wide/16 v0, 0x1
invoke-virtual {p1, v0, v1}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;->request(J)V
goto :goto_61
.line 153
:cond_3b
invoke-virtual {p1}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;->getQueue()Lio/reactivex/internal/fuseable/SimplePlainQueue;
move-result-object v0
.line 155
.local v0, "q":Lio/reactivex/internal/fuseable/SimplePlainQueue;, "Lio/reactivex/internal/fuseable/SimplePlainQueue<TT;>;"
invoke-interface {v0, p2}, Lio/reactivex/internal/fuseable/SimplePlainQueue;->offer(Ljava/lang/Object;)Z
move-result v2
if-nez v2, :cond_61
.line 156
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cancelAll()V
.line 157
new-instance v2, Lio/reactivex/exceptions/MissingBackpressureException;
invoke-direct {v2, v1}, Lio/reactivex/exceptions/MissingBackpressureException;-><init>(Ljava/lang/String;)V
move-object v1, v2
.line 158
.local v1, "mbe":Ljava/lang/Throwable;
iget-object v2, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->errors:Lio/reactivex/internal/util/AtomicThrowable;
const/4 v3, 0x0
invoke-virtual {v2, v3, v1}, Lio/reactivex/internal/util/AtomicThrowable;->compareAndSet(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_5d
.line 159
iget-object v2, p0, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->actual:Lorg/reactivestreams/Subscriber;
invoke-interface {v2, v1}, Lorg/reactivestreams/Subscriber;->onError(Ljava/lang/Throwable;)V
goto :goto_60
.line 161
:cond_5d
invoke-static {v1}, Lio/reactivex/plugins/RxJavaPlugins;->onError(Ljava/lang/Throwable;)V
.line 163
:goto_60
return-void
.line 166
.end local v0 # "q":Lio/reactivex/internal/fuseable/SimplePlainQueue;, "Lio/reactivex/internal/fuseable/SimplePlainQueue<TT;>;"
.end local v1 # "mbe":Ljava/lang/Throwable;
:cond_61
:goto_61
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->decrementAndGet()I
move-result v0
if-nez v0, :cond_85
.line 167
return-void
.line 170
:cond_68
invoke-virtual {p1}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinInnerSubscriber;->getQueue()Lio/reactivex/internal/fuseable/SimplePlainQueue;
move-result-object v0
.line 172
.restart local v0 # "q":Lio/reactivex/internal/fuseable/SimplePlainQueue;, "Lio/reactivex/internal/fuseable/SimplePlainQueue<TT;>;"
invoke-interface {v0, p2}, Lio/reactivex/internal/fuseable/SimplePlainQueue;->offer(Ljava/lang/Object;)Z
move-result v2
if-nez v2, :cond_7e
.line 173
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->cancelAll()V
.line 174
new-instance v2, Lio/reactivex/exceptions/MissingBackpressureException;
invoke-direct {v2, v1}, Lio/reactivex/exceptions/MissingBackpressureException;-><init>(Ljava/lang/String;)V
invoke-virtual {p0, v2}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->onError(Ljava/lang/Throwable;)V
.line 175
return-void
.line 178
:cond_7e
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->getAndIncrement()I
move-result v1
if-eqz v1, :cond_85
.line 179
return-void
.line 183
.end local v0 # "q":Lio/reactivex/internal/fuseable/SimplePlainQueue;, "Lio/reactivex/internal/fuseable/SimplePlainQueue<TT;>;"
:cond_85
invoke-virtual {p0}, Lio/reactivex/internal/operators/parallel/ParallelJoin$JoinSubscription;->drainLoop()V
.line 184
return-void
.end method