final class reactor.core.publisher.FluxMerge<T> extends reactor.core.publisher.Flux<T> implements reactor.core.publisher.SourceProducer<T>
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: reactor.core.publisher.FluxMerge
super_class: reactor.core.publisher.Flux
{
final org.reactivestreams.Publisher<? extends T>[] sources;
descriptor: [Lorg/reactivestreams/Publisher;
flags: (0x0010) ACC_FINAL
Signature: [Lorg/reactivestreams/Publisher<+TT;>;
final boolean delayError;
descriptor: Z
flags: (0x0010) ACC_FINAL
final int maxConcurrency;
descriptor: I
flags: (0x0010) ACC_FINAL
final java.util.function.Supplier<? extends java.util.Queue<T>> mainQueueSupplier;
descriptor: Ljava/util/function/Supplier;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
final int prefetch;
descriptor: I
flags: (0x0010) ACC_FINAL
final java.util.function.Supplier<? extends java.util.Queue<T>> innerQueueSupplier;
descriptor: Ljava/util/function/Supplier;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
void <init>(org.reactivestreams.Publisher<? extends T>[], boolean, int, java.util.function.Supplier<? extends java.util.Queue<T>>, int, java.util.function.Supplier<? extends java.util.Queue<T>>);
descriptor: ([Lorg/reactivestreams/Publisher;ZILjava/util/function/Supplier;ILjava/util/function/Supplier;)V
flags: (0x0000)
Code:
stack=5, locals=7, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 0
invokespecial reactor.core.publisher.Flux.<init>:()V
1: iload 5
ifgt 3
2: new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
ldc "prefetch > 0 required but it was "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
iload 5
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: reactor.core.publisher.FluxMerge org.reactivestreams.Publisher[] int int java.util.function.Supplier int java.util.function.Supplier
StackMap stack:
iload 3
ifgt 5
4: new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
ldc "maxConcurrency > 0 required but it was "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
iload 3
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
5: StackMap locals:
StackMap stack:
aload 0
aload 1
ldc "sources"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast org.reactivestreams.Publisher[]
putfield reactor.core.publisher.FluxMerge.sources:[Lorg/reactivestreams/Publisher;
6: aload 0
iload 2
putfield reactor.core.publisher.FluxMerge.delayError:Z
7: aload 0
iload 3
putfield reactor.core.publisher.FluxMerge.maxConcurrency:I
8: aload 0
iload 5
putfield reactor.core.publisher.FluxMerge.prefetch:I
9: aload 0
aload 4
ldc "mainQueueSupplier"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.function.Supplier
putfield reactor.core.publisher.FluxMerge.mainQueueSupplier:Ljava/util/function/Supplier;
10: aload 0
aload 6
ldc "innerQueueSupplier"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.function.Supplier
putfield reactor.core.publisher.FluxMerge.innerQueueSupplier:Ljava/util/function/Supplier;
11: return
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lreactor/core/publisher/FluxMerge<TT;>;
0 12 1 sources [Lorg/reactivestreams/Publisher;
0 12 2 delayError Z
0 12 3 maxConcurrency I
0 12 4 mainQueueSupplier Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
0 12 5 prefetch I
0 12 6 innerQueueSupplier Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
Signature: ([Lorg/reactivestreams/Publisher<+TT;>;ZILjava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;ILjava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;)V
MethodParameters:
Name Flags
sources
delayError
maxConcurrency
mainQueueSupplier
prefetch
innerQueueSupplier
public void subscribe(reactor.core.CoreSubscriber<? super T>);
descriptor: (Lreactor/core/CoreSubscriber;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=9, locals=3, args_size=2
start local 0 start local 1 0: new reactor.core.publisher.FluxFlatMap$FlatMapMain
dup
1: aload 1
invokestatic reactor.core.publisher.FluxMerge.identityFunction:()Ljava/util/function/Function;
aload 0
getfield reactor.core.publisher.FluxMerge.delayError:Z
aload 0
getfield reactor.core.publisher.FluxMerge.maxConcurrency:I
aload 0
getfield reactor.core.publisher.FluxMerge.mainQueueSupplier:Ljava/util/function/Supplier;
aload 0
getfield reactor.core.publisher.FluxMerge.prefetch:I
2: aload 0
getfield reactor.core.publisher.FluxMerge.innerQueueSupplier:Ljava/util/function/Supplier;
3: invokespecial reactor.core.publisher.FluxFlatMap$FlatMapMain.<init>:(Lreactor/core/CoreSubscriber;Ljava/util/function/Function;ZILjava/util/function/Supplier;ILjava/util/function/Supplier;)V
astore 2
start local 2 4: aload 2
new reactor.core.publisher.FluxArray$ArraySubscription
dup
aload 2
aload 0
getfield reactor.core.publisher.FluxMerge.sources:[Lorg/reactivestreams/Publisher;
invokespecial reactor.core.publisher.FluxArray$ArraySubscription.<init>:(Lreactor/core/CoreSubscriber;[Ljava/lang/Object;)V
invokevirtual reactor.core.publisher.FluxFlatMap$FlatMapMain.onSubscribe:(Lorg/reactivestreams/Subscription;)V
5: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lreactor/core/publisher/FluxMerge<TT;>;
0 6 1 actual Lreactor/core/CoreSubscriber<-TT;>;
4 6 2 merger Lreactor/core/publisher/FluxFlatMap$FlatMapMain<Lorg/reactivestreams/Publisher<+TT;>;TT;>;
Signature: (Lreactor/core/CoreSubscriber<-TT;>;)V
MethodParameters:
Name Flags
actual
reactor.core.publisher.FluxMerge<T> mergeAdditionalSource(org.reactivestreams.Publisher<? extends T>, java.util.function.IntFunction<java.util.function.Supplier<? extends java.util.Queue<T>>>);
descriptor: (Lorg/reactivestreams/Publisher;Ljava/util/function/IntFunction;)Lreactor/core/publisher/FluxMerge;
flags: (0x0000)
Code:
stack=8, locals=7, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield reactor.core.publisher.FluxMerge.sources:[Lorg/reactivestreams/Publisher;
arraylength
istore 3
start local 3 1: iload 3
iconst_1
iadd
anewarray org.reactivestreams.Publisher
astore 4
start local 4 2: aload 0
getfield reactor.core.publisher.FluxMerge.sources:[Lorg/reactivestreams/Publisher;
iconst_0
aload 4
iconst_0
iload 3
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
3: aload 4
iload 3
aload 1
aastore
4: aload 0
getfield reactor.core.publisher.FluxMerge.maxConcurrency:I
istore 6
start local 6 5: iload 6
ldc 2147483647
if_icmpeq 9
6: iinc 6 1
7: aload 2
iload 6
invokeinterface java.util.function.IntFunction.apply:(I)Ljava/lang/Object;
checkcast java.util.function.Supplier
astore 5
start local 5 8: goto 10
end local 5 9: StackMap locals: reactor.core.publisher.FluxMerge org.reactivestreams.Publisher java.util.function.IntFunction int org.reactivestreams.Publisher[] top int
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxMerge.mainQueueSupplier:Ljava/util/function/Supplier;
astore 5
start local 5 10: StackMap locals: reactor.core.publisher.FluxMerge org.reactivestreams.Publisher java.util.function.IntFunction int org.reactivestreams.Publisher[] java.util.function.Supplier int
StackMap stack:
new reactor.core.publisher.FluxMerge
dup
aload 4
aload 0
getfield reactor.core.publisher.FluxMerge.delayError:Z
iload 6
aload 5
aload 0
getfield reactor.core.publisher.FluxMerge.prefetch:I
aload 0
getfield reactor.core.publisher.FluxMerge.innerQueueSupplier:Ljava/util/function/Supplier;
invokespecial reactor.core.publisher.FluxMerge.<init>:([Lorg/reactivestreams/Publisher;ZILjava/util/function/Supplier;ILjava/util/function/Supplier;)V
areturn
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lreactor/core/publisher/FluxMerge<TT;>;
0 11 1 source Lorg/reactivestreams/Publisher<+TT;>;
0 11 2 newQueueSupplier Ljava/util/function/IntFunction<Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;>;
1 11 3 n I
2 11 4 newArray [Lorg/reactivestreams/Publisher;
8 9 5 newMainQueue Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
10 11 5 newMainQueue Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
5 11 6 mc I
Signature: (Lorg/reactivestreams/Publisher<+TT;>;Ljava/util/function/IntFunction<Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;>;)Lreactor/core/publisher/FluxMerge<TT;>;
MethodParameters:
Name Flags
source
newQueueSupplier
public java.lang.Object scanUnsafe(reactor.core.Scannable$Attr);
descriptor: (Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
getstatic reactor.core.Scannable$Attr.DELAY_ERROR:Lreactor/core/Scannable$Attr;
if_acmpne 1
aload 0
getfield reactor.core.publisher.FluxMerge.delayError:Z
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
areturn
1: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.PREFETCH:Lreactor/core/Scannable$Attr;
if_acmpne 2
aload 0
getfield reactor.core.publisher.FluxMerge.prefetch:I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
areturn
2: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
if_acmpne 3
getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
areturn
3: StackMap locals:
StackMap stack:
aconst_null
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lreactor/core/publisher/FluxMerge<TT;>;
0 4 1 key Lreactor/core/Scannable$Attr;
MethodParameters:
Name Flags
key
}
Signature: <T:Ljava/lang/Object;>Lreactor/core/publisher/Flux<TT;>;Lreactor/core/publisher/SourceProducer<TT;>;
SourceFile: "FluxMerge.java"
InnerClasses:
public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
public final RunStyle = reactor.core.Scannable$Attr$RunStyle of reactor.core.Scannable$Attr
final ArraySubscription = reactor.core.publisher.FluxArray$ArraySubscription of reactor.core.publisher.FluxArray
final FlatMapMain = reactor.core.publisher.FluxFlatMap$FlatMapMain of reactor.core.publisher.FluxFlatMap