final class reactor.core.publisher.FluxDelaySequence$DelaySubscriber<T> implements reactor.core.publisher.InnerOperator<T, T>
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: reactor.core.publisher.FluxDelaySequence$DelaySubscriber
super_class: java.lang.Object
{
final reactor.core.CoreSubscriber<? super T> actual;
descriptor: Lreactor/core/CoreSubscriber;
flags: (0x0010) ACC_FINAL
Signature: Lreactor/core/CoreSubscriber<-TT;>;
final long delay;
descriptor: J
flags: (0x0010) ACC_FINAL
final java.util.concurrent.TimeUnit timeUnit;
descriptor: Ljava/util/concurrent/TimeUnit;
flags: (0x0010) ACC_FINAL
final reactor.core.scheduler.Scheduler$Worker w;
descriptor: Lreactor/core/scheduler/Scheduler$Worker;
flags: (0x0010) ACC_FINAL
org.reactivestreams.Subscription s;
descriptor: Lorg/reactivestreams/Subscription;
flags: (0x0000)
volatile boolean done;
descriptor: Z
flags: (0x0040) ACC_VOLATILE
volatile long delayed;
descriptor: J
flags: (0x0040) ACC_VOLATILE
static final java.util.concurrent.atomic.AtomicLongFieldUpdater<reactor.core.publisher.FluxDelaySequence$DelaySubscriber> DELAYED;
descriptor: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
flags: (0x0018) ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater<Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: ldc Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber;
ldc "delayed"
invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
1: putstatic reactor.core.publisher.FluxDelaySequence$DelaySubscriber.DELAYED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
2: return
LocalVariableTable:
Start End Slot Name Signature
void <init>(reactor.core.CoreSubscriber<? super T>, java.time.Duration, reactor.core.scheduler.Scheduler$Worker);
descriptor: (Lreactor/core/CoreSubscriber;Ljava/time/Duration;Lreactor/core/scheduler/Scheduler$Worker;)V
flags: (0x0000)
Code:
stack=3, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 1
invokestatic reactor.core.publisher.Operators.serialize:(Lreactor/core/CoreSubscriber;)Lreactor/core/CoreSubscriber;
putfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.actual:Lreactor/core/CoreSubscriber;
2: aload 0
aload 3
putfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.w:Lreactor/core/scheduler/Scheduler$Worker;
3: aload 0
aload 2
invokevirtual java.time.Duration.toNanos:()J
putfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.delay:J
4: aload 0
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
putfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.timeUnit:Ljava/util/concurrent/TimeUnit;
5: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
0 6 1 actual Lreactor/core/CoreSubscriber<-TT;>;
0 6 2 delay Ljava/time/Duration;
0 6 3 w Lreactor/core/scheduler/Scheduler$Worker;
Signature: (Lreactor/core/CoreSubscriber<-TT;>;Ljava/time/Duration;Lreactor/core/scheduler/Scheduler$Worker;)V
MethodParameters:
Name Flags
actual
delay
w
public reactor.core.CoreSubscriber<? super T> actual();
descriptor: ()Lreactor/core/CoreSubscriber;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.actual:Lreactor/core/CoreSubscriber;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
Signature: ()Lreactor/core/CoreSubscriber<-TT;>;
public void onSubscribe(org.reactivestreams.Subscription);
descriptor: (Lorg/reactivestreams/Subscription;)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.FluxDelaySequence$DelaySubscriber.s:Lorg/reactivestreams/Subscription;
aload 1
invokestatic reactor.core.publisher.Operators.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
ifeq 3
1: aload 0
aload 1
putfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.s:Lorg/reactivestreams/Subscription;
2: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.actual:Lreactor/core/CoreSubscriber;
aload 0
invokeinterface reactor.core.CoreSubscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
3: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
0 4 1 s Lorg/reactivestreams/Subscription;
MethodParameters:
Name Flags
s
public void onNext();
descriptor: (Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.done:Z
ifne 1
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.delayed:J
lconst_0
lcmp
ifge 3
1: StackMap locals:
StackMap stack:
aload 1
aload 0
invokevirtual reactor.core.publisher.FluxDelaySequence$DelaySubscriber.currentContext:()Lreactor/util/context/Context;
invokestatic reactor.core.publisher.Operators.onNextDropped:(Ljava/lang/Object;Lreactor/util/context/Context;)V
2: return
3: StackMap locals:
StackMap stack:
getstatic reactor.core.publisher.FluxDelaySequence$DelaySubscriber.DELAYED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
aload 0
invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.incrementAndGet:(Ljava/lang/Object;)J
pop2
4: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.w:Lreactor/core/scheduler/Scheduler$Worker;
aload 0
aload 1
invokedynamic run(Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber;Ljava/lang/Object;)Ljava/lang/Runnable;
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:
()V
reactor/core/publisher/FluxDelaySequence$DelaySubscriber.lambda$0(Ljava/lang/Object;)V (7)
()V
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.delay:J
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.timeUnit:Ljava/util/concurrent/TimeUnit;
invokeinterface reactor.core.scheduler.Scheduler$Worker.schedule:(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lreactor/core/Disposable;
pop
5: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
0 6 1 t TT;
Signature: (TT;)V
MethodParameters:
Name Flags
t final
private void delayedNext();
descriptor: (Ljava/lang/Object;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: getstatic reactor.core.publisher.FluxDelaySequence$DelaySubscriber.DELAYED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
aload 0
invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
pop2
1: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.actual:Lreactor/core/CoreSubscriber;
aload 1
invokeinterface reactor.core.CoreSubscriber.onNext:(Ljava/lang/Object;)V
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
0 3 1 t TT;
Signature: (TT;)V
MethodParameters:
Name Flags
t
public void onError(java.lang.Throwable);
descriptor: (Ljava/lang/Throwable;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.done:Z
ifeq 3
1: aload 1
aload 0
invokevirtual reactor.core.publisher.FluxDelaySequence$DelaySubscriber.currentContext:()Lreactor/util/context/Context;
invokestatic reactor.core.publisher.Operators.onErrorDropped:(Ljava/lang/Throwable;Lreactor/util/context/Context;)V
2: return
3: StackMap locals:
StackMap stack:
aload 0
iconst_1
putfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.done:Z
4: getstatic reactor.core.publisher.FluxDelaySequence$DelaySubscriber.DELAYED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
aload 0
lconst_0
ldc -1
invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.compareAndSet:(Ljava/lang/Object;JJ)Z
ifeq 7
5: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.actual:Lreactor/core/CoreSubscriber;
aload 1
invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
6: goto 8
7: StackMap locals:
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.w:Lreactor/core/scheduler/Scheduler$Worker;
new reactor.core.publisher.FluxDelaySequence$DelaySubscriber$OnError
dup
aload 0
aload 1
invokespecial reactor.core.publisher.FluxDelaySequence$DelaySubscriber$OnError.<init>:(Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber;Ljava/lang/Throwable;)V
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.delay:J
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.timeUnit:Ljava/util/concurrent/TimeUnit;
invokeinterface reactor.core.scheduler.Scheduler$Worker.schedule:(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lreactor/core/Disposable;
pop
8: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
0 9 1 t Ljava/lang/Throwable;
MethodParameters:
Name Flags
t final
public void onComplete();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=1, args_size=1
start local 0 0: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.done:Z
ifeq 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
iconst_1
putfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.done:Z
3: getstatic reactor.core.publisher.FluxDelaySequence$DelaySubscriber.DELAYED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
aload 0
lconst_0
ldc -1
invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.compareAndSet:(Ljava/lang/Object;JJ)Z
ifeq 6
4: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.actual:Lreactor/core/CoreSubscriber;
invokeinterface reactor.core.CoreSubscriber.onComplete:()V
5: goto 7
6: StackMap locals:
StackMap stack:
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.w:Lreactor/core/scheduler/Scheduler$Worker;
new reactor.core.publisher.FluxDelaySequence$DelaySubscriber$OnComplete
dup
aload 0
invokespecial reactor.core.publisher.FluxDelaySequence$DelaySubscriber$OnComplete.<init>:(Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber;)V
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.delay:J
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.timeUnit:Ljava/util/concurrent/TimeUnit;
invokeinterface reactor.core.scheduler.Scheduler$Worker.schedule:(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lreactor/core/Disposable;
pop
7: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
public void request(long);
descriptor: (J)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.s:Lorg/reactivestreams/Subscription;
lload 1
invokeinterface org.reactivestreams.Subscription.request:(J)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
0 2 1 n J
MethodParameters:
Name Flags
n
public void cancel();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.s:Lorg/reactivestreams/Subscription;
invokeinterface org.reactivestreams.Subscription.cancel:()V
1: aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.w:Lreactor/core/scheduler/Scheduler$Worker;
invokeinterface reactor.core.scheduler.Scheduler$Worker.dispose:()V
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
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.PARENT:Lreactor/core/Scannable$Attr;
if_acmpne 1
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.s:Lorg/reactivestreams/Subscription;
areturn
1: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.RUN_ON:Lreactor/core/Scannable$Attr;
if_acmpne 2
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.w:Lreactor/core/scheduler/Scheduler$Worker;
areturn
2: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.TERMINATED:Lreactor/core/Scannable$Attr;
if_acmpne 3
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.done:Z
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
areturn
3: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.CANCELLED:Lreactor/core/Scannable$Attr;
if_acmpne 5
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.w:Lreactor/core/scheduler/Scheduler$Worker;
invokeinterface reactor.core.scheduler.Scheduler$Worker.isDisposed:()Z
ifeq 4
aload 0
getfield reactor.core.publisher.FluxDelaySequence$DelaySubscriber.done:Z
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.RUN_STYLE:Lreactor/core/Scannable$Attr;
if_acmpne 6
getstatic reactor.core.Scannable$Attr$RunStyle.ASYNC:Lreactor/core/Scannable$Attr$RunStyle;
areturn
6: StackMap locals:
StackMap stack:
aload 0
aload 1
invokespecial reactor.core.publisher.InnerOperator.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/FluxDelaySequence$DelaySubscriber<TT;>;
0 7 1 key Lreactor/core/Scannable$Attr;
MethodParameters:
Name Flags
key
private void lambda$0(java.lang.Object);
descriptor: (Ljava/lang/Object;)V
flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
Code:
stack=2, locals=2, args_size=2
start local 0 0: aload 0
aload 1
invokevirtual reactor.core.publisher.FluxDelaySequence$DelaySubscriber.delayedNext:(Ljava/lang/Object;)V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lreactor/core/publisher/FluxDelaySequence$DelaySubscriber<TT;>;
}
Signature: <T:Ljava/lang/Object;>Ljava/lang/Object;Lreactor/core/publisher/InnerOperator<TT;TT;>;
SourceFile: "FluxDelaySequence.java"
NestHost: reactor.core.publisher.FluxDelaySequence
InnerClasses:
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
public final RunStyle = reactor.core.Scannable$Attr$RunStyle of reactor.core.Scannable$Attr
final DelaySubscriber = reactor.core.publisher.FluxDelaySequence$DelaySubscriber of reactor.core.publisher.FluxDelaySequence
final OnComplete = reactor.core.publisher.FluxDelaySequence$DelaySubscriber$OnComplete of reactor.core.publisher.FluxDelaySequence$DelaySubscriber
final OnError = reactor.core.publisher.FluxDelaySequence$DelaySubscriber$OnError of reactor.core.publisher.FluxDelaySequence$DelaySubscriber
public abstract Worker = reactor.core.scheduler.Scheduler$Worker of reactor.core.scheduler.Scheduler