final class reactor.core.publisher.FluxWindowTimeout<T> extends reactor.core.publisher.InternalFluxOperator<T, reactor.core.publisher.Flux<T>>
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: reactor.core.publisher.FluxWindowTimeout
super_class: reactor.core.publisher.InternalFluxOperator
{
final int maxSize;
descriptor: I
flags: (0x0010) ACC_FINAL
final long timespan;
descriptor: J
flags: (0x0010) ACC_FINAL
final java.util.concurrent.TimeUnit unit;
descriptor: Ljava/util/concurrent/TimeUnit;
flags: (0x0010) ACC_FINAL
final reactor.core.scheduler.Scheduler timer;
descriptor: Lreactor/core/scheduler/Scheduler;
flags: (0x0010) ACC_FINAL
void <init>(reactor.core.publisher.Flux<T>, int, long, java.util.concurrent.TimeUnit, reactor.core.scheduler.Scheduler);
descriptor: (Lreactor/core/publisher/Flux;IJLjava/util/concurrent/TimeUnit;Lreactor/core/scheduler/Scheduler;)V
flags: (0x0000)
Code:
stack=4, locals=7, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 5 start local 6 0: aload 0
aload 1
invokespecial reactor.core.publisher.InternalFluxOperator.<init>:(Lreactor/core/publisher/Flux;)V
1: lload 3
lconst_0
lcmp
ifgt 3
2: new java.lang.IllegalArgumentException
dup
ldc "Timeout period must be strictly positive"
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: reactor.core.publisher.FluxWindowTimeout reactor.core.publisher.Flux int long java.util.concurrent.TimeUnit reactor.core.scheduler.Scheduler
StackMap stack:
iload 2
ifgt 5
4: new java.lang.IllegalArgumentException
dup
ldc "maxSize must be strictly positive"
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
5: StackMap locals:
StackMap stack:
aload 0
aload 6
ldc "Timer"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast reactor.core.scheduler.Scheduler
putfield reactor.core.publisher.FluxWindowTimeout.timer:Lreactor/core/scheduler/Scheduler;
6: aload 0
lload 3
putfield reactor.core.publisher.FluxWindowTimeout.timespan:J
7: aload 0
aload 5
ldc "unit"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.concurrent.TimeUnit
putfield reactor.core.publisher.FluxWindowTimeout.unit:Ljava/util/concurrent/TimeUnit;
8: aload 0
iload 2
putfield reactor.core.publisher.FluxWindowTimeout.maxSize:I
9: return
end local 6 end local 5 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/FluxWindowTimeout<TT;>;
0 10 1 source Lreactor/core/publisher/Flux<TT;>;
0 10 2 maxSize I
0 10 3 timespan J
0 10 5 unit Ljava/util/concurrent/TimeUnit;
0 10 6 timer Lreactor/core/scheduler/Scheduler;
Signature: (Lreactor/core/publisher/Flux<TT;>;IJLjava/util/concurrent/TimeUnit;Lreactor/core/scheduler/Scheduler;)V
MethodParameters:
Name Flags
source
maxSize
timespan
unit
timer
public reactor.core.CoreSubscriber<? super T> subscribeOrReturn(reactor.core.CoreSubscriber<? super reactor.core.publisher.Flux<T>>);
descriptor: (Lreactor/core/CoreSubscriber;)Lreactor/core/CoreSubscriber;
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=2, args_size=2
start local 0 start local 1 0: new reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber
dup
aload 1
aload 0
getfield reactor.core.publisher.FluxWindowTimeout.maxSize:I
1: aload 0
getfield reactor.core.publisher.FluxWindowTimeout.timespan:J
aload 0
getfield reactor.core.publisher.FluxWindowTimeout.unit:Ljava/util/concurrent/TimeUnit;
2: aload 0
getfield reactor.core.publisher.FluxWindowTimeout.timer:Lreactor/core/scheduler/Scheduler;
3: invokespecial reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.<init>:(Lreactor/core/CoreSubscriber;IJLjava/util/concurrent/TimeUnit;Lreactor/core/scheduler/Scheduler;)V
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lreactor/core/publisher/FluxWindowTimeout<TT;>;
0 4 1 actual Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/Flux<TT;>;>;
Signature: (Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/Flux<TT;>;>;)Lreactor/core/CoreSubscriber<-TT;>;
MethodParameters:
Name Flags
actual
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.RUN_ON:Lreactor/core/Scannable$Attr;
if_acmpne 1
aload 0
getfield reactor.core.publisher.FluxWindowTimeout.timer:Lreactor/core/scheduler/Scheduler;
areturn
1: StackMap locals:
StackMap stack:
aload 1
getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
if_acmpne 2
getstatic reactor.core.Scannable$Attr$RunStyle.ASYNC:Lreactor/core/Scannable$Attr$RunStyle;
areturn
2: StackMap locals:
StackMap stack:
aload 0
aload 1
invokespecial reactor.core.publisher.InternalFluxOperator.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lreactor/core/publisher/FluxWindowTimeout<TT;>;
0 3 1 key Lreactor/core/Scannable$Attr;
MethodParameters:
Name Flags
key
}
Signature: <T:Ljava/lang/Object;>Lreactor/core/publisher/InternalFluxOperator<TT;Lreactor/core/publisher/Flux<TT;>;>;
SourceFile: "FluxWindowTimeout.java"
NestMembers:
reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber$ConsumerIndexHolder
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 WindowTimeoutSubscriber = reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber of reactor.core.publisher.FluxWindowTimeout