final class reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription<TLeft, TRight, TLeftEnd, TRightEnd, R> implements reactor.core.publisher.FluxGroupJoin$JoinSupport<R>
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription
super_class: java.lang.Object
{
final java.util.Queue<java.lang.Object> queue;
descriptor: Ljava/util/Queue;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/Queue<Ljava/lang/Object;>;
final java.util.function.BiPredicate<java.lang.Object, java.lang.Object> queueBiOffer;
descriptor: Ljava/util/function/BiPredicate;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/BiPredicate<Ljava/lang/Object;Ljava/lang/Object;>;
final reactor.core.Disposable$Composite cancellations;
descriptor: Lreactor/core/Disposable$Composite;
flags: (0x0010) ACC_FINAL
final java.util.Map<java.lang.Integer, reactor.core.publisher.Sinks$Many<TRight>> lefts;
descriptor: Ljava/util/Map;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/Map<Ljava/lang/Integer;Lreactor/core/publisher/Sinks$Many<TTRight;>;>;
final java.util.Map<java.lang.Integer, TRight> rights;
descriptor: Ljava/util/Map;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/Map<Ljava/lang/Integer;TTRight;>;
final java.util.function.Function<? super TLeft, ? extends org.reactivestreams.Publisher<TLeftEnd>> leftEnd;
descriptor: Ljava/util/function/Function;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;
final java.util.function.Function<? super TRight, ? extends org.reactivestreams.Publisher<TRightEnd>> rightEnd;
descriptor: Ljava/util/function/Function;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;
final java.util.function.BiFunction<? super TLeft, ? super reactor.core.publisher.Flux<TRight>, ? extends R> resultSelector;
descriptor: Ljava/util/function/BiFunction;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/BiFunction<-TTLeft;-Lreactor/core/publisher/Flux<TTRight;>;+TR;>;
final java.util.function.Supplier<? extends java.util.Queue<TRight>> processorQueueSupplier;
descriptor: Ljava/util/function/Supplier;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Supplier<+Ljava/util/Queue<TTRight;>;>;
final reactor.core.CoreSubscriber<? super R> actual;
descriptor: Lreactor/core/CoreSubscriber;
flags: (0x0010) ACC_FINAL
Signature: Lreactor/core/CoreSubscriber<-TR;>;
int leftIndex;
descriptor: I
flags: (0x0000)
int rightIndex;
descriptor: I
flags: (0x0000)
volatile int wip;
descriptor: I
flags: (0x0040) ACC_VOLATILE
static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription> WIP;
descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
flags: (0x0018) ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription;>;
volatile int active;
descriptor: I
flags: (0x0040) ACC_VOLATILE
static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription> ACTIVE;
descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
flags: (0x0018) ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription;>;
volatile long requested;
descriptor: J
flags: (0x0040) ACC_VOLATILE
static final java.util.concurrent.atomic.AtomicLongFieldUpdater<reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription> REQUESTED;
descriptor: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
flags: (0x0018) ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater<Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription;>;
volatile java.lang.Throwable error;
descriptor: Ljava/lang/Throwable;
flags: (0x0040) ACC_VOLATILE
static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription, java.lang.Throwable> ERROR;
descriptor: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
flags: (0x0018) ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription;Ljava/lang/Throwable;>;
static final java.lang.Integer LEFT_VALUE;
descriptor: Ljava/lang/Integer;
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final java.lang.Integer RIGHT_VALUE;
descriptor: Ljava/lang/Integer;
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final java.lang.Integer LEFT_CLOSE;
descriptor: Ljava/lang/Integer;
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final java.lang.Integer RIGHT_CLOSE;
descriptor: Ljava/lang/Integer;
flags: (0x0018) ACC_STATIC, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=3, locals=0, args_size=0
0: ldc Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription;
ldc "wip"
invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
1: putstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
2: ldc Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription;
3: ldc "active"
4: invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
5: putstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ACTIVE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
6: ldc Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription;
7: ldc "requested"
8: invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
9: putstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
10: ldc Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription;
11: ldc Ljava/lang/Throwable;
12: ldc "error"
13: invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
14: putstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
15: iconst_1
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
putstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
16: iconst_2
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
putstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
17: iconst_3
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
putstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
18: iconst_4
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
putstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
return
LocalVariableTable:
Start End Slot Name Signature
void <init>(reactor.core.CoreSubscriber<? super R>, java.util.function.Function<? super TLeft, ? extends org.reactivestreams.Publisher<TLeftEnd>>, java.util.function.Function<? super TRight, ? extends org.reactivestreams.Publisher<TRightEnd>>, java.util.function.BiFunction<? super TLeft, ? super reactor.core.publisher.Flux<TRight>, ? extends R>, java.util.function.Supplier<? extends java.util.Queue<TRight>>);
descriptor: (Lreactor/core/CoreSubscriber;Ljava/util/function/Function;Ljava/util/function/Function;Ljava/util/function/BiFunction;Ljava/util/function/Supplier;)V
flags: (0x0000)
Code:
stack=3, locals=6, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 1
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.actual:Lreactor/core/CoreSubscriber;
2: aload 0
invokestatic reactor.core.Disposables.composite:()Lreactor/core/Disposable$Composite;
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
3: aload 0
aload 5
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.processorQueueSupplier:Ljava/util/function/Supplier;
4: aload 0
invokestatic reactor.util.concurrent.Queues.unboundedMultiproducer:()Ljava/util/function/Supplier;
invokeinterface java.util.function.Supplier.get:()Ljava/lang/Object;
checkcast java.util.Queue
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.queue:Ljava/util/Queue;
5: aload 0
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.queue:Ljava/util/Queue;
checkcast java.util.function.BiPredicate
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.queueBiOffer:Ljava/util/function/BiPredicate;
6: aload 0
new java.util.LinkedHashMap
dup
invokespecial java.util.LinkedHashMap.<init>:()V
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
7: aload 0
new java.util.LinkedHashMap
dup
invokespecial java.util.LinkedHashMap.<init>:()V
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
8: aload 0
aload 2
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.leftEnd:Ljava/util/function/Function;
9: aload 0
aload 3
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rightEnd:Ljava/util/function/Function;
10: aload 0
aload 4
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.resultSelector:Ljava/util/function/BiFunction;
11: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ACTIVE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
iconst_2
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
12: return
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 13 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 13 1 actual Lreactor/core/CoreSubscriber<-TR;>;
0 13 2 leftEnd Ljava/util/function/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;
0 13 3 rightEnd Ljava/util/function/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;
0 13 4 resultSelector Ljava/util/function/BiFunction<-TTLeft;-Lreactor/core/publisher/Flux<TTRight;>;+TR;>;
0 13 5 processorQueueSupplier Ljava/util/function/Supplier<+Ljava/util/Queue<TTRight;>;>;
Signature: (Lreactor/core/CoreSubscriber<-TR;>;Ljava/util/function/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;Ljava/util/function/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;Ljava/util/function/BiFunction<-TTLeft;-Lreactor/core/publisher/Flux<TTRight;>;+TR;>;Ljava/util/function/Supplier<+Ljava/util/Queue<TTRight;>;>;)V
MethodParameters:
Name Flags
actual
leftEnd
rightEnd
resultSelector
processorQueueSupplier
public final reactor.core.CoreSubscriber<? super R> actual();
descriptor: ()Lreactor/core/CoreSubscriber;
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.actual:Lreactor/core/CoreSubscriber;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
Signature: ()Lreactor/core/CoreSubscriber<-TR;>;
public java.util.stream.Stream<? extends reactor.core.Scannable> inners();
descriptor: ()Ljava/util/stream/Stream;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
invokeinterface java.util.Map.values:()Ljava/util/Collection;
invokeinterface java.util.Collection.stream:()Ljava/util/stream/Stream;
invokedynamic apply()Ljava/util/function/Function;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
(Ljava/lang/Object;)Ljava/lang/Object;
reactor/core/Scannable.from(Ljava/lang/Object;)Lreactor/core/Scannable; (6 itf)
(Lreactor/core/publisher/Sinks$Many;)Lreactor/core/Scannable;
invokeinterface java.util.stream.Stream.map:(Ljava/util/function/Function;)Ljava/util/stream/Stream;
1: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokestatic reactor.core.Scannable.from:(Ljava/lang/Object;)Lreactor/core/Scannable;
invokeinterface reactor.core.Scannable.inners:()Ljava/util/stream/Stream;
2: invokestatic java.util.stream.Stream.concat:(Ljava/util/stream/Stream;Ljava/util/stream/Stream;)Ljava/util/stream/Stream;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
Signature: ()Ljava/util/stream/Stream<+Lreactor/core/Scannable;>;
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.REQUESTED_FROM_DOWNSTREAM:Lreactor/core/Scannable$Attr;
if_acmpne 1
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.requested:J
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
areturn
1: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.CANCELLED:Lreactor/core/Scannable$Attr;
if_acmpne 2
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokeinterface reactor.core.Disposable$Composite.isDisposed:()Z
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
areturn
2: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.BUFFERED:Lreactor/core/Scannable$Attr;
if_acmpne 3
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.queue:Ljava/util/Queue;
invokeinterface java.util.Queue.size:()I
iconst_2
idiv
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
areturn
3: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.TERMINATED:Lreactor/core/Scannable$Attr;
if_acmpne 5
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.active:I
ifne 4
iconst_1
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
areturn
StackMap locals:
StackMap stack:
4: iconst_0
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
areturn
5: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.ERROR:Lreactor/core/Scannable$Attr;
if_acmpne 6
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.error:Ljava/lang/Throwable;
areturn
6: StackMap locals:
StackMap stack:
aload 0
aload 1
invokespecial reactor.core.publisher.FluxGroupJoin$JoinSupport.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 7 1 key Lreactor/core/Scannable$Attr;
RuntimeVisibleAnnotations:
reactor.util.annotation.Nullable()
MethodParameters:
Name Flags
key
public void request(long);
descriptor: (J)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: lload 1
invokestatic reactor.core.publisher.Operators.validate:(J)Z
ifeq 2
1: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
aload 0
lload 1
invokestatic reactor.core.publisher.Operators.addCap:(Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;Ljava/lang/Object;J)J
pop2
2: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 3 1 n J
MethodParameters:
Name Flags
n
public void cancel();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokeinterface reactor.core.Disposable$Composite.isDisposed:()Z
ifeq 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokeinterface reactor.core.Disposable$Composite.dispose:()V
3: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
ifne 5
4: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.queue:Ljava/util/Queue;
invokeinterface java.util.Queue.clear:()V
5: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
void errorAll(org.reactivestreams.Subscriber<?>);
descriptor: (Lorg/reactivestreams/Subscriber;)V
flags: (0x0000)
Code:
stack=3, locals=5, args_size=2
start local 0 start local 1 0: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
aload 0
invokestatic reactor.core.Exceptions.terminate:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;)Ljava/lang/Throwable;
astore 2
start local 2 1: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
invokeinterface java.util.Map.values:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 4
goto 4
StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription org.reactivestreams.Subscriber java.lang.Throwable top java.util.Iterator
StackMap stack:
2: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast reactor.core.publisher.Sinks$Many
astore 3
start local 3 3: aload 3
aload 2
getstatic reactor.core.publisher.Sinks$EmitFailureHandler.FAIL_FAST:Lreactor/core/publisher/Sinks$EmitFailureHandler;
invokeinterface reactor.core.publisher.Sinks$Many.emitError:(Ljava/lang/Throwable;Lreactor/core/publisher/Sinks$EmitFailureHandler;)V
end local 3 4: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 2
5: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
invokeinterface java.util.Map.clear:()V
6: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
invokeinterface java.util.Map.clear:()V
7: aload 1
aload 2
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
8: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 9 1 a Lorg/reactivestreams/Subscriber<*>;
1 9 2 ex Ljava/lang/Throwable;
3 4 3 up Lreactor/core/publisher/Sinks$Many<TTRight;>;
Signature: (Lorg/reactivestreams/Subscriber<*>;)V
MethodParameters:
Name Flags
a
void drain();
descriptor: ()V
flags: (0x0000)
Code:
stack=6, locals=19, args_size=1
start local 0 0: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
ifeq 2
1: return
2: StackMap locals:
StackMap stack:
iconst_1
istore 1
start local 1 3: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.queue:Ljava/util/Queue;
astore 2
start local 2 4: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.actual:Lreactor/core/CoreSubscriber;
astore 3
start local 3 5: StackMap locals: int java.util.Queue org.reactivestreams.Subscriber
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokeinterface reactor.core.Disposable$Composite.isDisposed:()Z
ifeq 8
6: aload 2
invokeinterface java.util.Queue.clear:()V
7: return
8: StackMap locals:
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.error:Ljava/lang/Throwable;
astore 4
start local 4 9: aload 4
ifnull 14
10: aload 2
invokeinterface java.util.Queue.clear:()V
11: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokeinterface reactor.core.Disposable$Composite.dispose:()V
12: aload 0
aload 3
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
13: return
14: StackMap locals: java.lang.Throwable
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.active:I
ifne 15
iconst_1
goto 16
StackMap locals:
StackMap stack:
15: iconst_0
StackMap locals:
StackMap stack: int
16: istore 5
start local 5 17: aload 2
invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
checkcast java.lang.Integer
astore 6
start local 6 18: aload 6
ifnonnull 19
iconst_1
goto 20
StackMap locals: int java.lang.Integer
StackMap stack:
19: iconst_0
StackMap locals:
StackMap stack: int
20: istore 7
start local 7 21: iload 5
ifeq 31
iload 7
ifeq 31
22: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
invokeinterface java.util.Map.values:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 9
goto 25
StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int top java.util.Iterator
StackMap stack:
23: aload 9
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast reactor.core.publisher.Sinks$Many
astore 8
start local 8 24: aload 8
getstatic reactor.core.publisher.Sinks$EmitFailureHandler.FAIL_FAST:Lreactor/core/publisher/Sinks$EmitFailureHandler;
invokeinterface reactor.core.publisher.Sinks$Many.emitComplete:(Lreactor/core/publisher/Sinks$EmitFailureHandler;)V
end local 8 25: StackMap locals:
StackMap stack:
aload 9
invokeinterface java.util.Iterator.hasNext:()Z
ifne 23
26: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
invokeinterface java.util.Map.clear:()V
27: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
invokeinterface java.util.Map.clear:()V
28: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokeinterface reactor.core.Disposable$Composite.dispose:()V
29: aload 3
invokeinterface org.reactivestreams.Subscriber.onComplete:()V
30: return
31: StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int
StackMap stack:
iload 7
ifeq 33
32: goto 134
33: StackMap locals:
StackMap stack:
aload 2
invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
astore 8
start local 8 34: aload 6
getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
if_acmpne 90
35: aload 8
astore 9
start local 9 36: invokestatic reactor.core.publisher.Sinks.unsafe:()Lreactor/core/publisher/Sinks$RootSpec;
invokeinterface reactor.core.publisher.Sinks$RootSpec.many:()Lreactor/core/publisher/Sinks$ManySpec;
invokeinterface reactor.core.publisher.Sinks$ManySpec.unicast:()Lreactor/core/publisher/Sinks$UnicastSpec;
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.processorQueueSupplier:Ljava/util/function/Supplier;
invokeinterface java.util.function.Supplier.get:()Ljava/lang/Object;
checkcast java.util.Queue
invokeinterface reactor.core.publisher.Sinks$UnicastSpec.onBackpressureBuffer:(Ljava/util/Queue;)Lreactor/core/publisher/Sinks$Many;
astore 10
start local 10 37: aload 0
dup
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.leftIndex:I
dup_x1
iconst_1
iadd
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.leftIndex:I
istore 11
start local 11 38: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
iload 11
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
aload 10
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
39: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.leftEnd:Ljava/util/function/Function;
aload 9
invokeinterface java.util.function.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.reactivestreams.Publisher
40: ldc "The leftEnd returned a null Publisher"
41: invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast org.reactivestreams.Publisher
astore 12
start local 12 42: goto 52
end local 12 43: StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object reactor.core.publisher.Sinks$Many int
StackMap stack: java.lang.Throwable
astore 13
start local 13 44: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
45: aload 0
46: aload 0
aload 13
aload 9
47: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.actual:Lreactor/core/CoreSubscriber;
invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
48: invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
49: invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
pop
50: aload 0
aload 3
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
51: return
end local 13 start local 12 52: StackMap locals: org.reactivestreams.Publisher
StackMap stack:
new reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
dup
aload 0
iconst_1
iload 11
invokespecial reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber.<init>:(Lreactor/core/publisher/FluxGroupJoin$JoinSupport;ZI)V
53: astore 13
start local 13 54: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
aload 13
invokeinterface reactor.core.Disposable$Composite.add:(Lreactor/core/Disposable;)Z
pop
55: aload 12
aload 13
invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
56: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.error:Ljava/lang/Throwable;
astore 4
57: aload 4
ifnull 62
58: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokeinterface reactor.core.Disposable$Composite.dispose:()V
59: aload 2
invokeinterface java.util.Queue.clear:()V
60: aload 0
aload 3
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
61: return
62: StackMap locals: reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.resultSelector:Ljava/util/function/BiFunction;
aload 9
aload 10
invokeinterface reactor.core.publisher.Sinks$Many.asFlux:()Lreactor/core/publisher/Flux;
invokeinterface java.util.function.BiFunction.apply:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
63: ldc "The resultSelector returned a null value"
64: invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
astore 14
start local 14 65: goto 74
end local 14 66: StackMap locals:
StackMap stack: java.lang.Throwable
astore 15
start local 15 67: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
68: aload 0
aload 0
aload 15
aload 10
69: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.actual:Lreactor/core/CoreSubscriber;
invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
70: invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
71: invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
pop
72: aload 0
aload 3
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
73: return
end local 15 start local 14 74: StackMap locals: java.lang.Object
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.requested:J
lstore 15
start local 15 75: lload 15
lconst_0
lcmp
ifeq 79
76: aload 3
aload 14
invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
77: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
aload 0
lconst_1
invokestatic reactor.core.publisher.Operators.produced:(Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;Ljava/lang/Object;J)J
pop2
78: goto 85
79: StackMap locals: long
StackMap stack:
getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
80: aload 0
81: invokestatic reactor.core.Exceptions.failWithOverflow:()Ljava/lang/IllegalStateException;
82: invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
pop
83: aload 0
aload 3
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
84: return
85: StackMap locals:
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
invokeinterface java.util.Map.values:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 18
goto 88
StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object reactor.core.publisher.Sinks$Many int org.reactivestreams.Publisher reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber java.lang.Object long top java.util.Iterator
StackMap stack:
86: aload 18
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.Object
astore 17
start local 17 87: aload 10
aload 17
getstatic reactor.core.publisher.Sinks$EmitFailureHandler.FAIL_FAST:Lreactor/core/publisher/Sinks$EmitFailureHandler;
invokeinterface reactor.core.publisher.Sinks$Many.emitNext:(Ljava/lang/Object;Lreactor/core/publisher/Sinks$EmitFailureHandler;)V
end local 17 88: StackMap locals:
StackMap stack:
aload 18
invokeinterface java.util.Iterator.hasNext:()Z
ifne 86
end local 15 end local 14 end local 13 end local 12 end local 11 end local 10 end local 9 89: goto 5
90: StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object
StackMap stack:
aload 6
getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
if_acmpne 122
91: aload 8
astore 9
start local 9 92: aload 0
dup
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rightIndex:I
dup_x1
iconst_1
iadd
putfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rightIndex:I
istore 10
start local 10 93: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
iload 10
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
aload 9
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
94: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rightEnd:Ljava/util/function/Function;
aload 9
invokeinterface java.util.function.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.reactivestreams.Publisher
95: ldc "The rightEnd returned a null Publisher"
96: invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast org.reactivestreams.Publisher
astore 11
start local 11 97: goto 107
end local 11 98: StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int
StackMap stack: java.lang.Throwable
astore 12
start local 12 99: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
100: aload 0
101: aload 0
aload 12
aload 9
102: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.actual:Lreactor/core/CoreSubscriber;
invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
103: invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
104: invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
pop
105: aload 0
aload 3
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
106: return
end local 12 start local 11 107: StackMap locals: org.reactivestreams.Publisher
StackMap stack:
new reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
dup
aload 0
iconst_0
iload 10
invokespecial reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber.<init>:(Lreactor/core/publisher/FluxGroupJoin$JoinSupport;ZI)V
108: astore 12
start local 12 109: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
aload 12
invokeinterface reactor.core.Disposable$Composite.add:(Lreactor/core/Disposable;)Z
pop
110: aload 11
aload 12
invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
111: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.error:Ljava/lang/Throwable;
astore 4
112: aload 4
ifnull 117
113: aload 2
invokeinterface java.util.Queue.clear:()V
114: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
invokeinterface reactor.core.Disposable$Composite.dispose:()V
115: aload 0
aload 3
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
116: return
117: StackMap locals: reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
invokeinterface java.util.Map.values:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 14
goto 120
StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int org.reactivestreams.Publisher reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber top java.util.Iterator
StackMap stack:
118: aload 14
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast reactor.core.publisher.Sinks$Many
astore 13
start local 13 119: aload 13
aload 9
getstatic reactor.core.publisher.Sinks$EmitFailureHandler.FAIL_FAST:Lreactor/core/publisher/Sinks$EmitFailureHandler;
invokeinterface reactor.core.publisher.Sinks$Many.emitNext:(Ljava/lang/Object;Lreactor/core/publisher/Sinks$EmitFailureHandler;)V
end local 13 120: StackMap locals:
StackMap stack:
aload 14
invokeinterface java.util.Iterator.hasNext:()Z
ifne 118
end local 12 end local 11 end local 10 end local 9 121: goto 5
122: StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object
StackMap stack:
aload 6
getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
if_acmpne 129
123: aload 8
checkcast reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
astore 9
start local 9 124: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
aload 9
getfield reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber.index:I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast reactor.core.publisher.Sinks$Many
astore 10
start local 10 125: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
aload 9
invokeinterface reactor.core.Disposable$Composite.remove:(Lreactor/core/Disposable;)Z
pop
126: aload 10
ifnull 5
127: aload 10
getstatic reactor.core.publisher.Sinks$EmitFailureHandler.FAIL_FAST:Lreactor/core/publisher/Sinks$EmitFailureHandler;
invokeinterface reactor.core.publisher.Sinks$Many.emitComplete:(Lreactor/core/publisher/Sinks$EmitFailureHandler;)V
end local 10 end local 9 128: goto 5
129: StackMap locals:
StackMap stack:
aload 6
getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
if_acmpne 5
130: aload 8
checkcast reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
astore 9
start local 9 131: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
aload 9
getfield reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber.index:I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
pop
132: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
aload 9
invokeinterface reactor.core.Disposable$Composite.remove:(Lreactor/core/Disposable;)Z
pop
end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 133: goto 5
134: StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.util.Queue org.reactivestreams.Subscriber
StackMap stack:
getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
iload 1
ineg
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.addAndGet:(Ljava/lang/Object;I)I
istore 1
135: iload 1
ifne 5
136: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 137 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
3 137 1 missed I
4 137 2 q Ljava/util/Queue<Ljava/lang/Object;>;
5 137 3 a Lorg/reactivestreams/Subscriber<-TR;>;
9 133 4 ex Ljava/lang/Throwable;
17 133 5 d Z
18 133 6 mode Ljava/lang/Integer;
21 133 7 empty Z
24 25 8 up Lreactor/core/publisher/Sinks$Many<*>;
34 133 8 val Ljava/lang/Object;
36 89 9 left TTLeft;
37 89 10 up Lreactor/core/publisher/Sinks$Many<TTRight;>;
38 89 11 idx I
42 43 12 p Lorg/reactivestreams/Publisher<TTLeftEnd;>;
52 89 12 p Lorg/reactivestreams/Publisher<TTLeftEnd;>;
44 52 13 exc Ljava/lang/Throwable;
54 89 13 end Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
65 66 14 w TR;
74 89 14 w TR;
67 74 15 exc Ljava/lang/Throwable;
75 89 15 r J
87 88 17 right TTRight;
92 121 9 right TTRight;
93 121 10 idx I
97 98 11 p Lorg/reactivestreams/Publisher<TTRightEnd;>;
107 121 11 p Lorg/reactivestreams/Publisher<TTRightEnd;>;
99 107 12 exc Ljava/lang/Throwable;
109 121 12 end Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
119 120 13 up Lreactor/core/publisher/Sinks$Many<TTRight;>;
124 128 9 end Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
125 128 10 up Lreactor/core/publisher/Sinks$Many<TTRight;>;
131 133 9 end Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
Exception table:
from to target type
39 42 43 Class java.lang.Throwable
62 65 66 Class java.lang.Throwable
94 97 98 Class java.lang.Throwable
public void innerError(java.lang.Throwable);
descriptor: (Ljava/lang/Throwable;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
aload 0
aload 1
invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
ifeq 4
1: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ACTIVE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
pop
2: aload 0
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.drain:()V
3: goto 5
4: StackMap locals:
StackMap stack:
aload 1
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.actual:Lreactor/core/CoreSubscriber;
invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
invokestatic reactor.core.publisher.Operators.onErrorDropped:(Ljava/lang/Throwable;Lreactor/util/context/Context;)V
5: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 6 1 ex Ljava/lang/Throwable;
MethodParameters:
Name Flags
ex
public void innerComplete(reactor.core.publisher.FluxGroupJoin$LeftRightSubscriber);
descriptor: (Lreactor/core/publisher/FluxGroupJoin$LeftRightSubscriber;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
aload 1
invokeinterface reactor.core.Disposable$Composite.remove:(Lreactor/core/Disposable;)Z
pop
1: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ACTIVE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
pop
2: aload 0
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.drain:()V
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 4 1 sender Lreactor/core/publisher/FluxGroupJoin$LeftRightSubscriber;
MethodParameters:
Name Flags
sender
public void innerValue(boolean, java.lang.Object);
descriptor: (ZLjava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.queueBiOffer:Ljava/util/function/BiPredicate;
iload 1
ifeq 1
getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
goto 2
StackMap locals:
StackMap stack: java.util.function.BiPredicate
1: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int java.lang.Object
StackMap stack: java.util.function.BiPredicate java.lang.Integer
2: aload 2
invokeinterface java.util.function.BiPredicate.test:(Ljava/lang/Object;Ljava/lang/Object;)Z
pop
3: aload 0
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.drain:()V
4: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 5 1 isLeft Z
0 5 2 o Ljava/lang/Object;
MethodParameters:
Name Flags
isLeft
o
public void innerClose(boolean, reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber);
descriptor: (ZLreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.queueBiOffer:Ljava/util/function/BiPredicate;
iload 1
ifeq 1
getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
goto 2
StackMap locals:
StackMap stack: java.util.function.BiPredicate
1: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
StackMap locals: reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription int reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
StackMap stack: java.util.function.BiPredicate java.lang.Integer
2: aload 2
invokeinterface java.util.function.BiPredicate.test:(Ljava/lang/Object;Ljava/lang/Object;)Z
pop
3: aload 0
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.drain:()V
4: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 5 1 isLeft Z
0 5 2 index Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
MethodParameters:
Name Flags
isLeft
index
public void innerCloseError(java.lang.Throwable);
descriptor: (Ljava/lang/Throwable;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: getstatic reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
aload 0
aload 1
invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
ifeq 3
1: aload 0
invokevirtual reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.drain:()V
2: goto 4
3: StackMap locals:
StackMap stack:
aload 1
aload 0
getfield reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription.actual:Lreactor/core/CoreSubscriber;
invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
invokestatic reactor.core.publisher.Operators.onErrorDropped:(Ljava/lang/Throwable;Lreactor/util/context/Context;)V
4: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lreactor/core/publisher/FluxGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
0 5 1 ex Ljava/lang/Throwable;
MethodParameters:
Name Flags
ex
}
Signature: <TLeft:Ljava/lang/Object;TRight:Ljava/lang/Object;TLeftEnd:Ljava/lang/Object;TRightEnd:Ljava/lang/Object;R:Ljava/lang/Object;>Ljava/lang/Object;Lreactor/core/publisher/FluxGroupJoin$JoinSupport<TR;>;
SourceFile: "FluxGroupJoin.java"
NestHost: reactor.core.publisher.FluxGroupJoin
InnerClasses:
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
public abstract Composite = reactor.core.Disposable$Composite of reactor.core.Disposable
public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
final GroupJoinSubscription = reactor.core.publisher.FluxGroupJoin$GroupJoinSubscription of reactor.core.publisher.FluxGroupJoin
abstract JoinSupport = reactor.core.publisher.FluxGroupJoin$JoinSupport of reactor.core.publisher.FluxGroupJoin
final LeftRightEndSubscriber = reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber of reactor.core.publisher.FluxGroupJoin
final LeftRightSubscriber = reactor.core.publisher.FluxGroupJoin$LeftRightSubscriber of reactor.core.publisher.FluxGroupJoin
public abstract EmitFailureHandler = reactor.core.publisher.Sinks$EmitFailureHandler of reactor.core.publisher.Sinks
public abstract Many = reactor.core.publisher.Sinks$Many of reactor.core.publisher.Sinks
public abstract ManySpec = reactor.core.publisher.Sinks$ManySpec of reactor.core.publisher.Sinks
public abstract RootSpec = reactor.core.publisher.Sinks$RootSpec of reactor.core.publisher.Sinks
public abstract UnicastSpec = reactor.core.publisher.Sinks$UnicastSpec of reactor.core.publisher.Sinks