final class reactor.core.publisher.ParallelThen$ThenMain extends reactor.core.publisher.Operators$MonoSubscriber<java.lang.Object, java.lang.Void>
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: reactor.core.publisher.ParallelThen$ThenMain
super_class: reactor.core.publisher.Operators$MonoSubscriber
{
final reactor.core.publisher.ParallelThen$ThenInner[] subscribers;
descriptor: [Lreactor/core/publisher/ParallelThen$ThenInner;
flags: (0x0010) ACC_FINAL
volatile int remaining;
descriptor: I
flags: (0x0040) ACC_VOLATILE
static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<reactor.core.publisher.ParallelThen$ThenMain> REMAINING;
descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
flags: (0x0018) ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lreactor/core/publisher/ParallelThen$ThenMain;>;
volatile java.lang.Throwable error;
descriptor: Ljava/lang/Throwable;
flags: (0x0040) ACC_VOLATILE
static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.publisher.ParallelThen$ThenMain, 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/ParallelThen$ThenMain;Ljava/lang/Throwable;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=3, locals=0, args_size=0
0: ldc Lreactor/core/publisher/ParallelThen$ThenMain;
1: ldc "remaining"
2: invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
putstatic reactor.core.publisher.ParallelThen$ThenMain.REMAINING:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
3: ldc Lreactor/core/publisher/ParallelThen$ThenMain;
4: ldc Ljava/lang/Throwable;
5: ldc "error"
6: invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
putstatic reactor.core.publisher.ParallelThen$ThenMain.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
7: return
LocalVariableTable:
Start End Slot Name Signature
void <init>(reactor.core.CoreSubscriber<? super java.lang.Void>, );
descriptor: (Lreactor/core/CoreSubscriber;I)V
flags: (0x0000)
Code:
stack=5, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
invokespecial reactor.core.publisher.Operators$MonoSubscriber.<init>:(Lreactor/core/CoreSubscriber;)V
1: iload 2
anewarray reactor.core.publisher.ParallelThen$ThenInner
astore 3
start local 3 2: iconst_0
istore 4
start local 4 3: goto 6
4: StackMap locals: reactor.core.publisher.ParallelThen$ThenMain reactor.core.CoreSubscriber int reactor.core.publisher.ParallelThen$ThenInner[] int
StackMap stack:
aload 3
iload 4
new reactor.core.publisher.ParallelThen$ThenInner
dup
aload 0
invokespecial reactor.core.publisher.ParallelThen$ThenInner.<init>:(Lreactor/core/publisher/ParallelThen$ThenMain;)V
aastore
5: iinc 4 1
StackMap locals:
StackMap stack:
6: iload 4
iload 2
if_icmplt 4
end local 4 7: aload 0
aload 3
putfield reactor.core.publisher.ParallelThen$ThenMain.subscribers:[Lreactor/core/publisher/ParallelThen$ThenInner;
8: getstatic reactor.core.publisher.ParallelThen$ThenMain.REMAINING:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
iload 2
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
9: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lreactor/core/publisher/ParallelThen$ThenMain;
0 10 1 subscriber Lreactor/core/CoreSubscriber<-Ljava/lang/Void;>;
0 10 2 n I
2 10 3 a [Lreactor/core/publisher/ParallelThen$ThenInner;
3 7 4 i I
Signature: (Lreactor/core/CoreSubscriber<-Ljava/lang/Void;>;I)V
MethodParameters:
Name Flags
subscriber
n
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.ERROR:Lreactor/core/Scannable$Attr;
if_acmpne 1
aload 0
getfield reactor.core.publisher.ParallelThen$ThenMain.error:Ljava/lang/Throwable;
areturn
1: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.TERMINATED:Lreactor/core/Scannable$Attr;
if_acmpne 3
getstatic reactor.core.publisher.ParallelThen$ThenMain.REMAINING:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.get:(Ljava/lang/Object;)I
ifne 2
iconst_1
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
areturn
StackMap locals:
StackMap stack:
2: iconst_0
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
areturn
3: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
if_acmpne 4
getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
areturn
4: StackMap locals:
StackMap stack:
aload 0
aload 1
invokespecial reactor.core.publisher.Operators$MonoSubscriber.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lreactor/core/publisher/ParallelThen$ThenMain;
0 5 1 key Lreactor/core/Scannable$Attr;
RuntimeVisibleAnnotations:
reactor.util.annotation.Nullable()
MethodParameters:
Name Flags
key
public void cancel();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=5, args_size=1
start local 0 0: aload 0
getfield reactor.core.publisher.ParallelThen$ThenMain.subscribers:[Lreactor/core/publisher/ParallelThen$ThenInner;
dup
astore 4
arraylength
istore 3
iconst_0
istore 2
goto 4
StackMap locals: reactor.core.publisher.ParallelThen$ThenMain top int int reactor.core.publisher.ParallelThen$ThenInner[]
StackMap stack:
1: aload 4
iload 2
aaload
astore 1
start local 1 2: aload 1
invokevirtual reactor.core.publisher.ParallelThen$ThenInner.cancel:()V
end local 1 3: iinc 2 1
StackMap locals:
StackMap stack:
4: iload 2
iload 3
if_icmplt 1
5: aload 0
invokespecial reactor.core.publisher.Operators$MonoSubscriber.cancel:()V
6: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lreactor/core/publisher/ParallelThen$ThenMain;
2 3 1 inner Lreactor/core/publisher/ParallelThen$ThenInner;
void innerError(java.lang.Throwable);
descriptor: (Ljava/lang/Throwable;)V
flags: (0x0000)
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: getstatic reactor.core.publisher.ParallelThen$ThenMain.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
aload 0
aconst_null
aload 1
invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
ifeq 4
1: aload 0
invokevirtual reactor.core.publisher.ParallelThen$ThenMain.cancel:()V
2: aload 0
getfield reactor.core.publisher.ParallelThen$ThenMain.actual:Lreactor/core/CoreSubscriber;
aload 1
invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
3: goto 6
4: StackMap locals:
StackMap stack:
aload 0
getfield reactor.core.publisher.ParallelThen$ThenMain.error:Ljava/lang/Throwable;
aload 1
if_acmpeq 6
5: aload 1
aload 0
getfield reactor.core.publisher.ParallelThen$ThenMain.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
6: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lreactor/core/publisher/ParallelThen$ThenMain;
0 7 1 ex Ljava/lang/Throwable;
MethodParameters:
Name Flags
ex
void innerComplete();
descriptor: ()V
flags: (0x0000)
Code:
stack=2, locals=1, args_size=1
start local 0 0: getstatic reactor.core.publisher.ParallelThen$ThenMain.REMAINING:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
ifne 2
1: aload 0
getfield reactor.core.publisher.ParallelThen$ThenMain.actual:Lreactor/core/CoreSubscriber;
invokeinterface reactor.core.CoreSubscriber.onComplete:()V
2: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lreactor/core/publisher/ParallelThen$ThenMain;
}
Signature: Lreactor/core/publisher/Operators$MonoSubscriber<Ljava/lang/Object;Ljava/lang/Void;>;
SourceFile: "ParallelThen.java"
NestHost: reactor.core.publisher.ParallelThen
InnerClasses:
public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
public final RunStyle = reactor.core.Scannable$Attr$RunStyle of reactor.core.Scannable$Attr
public MonoSubscriber = reactor.core.publisher.Operators$MonoSubscriber of reactor.core.publisher.Operators
final ThenInner = reactor.core.publisher.ParallelThen$ThenInner of reactor.core.publisher.ParallelThen
final ThenMain = reactor.core.publisher.ParallelThen$ThenMain of reactor.core.publisher.ParallelThen