final class reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber<T> implements reactor.core.publisher.InnerOperator<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$WindowTimeoutSubscriber
  super_class: java.lang.Object
{
  final reactor.core.CoreSubscriber<? super reactor.core.publisher.Flux<T>> actual;
    descriptor: Lreactor/core/CoreSubscriber;
    flags: (0x0010) ACC_FINAL
    Signature: Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/Flux<TT;>;>;

  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 scheduler;
    descriptor: Lreactor/core/scheduler/Scheduler;
    flags: (0x0010) ACC_FINAL

  final int maxSize;
    descriptor: I
    flags: (0x0010) ACC_FINAL

  final reactor.core.scheduler.Scheduler$Worker worker;
    descriptor: Lreactor/core/scheduler/Scheduler$Worker;
    flags: (0x0010) ACC_FINAL

  final java.util.Queue<java.lang.Object> queue;
    descriptor: Ljava/util/Queue;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Queue<Ljava/lang/Object;>;

  java.lang.Throwable error;
    descriptor: Ljava/lang/Throwable;
    flags: (0x0000) 

  volatile boolean done;
    descriptor: Z
    flags: (0x0040) ACC_VOLATILE

  volatile boolean cancelled;
    descriptor: Z
    flags: (0x0040) ACC_VOLATILE

  volatile long requested;
    descriptor: J
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicLongFieldUpdater<reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber> REQUESTED;
    descriptor: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater<Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber;>;

  volatile int wip;
    descriptor: I
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber> WIP;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber;>;

  int count;
    descriptor: I
    flags: (0x0000) 

  long producerIndex;
    descriptor: J
    flags: (0x0000) 

  org.reactivestreams.Subscription s;
    descriptor: Lorg/reactivestreams/Subscription;
    flags: (0x0000) 

  reactor.core.publisher.Sinks$Many<T> window;
    descriptor: Lreactor/core/publisher/Sinks$Many;
    flags: (0x0000) 
    Signature: Lreactor/core/publisher/Sinks$Many<TT;>;

  volatile boolean terminated;
    descriptor: Z
    flags: (0x0040) ACC_VOLATILE

  volatile reactor.core.Disposable timer;
    descriptor: Lreactor/core/Disposable;
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber, reactor.core.Disposable> TIMER;
    descriptor: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber;Lreactor/core/Disposable;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 94
            ldc Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber;
         1: .line 95
            ldc "requested"
         2: .line 94
            invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         3: .line 93
            putstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         4: .line 100
            ldc Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber;
         5: .line 101
            ldc "wip"
         6: .line 100
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         7: .line 99
            putstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         8: .line 115
            ldc Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber;
            ldc Lreactor/core/Disposable;
            ldc "timer"
            invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         9: .line 114
            putstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.TIMER:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
        10: .line 115
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(reactor.core.CoreSubscriber<? super reactor.core.publisher.Flux<T>>, int, long, java.util.concurrent.TimeUnit, reactor.core.scheduler.Scheduler);
    descriptor: (Lreactor/core/CoreSubscriber;IJLjava/util/concurrent/TimeUnit;Lreactor/core/scheduler/Scheduler;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=7, args_size=6
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
        start local 1 // reactor.core.CoreSubscriber actual
        start local 2 // int maxSize
        start local 3 // long timespan
        start local 5 // java.util.concurrent.TimeUnit unit
        start local 6 // reactor.core.scheduler.Scheduler scheduler
         0: .line 117
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 122
            aload 0 /* this */
            aload 1 /* actual */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
         2: .line 123
            aload 0 /* this */
            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.FluxWindowTimeout$WindowTimeoutSubscriber.queue:Ljava/util/Queue;
         3: .line 124
            aload 0 /* this */
            lload 3 /* timespan */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timespan:J
         4: .line 125
            aload 0 /* this */
            aload 5 /* unit */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.unit:Ljava/util/concurrent/TimeUnit;
         5: .line 126
            aload 0 /* this */
            aload 6 /* scheduler */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.scheduler:Lreactor/core/scheduler/Scheduler;
         6: .line 127
            aload 0 /* this */
            iload 2 /* maxSize */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.maxSize:I
         7: .line 128
            aload 0 /* this */
            aload 6 /* scheduler */
            invokeinterface reactor.core.scheduler.Scheduler.createWorker:()Lreactor/core/scheduler/Scheduler$Worker;
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
         8: .line 129
            return
        end local 6 // reactor.core.scheduler.Scheduler scheduler
        end local 5 // java.util.concurrent.TimeUnit unit
        end local 3 // long timespan
        end local 2 // int maxSize
        end local 1 // reactor.core.CoreSubscriber actual
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0       this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            0    9     1     actual  Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/Flux<TT;>;>;
            0    9     2    maxSize  I
            0    9     3   timespan  J
            0    9     5       unit  Ljava/util/concurrent/TimeUnit;
            0    9     6  scheduler  Lreactor/core/scheduler/Scheduler;
    Signature: (Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/Flux<TT;>;>;IJLjava/util/concurrent/TimeUnit;Lreactor/core/scheduler/Scheduler;)V
    MethodParameters:
           Name  Flags
      actual     
      maxSize    
      timespan   
      unit       
      scheduler  

  public reactor.core.CoreSubscriber<? super reactor.core.publisher.Flux<T>> actual();
    descriptor: ()Lreactor/core/CoreSubscriber;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
         0: .line 133
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            areturn
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
    Signature: ()Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/Flux<TT;>;>;

  public java.util.stream.Stream<? extends reactor.core.Scannable> inners();
    descriptor: ()Ljava/util/stream/Stream;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
         0: .line 138
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
            astore 1 /* w */
        start local 1 // reactor.core.publisher.Sinks$Many w
         1: .line 139
            aload 1 /* w */
            ifnonnull 2
            invokestatic java.util.stream.Stream.empty:()Ljava/util/stream/Stream;
            goto 3
      StackMap locals: reactor.core.publisher.Sinks$Many
      StackMap stack:
         2: aload 1 /* w */
            invokestatic reactor.core.Scannable.from:(Ljava/lang/Object;)Lreactor/core/Scannable;
            invokestatic java.util.stream.Stream.of:(Ljava/lang/Object;)Ljava/util/stream/Stream;
      StackMap locals:
      StackMap stack: java.util.stream.Stream
         3: areturn
        end local 1 // reactor.core.publisher.Sinks$Many w
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            1    4     1     w  Lreactor/core/publisher/Sinks$Many<TT;>;
    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 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
        start local 1 // reactor.core.Scannable$Attr key
         0: .line 144
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.PARENT:Lreactor/core/Scannable$Attr;
            if_acmpne 1
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.s:Lorg/reactivestreams/Subscription;
            areturn
         1: .line 145
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.CANCELLED:Lreactor/core/Scannable$Attr;
            if_acmpne 2
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.cancelled:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         2: .line 146
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.TERMINATED:Lreactor/core/Scannable$Attr;
            if_acmpne 3
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.done:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         3: .line 147
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.REQUESTED_FROM_DOWNSTREAM:Lreactor/core/Scannable$Attr;
            if_acmpne 4
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.requested:J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
         4: .line 148
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.CAPACITY:Lreactor/core/Scannable$Attr;
            if_acmpne 5
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.maxSize:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
         5: .line 149
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.BUFFERED:Lreactor/core/Scannable$Attr;
            if_acmpne 6
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.size:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
         6: .line 150
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_ON:Lreactor/core/Scannable$Attr;
            if_acmpne 7
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            areturn
         7: .line 151
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
            if_acmpne 8
            getstatic reactor.core.Scannable$Attr$RunStyle.ASYNC:Lreactor/core/Scannable$Attr$RunStyle;
            areturn
         8: .line 152
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* key */
            invokespecial reactor.core.publisher.InnerOperator.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
            areturn
        end local 1 // reactor.core.Scannable$Attr key
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            0    9     1   key  Lreactor/core/Scannable$Attr;
    MethodParameters:
      Name  Flags
      key   

  public void onSubscribe(org.reactivestreams.Subscription);
    descriptor: (Lorg/reactivestreams/Subscription;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 157
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.s:Lorg/reactivestreams/Subscription;
            aload 1 /* s */
            invokestatic reactor.core.publisher.Operators.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
            ifeq 20
         1: .line 158
            aload 0 /* this */
            aload 1 /* s */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.s:Lorg/reactivestreams/Subscription;
         2: .line 160
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            astore 2 /* a */
        start local 2 // org.reactivestreams.Subscriber a
         3: .line 162
            aload 2 /* a */
            aload 0 /* this */
            invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         4: .line 164
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.cancelled:Z
            ifeq 6
         5: .line 165
            return
         6: .line 168
      StackMap locals: org.reactivestreams.Subscriber
      StackMap stack:
            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;
            invokeinterface reactor.core.publisher.Sinks$UnicastSpec.onBackpressureBuffer:()Lreactor/core/publisher/Sinks$Many;
            astore 3 /* w */
        start local 3 // reactor.core.publisher.Sinks$Many w
         7: .line 169
            aload 0 /* this */
            aload 3 /* w */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
         8: .line 171
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.requested:J
            lstore 4 /* r */
        start local 4 // long r
         9: .line 172
            lload 4 /* r */
            lconst_0
            lcmp
            ifeq 14
        10: .line 173
            aload 2 /* a */
            aload 3 /* w */
            invokeinterface reactor.core.publisher.Sinks$Many.asFlux:()Lreactor/core/publisher/Flux;
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        11: .line 174
            lload 4 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 18
        12: .line 175
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
            pop2
        13: .line 177
            goto 18
        14: .line 179
      StackMap locals: reactor.core.publisher.Sinks$Many long
      StackMap stack:
            aload 2 /* a */
            aload 1 /* s */
        15: .line 180
            invokestatic reactor.core.Exceptions.failWithOverflow:()Ljava/lang/IllegalStateException;
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
        16: .line 179
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Lreactor/util/context/Context;)Ljava/lang/Throwable;
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        17: .line 181
            return
        18: .line 184
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.TIMER:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.newPeriod:()Lreactor/core/Disposable;
            invokestatic reactor.core.publisher.OperatorDisposables.replace:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Lreactor/core/Disposable;)Z
            ifeq 20
        19: .line 185
            aload 1 /* s */
            ldc 9223372036854775807
            invokeinterface org.reactivestreams.Subscription.request:(J)V
        end local 4 // long r
        end local 3 // reactor.core.publisher.Sinks$Many w
        end local 2 // org.reactivestreams.Subscriber a
        20: .line 188
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   21     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            0   21     1     s  Lorg/reactivestreams/Subscription;
            3   20     2     a  Lorg/reactivestreams/Subscriber<-Lreactor/core/publisher/Flux<TT;>;>;
            7   20     3     w  Lreactor/core/publisher/Sinks$Many<TT;>;
            9   20     4     r  J
    MethodParameters:
      Name  Flags
      s     

  reactor.core.Disposable newPeriod();
    descriptor: ()Lreactor/core/Disposable;
    flags: (0x0000) 
    Code:
      stack=7, locals=2, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
         0: .line 192
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            new reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber$ConsumerIndexHolder
            dup
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.producerIndex:J
         1: .line 193
            aload 0 /* this */
            invokespecial reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber$ConsumerIndexHolder.<init>:(JLreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber;)V
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timespan:J
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timespan:J
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.unit:Ljava/util/concurrent/TimeUnit;
         2: .line 192
            invokeinterface reactor.core.scheduler.Scheduler$Worker.schedulePeriodically:(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Lreactor/core/Disposable;
         3: areturn
         4: .line 195
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* e */
        start local 1 // java.lang.Exception e
         5: .line 196
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 1 /* e */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.s:Lorg/reactivestreams/Subscription;
            aconst_null
            aconst_null
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
            invokestatic reactor.core.publisher.Operators.onRejectedExecution:(Ljava/lang/Throwable;Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/RuntimeException;
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
         6: .line 197
            invokestatic reactor.core.Disposables.disposed:()Lreactor/core/Disposable;
            areturn
        end local 1 // java.lang.Exception e
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            5    7     1     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0     3       4  Class java.lang.Exception

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=8, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
        start local 1 // java.lang.Object t
         0: .line 203
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.terminated:Z
            ifeq 2
         1: .line 204
            return
         2: .line 207
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.get:(Ljava/lang/Object;)I
            ifne 34
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.compareAndSet:(Ljava/lang/Object;II)Z
            ifeq 34
         3: .line 208
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
            astore 2 /* w */
        start local 2 // reactor.core.publisher.Sinks$Many w
         4: .line 209
            aload 2 /* w */
            aload 1 /* t */
            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
         5: .line 211
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.count:I
            iconst_1
            iadd
            istore 3 /* c */
        start local 3 // int c
         6: .line 213
            iload 3 /* c */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.maxSize:I
            if_icmplt 31
         7: .line 214
            aload 0 /* this */
            dup
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.producerIndex:J
            lconst_1
            ladd
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.producerIndex:J
         8: .line 215
            aload 0 /* this */
            iconst_0
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.count:I
         9: .line 217
            aload 2 /* w */
            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
        10: .line 219
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.requested:J
            lstore 4 /* r */
        start local 4 // long r
        11: .line 221
            lload 4 /* r */
            lconst_0
            lcmp
            ifeq 23
        12: .line 222
            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;
            invokeinterface reactor.core.publisher.Sinks$UnicastSpec.onBackpressureBuffer:()Lreactor/core/publisher/Sinks$Many;
            astore 2 /* w */
        13: .line 223
            aload 0 /* this */
            aload 2 /* w */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
        14: .line 224
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 2 /* w */
            invokeinterface reactor.core.publisher.Sinks$Many.asFlux:()Lreactor/core/publisher/Flux;
            invokeinterface reactor.core.CoreSubscriber.onNext:(Ljava/lang/Object;)V
        15: .line 225
            lload 4 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 17
        16: .line 226
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
            pop2
        17: .line 229
      StackMap locals: reactor.core.publisher.Sinks$Many int long
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            astore 6 /* tm */
        start local 6 // reactor.core.Disposable tm
        18: .line 230
            aload 6 /* tm */
            invokeinterface reactor.core.Disposable.dispose:()V
        19: .line 232
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.newPeriod:()Lreactor/core/Disposable;
            astore 7 /* task */
        start local 7 // reactor.core.Disposable task
        20: .line 234
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.TIMER:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 6 /* tm */
            aload 7 /* task */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
            ifne 32
        21: .line 235
            aload 7 /* task */
            invokeinterface reactor.core.Disposable.dispose:()V
        end local 7 // reactor.core.Disposable task
        end local 6 // reactor.core.Disposable tm
        22: .line 237
            goto 32
        23: .line 239
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
        24: .line 240
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.s:Lorg/reactivestreams/Subscription;
        25: .line 241
            invokestatic reactor.core.Exceptions.failWithOverflow:()Ljava/lang/IllegalStateException;
            aload 1 /* t */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
        26: .line 242
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
        27: .line 240
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
        28: .line 243
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            invokeinterface reactor.core.Disposable.dispose:()V
        29: .line 244
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            invokeinterface reactor.core.scheduler.Scheduler$Worker.dispose:()V
        30: .line 245
            return
        end local 4 // long r
        31: .line 249
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 3 /* c */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.count:I
        32: .line 252
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            ifne 37
        33: .line 253
            return
        end local 3 // int c
        end local 2 // reactor.core.publisher.Sinks$Many w
        34: .line 257
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.queue:Ljava/util/Queue;
            aload 1 /* t */
            invokeinterface java.util.Queue.offer:(Ljava/lang/Object;)Z
            pop
        35: .line 258
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.enter:()Z
            ifne 37
        36: .line 259
            return
        37: .line 262
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.drainLoop:()V
        38: .line 263
            return
        end local 1 // java.lang.Object t
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   39     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            0   39     1     t  TT;
            4   34     2     w  Lreactor/core/publisher/Sinks$Many<TT;>;
            6   34     3     c  I
           11   31     4     r  J
           18   22     6    tm  Lreactor/core/Disposable;
           20   22     7  task  Lreactor/core/Disposable;
    Signature: (TT;)V
    MethodParameters:
      Name  Flags
      t     

  public void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 267
            aload 0 /* this */
            aload 1 /* t */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.error:Ljava/lang/Throwable;
         1: .line 268
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.done:Z
         2: .line 269
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.enter:()Z
            ifeq 4
         3: .line 270
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.drainLoop:()V
         4: .line 273
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 1 /* t */
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
         5: .line 274
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            invokeinterface reactor.core.Disposable.dispose:()V
         6: .line 275
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            invokeinterface reactor.core.scheduler.Scheduler$Worker.dispose:()V
         7: .line 276
            return
        end local 1 // java.lang.Throwable t
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            0    8     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
         0: .line 280
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.done:Z
         1: .line 281
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.enter:()Z
            ifeq 3
         2: .line 282
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.drainLoop:()V
         3: .line 285
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.onComplete:()V
         4: .line 286
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            invokeinterface reactor.core.Disposable.dispose:()V
         5: .line 287
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            invokeinterface reactor.core.scheduler.Scheduler$Worker.dispose:()V
         6: .line 288
            return
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;

  public void request(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
        start local 1 // long n
         0: .line 292
            lload 1 /* n */
            invokestatic reactor.core.publisher.Operators.validate:(J)Z
            ifeq 2
         1: .line 293
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lload 1 /* n */
            invokestatic reactor.core.publisher.Operators.addCap:(Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;Ljava/lang/Object;J)J
            pop2
         2: .line 295
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long n
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            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 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
         0: .line 299
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.cancelled:Z
         1: .line 300
            return
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;

  void drainLoop();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=14, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
         0: .line 304
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.queue:Ljava/util/Queue;
            astore 1 /* q */
        start local 1 // java.util.Queue q
         1: .line 305
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            astore 2 /* a */
        start local 2 // org.reactivestreams.Subscriber a
         2: .line 306
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
            astore 3 /* w */
        start local 3 // reactor.core.publisher.Sinks$Many w
         3: .line 308
            iconst_1
            istore 4 /* missed */
        start local 4 // int missed
         4: .line 312
      StackMap locals: reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber java.util.Queue org.reactivestreams.Subscriber reactor.core.publisher.Sinks$Many int
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.terminated:Z
            ifeq 10
         5: .line 313
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.s:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         6: .line 314
            aload 1 /* q */
            invokeinterface java.util.Queue.clear:()V
         7: .line 315
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            invokeinterface reactor.core.Disposable.dispose:()V
         8: .line 316
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            invokeinterface reactor.core.scheduler.Scheduler$Worker.dispose:()V
         9: .line 317
            return
        10: .line 320
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.done:Z
            istore 5 /* d */
        start local 5 // boolean d
        11: .line 322
            aload 1 /* q */
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            astore 6 /* o */
        start local 6 // java.lang.Object o
        12: .line 324
            aload 6 /* o */
            ifnonnull 13
            iconst_1
            goto 14
      StackMap locals: int java.lang.Object
      StackMap stack:
        13: iconst_0
      StackMap locals:
      StackMap stack: int
        14: istore 7 /* empty */
        start local 7 // boolean empty
        15: .line 325
            aload 6 /* o */
            instanceof reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber$ConsumerIndexHolder
            istore 8 /* isHolder */
        start local 8 // boolean isHolder
        16: .line 327
            iload 5 /* d */
            ifeq 27
            iload 7 /* empty */
            ifne 17
            iload 8 /* isHolder */
            ifeq 27
        17: .line 328
      StackMap locals: int int
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
        18: .line 329
            aload 1 /* q */
            invokeinterface java.util.Queue.clear:()V
        19: .line 330
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.error:Ljava/lang/Throwable;
            astore 9 /* err */
        start local 9 // java.lang.Throwable err
        20: .line 331
            aload 9 /* err */
            ifnull 23
        21: .line 332
            aload 3 /* w */
            aload 9 /* err */
            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
        22: .line 333
            goto 24
        23: .line 335
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 3 /* w */
            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
        24: .line 337
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            invokeinterface reactor.core.Disposable.dispose:()V
        25: .line 338
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            invokeinterface reactor.core.scheduler.Scheduler$Worker.dispose:()V
        26: .line 339
            return
        end local 9 // java.lang.Throwable err
        27: .line 342
      StackMap locals:
      StackMap stack:
            iload 7 /* empty */
            ifeq 29
        28: .line 343
            goto 77
        29: .line 346
      StackMap locals:
      StackMap stack:
            iload 8 /* isHolder */
            ifeq 48
        30: .line 347
            aload 3 /* w */
            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
        31: .line 348
            aload 0 /* this */
            iconst_0
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.count:I
        32: .line 349
            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;
            invokeinterface reactor.core.publisher.Sinks$UnicastSpec.onBackpressureBuffer:()Lreactor/core/publisher/Sinks$Many;
            astore 3 /* w */
        33: .line 350
            aload 0 /* this */
            aload 3 /* w */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
        34: .line 352
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.requested:J
            lstore 9 /* r */
        start local 9 // long r
        35: .line 353
            lload 9 /* r */
            lconst_0
            lcmp
            ifeq 40
        36: .line 354
            aload 2 /* a */
            aload 3 /* w */
            invokeinterface reactor.core.publisher.Sinks$Many.asFlux:()Lreactor/core/publisher/Flux;
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        37: .line 355
            lload 9 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 4
        38: .line 356
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
            pop2
        39: .line 358
            goto 4
        40: .line 360
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
        41: .line 361
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.clear:()V
        42: .line 362
            aload 2 /* a */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.s:Lorg/reactivestreams/Subscription;
        43: .line 363
            invokestatic reactor.core.Exceptions.failWithOverflow:()Ljava/lang/IllegalStateException;
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
        44: .line 362
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Lreactor/util/context/Context;)Ljava/lang/Throwable;
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        45: .line 364
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            invokeinterface reactor.core.Disposable.dispose:()V
        46: .line 365
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            invokeinterface reactor.core.scheduler.Scheduler$Worker.dispose:()V
        47: .line 366
            return
        end local 9 // long r
        48: .line 371
      StackMap locals:
      StackMap stack:
            aload 3 /* w */
            aload 6 /* o */
            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
        49: .line 372
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.count:I
            iconst_1
            iadd
            istore 9 /* c */
        start local 9 // int c
        50: .line 374
            iload 9 /* c */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.maxSize:I
            if_icmplt 75
        51: .line 375
            aload 0 /* this */
            dup
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.producerIndex:J
            lconst_1
            ladd
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.producerIndex:J
        52: .line 376
            aload 0 /* this */
            iconst_0
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.count:I
        53: .line 378
            aload 3 /* w */
            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
        54: .line 380
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.requested:J
            lstore 10 /* r */
        start local 10 // long r
        55: .line 382
            lload 10 /* r */
            lconst_0
            lcmp
            ifeq 67
        56: .line 383
            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;
            invokeinterface reactor.core.publisher.Sinks$UnicastSpec.onBackpressureBuffer:()Lreactor/core/publisher/Sinks$Many;
            astore 3 /* w */
        57: .line 384
            aload 0 /* this */
            aload 3 /* w */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
        58: .line 385
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 3 /* w */
            invokeinterface reactor.core.publisher.Sinks$Many.asFlux:()Lreactor/core/publisher/Flux;
            invokeinterface reactor.core.CoreSubscriber.onNext:(Ljava/lang/Object;)V
        59: .line 386
            lload 10 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 61
        60: .line 387
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
            pop2
        61: .line 390
      StackMap locals: int long
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            astore 12 /* tm */
        start local 12 // reactor.core.Disposable tm
        62: .line 391
            aload 12 /* tm */
            invokeinterface reactor.core.Disposable.dispose:()V
        63: .line 393
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.newPeriod:()Lreactor/core/Disposable;
            astore 13 /* task */
        start local 13 // reactor.core.Disposable task
        64: .line 395
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.TIMER:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 12 /* tm */
            aload 13 /* task */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
            ifne 4
        65: .line 396
            aload 13 /* task */
            invokeinterface reactor.core.Disposable.dispose:()V
        end local 13 // reactor.core.Disposable task
        end local 12 // reactor.core.Disposable tm
        66: .line 398
            goto 4
        67: .line 400
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.window:Lreactor/core/publisher/Sinks$Many;
        68: .line 401
            aload 2 /* a */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.s:Lorg/reactivestreams/Subscription;
        69: .line 402
            invokestatic reactor.core.Exceptions.failWithOverflow:()Ljava/lang/IllegalStateException;
            aload 6 /* o */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.actual:Lreactor/core/CoreSubscriber;
        70: .line 403
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
        71: .line 401
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        72: .line 404
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.timer:Lreactor/core/Disposable;
            invokeinterface reactor.core.Disposable.dispose:()V
        73: .line 405
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.worker:Lreactor/core/scheduler/Scheduler$Worker;
            invokeinterface reactor.core.scheduler.Scheduler$Worker.dispose:()V
        74: .line 406
            return
        end local 10 // long r
        75: .line 410
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 9 /* c */
            putfield reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.count:I
        end local 9 // int c
        end local 8 // boolean isHolder
        end local 7 // boolean empty
        end local 6 // java.lang.Object o
        end local 5 // boolean d
        76: .line 311
            goto 4
        77: .line 414
      StackMap locals: reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber java.util.Queue org.reactivestreams.Subscriber reactor.core.publisher.Sinks$Many int
      StackMap stack:
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iload 4 /* missed */
            ineg
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.addAndGet:(Ljava/lang/Object;I)I
            istore 4 /* missed */
        78: .line 415
            iload 4 /* missed */
            ifne 4
        79: .line 419
            return
        end local 4 // int missed
        end local 3 // reactor.core.publisher.Sinks$Many w
        end local 2 // org.reactivestreams.Subscriber a
        end local 1 // java.util.Queue q
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   80     0      this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
            1   80     1         q  Ljava/util/Queue<Ljava/lang/Object;>;
            2   80     2         a  Lorg/reactivestreams/Subscriber<-Lreactor/core/publisher/Flux<TT;>;>;
            3   80     3         w  Lreactor/core/publisher/Sinks$Many<TT;>;
            4   80     4    missed  I
           11   76     5         d  Z
           12   76     6         o  Ljava/lang/Object;
           15   76     7     empty  Z
           16   76     8  isHolder  Z
           20   27     9       err  Ljava/lang/Throwable;
           35   48     9         r  J
           50   76     9         c  I
           55   75    10         r  J
           62   66    12        tm  Lreactor/core/Disposable;
           64   66    13      task  Lreactor/core/Disposable;

  boolean enter();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
         0: .line 422
            getstatic reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxWindowTimeout$WindowTimeoutSubscriber<TT;>;
}
Signature: <T:Ljava/lang/Object;>Ljava/lang/Object;Lreactor/core/publisher/InnerOperator<TT;Lreactor/core/publisher/Flux<TT;>;>;
SourceFile: "FluxWindowTimeout.java"
NestHost: reactor.core.publisher.FluxWindowTimeout
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
  final ConsumerIndexHolder = reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber$ConsumerIndexHolder of reactor.core.publisher.FluxWindowTimeout$WindowTimeoutSubscriber
  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
  public abstract Worker = reactor.core.scheduler.Scheduler$Worker of reactor.core.scheduler.Scheduler