ParallelReduce.smali
.class public final Lio/reactivex/internal/operators/parallel/ParallelReduce;
.super Lio/reactivex/parallel/ParallelFlowable;
.source "ParallelReduce.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber;
}
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
"R:",
"Ljava/lang/Object;",
">",
"Lio/reactivex/parallel/ParallelFlowable<",
"TR;>;"
}
.end annotation
# instance fields
.field final initialSupplier:Ljava/util/concurrent/Callable;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/Callable<",
"TR;>;"
}
.end annotation
.end field
.field final reducer:Lio/reactivex/functions/BiFunction;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lio/reactivex/functions/BiFunction<",
"TR;-TT;TR;>;"
}
.end annotation
.end field
.field final source:Lio/reactivex/parallel/ParallelFlowable;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lio/reactivex/parallel/ParallelFlowable<",
"+TT;>;"
}
.end annotation
.end field
# direct methods
.method static constructor <clinit>()V
.registers 1
return-void
.end method
.method public constructor <init>(Lio/reactivex/parallel/ParallelFlowable;Ljava/util/concurrent/Callable;Lio/reactivex/functions/BiFunction;)V
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/reactivex/parallel/ParallelFlowable<",
"+TT;>;",
"Ljava/util/concurrent/Callable<",
"TR;>;",
"Lio/reactivex/functions/BiFunction<",
"TR;-TT;TR;>;)V"
}
.end annotation
.line 42
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelReduce;, "Lio/reactivex/internal/operators/parallel/ParallelReduce<TT;TR;>;"
.local p1, "source":Lio/reactivex/parallel/ParallelFlowable;, "Lio/reactivex/parallel/ParallelFlowable<+TT;>;"
.local p2, "initialSupplier":Ljava/util/concurrent/Callable;, "Ljava/util/concurrent/Callable<TR;>;"
.local p3, "reducer":Lio/reactivex/functions/BiFunction;, "Lio/reactivex/functions/BiFunction<TR;-TT;TR;>;"
invoke-direct {p0}, Lio/reactivex/parallel/ParallelFlowable;-><init>()V
.line 43
iput-object p1, p0, Lio/reactivex/internal/operators/parallel/ParallelReduce;->source:Lio/reactivex/parallel/ParallelFlowable;
.line 44
iput-object p2, p0, Lio/reactivex/internal/operators/parallel/ParallelReduce;->initialSupplier:Ljava/util/concurrent/Callable;
.line 45
iput-object p3, p0, Lio/reactivex/internal/operators/parallel/ParallelReduce;->reducer:Lio/reactivex/functions/BiFunction;
.line 46
return-void
.end method
# virtual methods
.method public parallelism()I
.registers 2
.line 84
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelReduce;, "Lio/reactivex/internal/operators/parallel/ParallelReduce<TT;TR;>;"
iget-object v0, p0, Lio/reactivex/internal/operators/parallel/ParallelReduce;->source:Lio/reactivex/parallel/ParallelFlowable;
invoke-virtual {v0}, Lio/reactivex/parallel/ParallelFlowable;->parallelism()I
move-result v0
return v0
.end method
.method reportError([Lorg/reactivestreams/Subscriber;Ljava/lang/Throwable;)V
.registers 6
.param p2, "ex" # Ljava/lang/Throwable;
.annotation system Ldalvik/annotation/Signature;
value = {
"([",
"Lorg/reactivestreams/Subscriber<",
"*>;",
"Ljava/lang/Throwable;",
")V"
}
.end annotation
.line 77
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelReduce;, "Lio/reactivex/internal/operators/parallel/ParallelReduce<TT;TR;>;"
.local p1, "subscribers":[Lorg/reactivestreams/Subscriber;, "[Lorg/reactivestreams/Subscriber<*>;"
array-length v0, p1
const/4 v1, 0x0
:goto_2
if-ge v1, v0, :cond_c
aget-object v2, p1, v1
.line 78
.local v2, "s":Lorg/reactivestreams/Subscriber;, "Lorg/reactivestreams/Subscriber<*>;"
invoke-static {p2, v2}, Lio/reactivex/internal/subscriptions/EmptySubscription;->error(Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;)V
.line 77
.end local v2 # "s":Lorg/reactivestreams/Subscriber;, "Lorg/reactivestreams/Subscriber<*>;"
add-int/lit8 v1, v1, 0x1
goto :goto_2
.line 80
:cond_c
return-void
.end method
.method public subscribe([Lorg/reactivestreams/Subscriber;)V
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"([",
"Lorg/reactivestreams/Subscriber<",
"-TR;>;)V"
}
.end annotation
.line 50
.local p0, "this":Lio/reactivex/internal/operators/parallel/ParallelReduce;, "Lio/reactivex/internal/operators/parallel/ParallelReduce<TT;TR;>;"
.local p1, "subscribers":[Lorg/reactivestreams/Subscriber;, "[Lorg/reactivestreams/Subscriber<-TR;>;"
invoke-virtual {p0, p1}, Lio/reactivex/internal/operators/parallel/ParallelReduce;->validate([Lorg/reactivestreams/Subscriber;)Z
move-result v0
if-nez v0, :cond_7
.line 51
return-void
.line 54
:cond_7
array-length v0, p1
.line 56
.local v0, "n":I
new-array v1, v0, [Lorg/reactivestreams/Subscriber;
.line 58
.local v1, "parents":[Lorg/reactivestreams/Subscriber;, "[Lorg/reactivestreams/Subscriber<TT;>;"
const/4 v2, 0x0
.local v2, "i":I
:goto_b
if-ge v2, v0, :cond_30
.line 63
:try_start_d
iget-object v3, p0, Lio/reactivex/internal/operators/parallel/ParallelReduce;->initialSupplier:Ljava/util/concurrent/Callable;
invoke-interface {v3}, Ljava/util/concurrent/Callable;->call()Ljava/lang/Object;
move-result-object v3
const-string v4, "The initialSupplier returned a null value"
invoke-static {v3, v4}, Lio/reactivex/internal/functions/ObjectHelper;->requireNonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
move-result-object v3
:try_end_19
.catchall {:try_start_d .. :try_end_19} :catchall_28
.line 68
.local v3, "initialValue":Ljava/lang/Object;, "TR;"
nop
.line 70
new-instance v4, Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber;
aget-object v5, p1, v2
iget-object v6, p0, Lio/reactivex/internal/operators/parallel/ParallelReduce;->reducer:Lio/reactivex/functions/BiFunction;
invoke-direct {v4, v5, v3, v6}, Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber;-><init>(Lorg/reactivestreams/Subscriber;Ljava/lang/Object;Lio/reactivex/functions/BiFunction;)V
aput-object v4, v1, v2
.line 58
.end local v3 # "initialValue":Ljava/lang/Object;, "TR;"
add-int/lit8 v2, v2, 0x1
goto :goto_b
.line 64
:catchall_28
move-exception v3
.line 65
.local v3, "ex":Ljava/lang/Throwable;
invoke-static {v3}, Lio/reactivex/exceptions/Exceptions;->throwIfFatal(Ljava/lang/Throwable;)V
.line 66
invoke-virtual {p0, p1, v3}, Lio/reactivex/internal/operators/parallel/ParallelReduce;->reportError([Lorg/reactivestreams/Subscriber;Ljava/lang/Throwable;)V
.line 67
return-void
.line 73
.end local v2 # "i":I
.end local v3 # "ex":Ljava/lang/Throwable;
:cond_30
iget-object v2, p0, Lio/reactivex/internal/operators/parallel/ParallelReduce;->source:Lio/reactivex/parallel/ParallelFlowable;
invoke-virtual {v2, v1}, Lio/reactivex/parallel/ParallelFlowable;->subscribe([Lorg/reactivestreams/Subscriber;)V
.line 74
return-void
.end method