final class reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber<T, U, V> extends reactor.core.publisher.QueueDrainSubscriber<T, java.lang.Object, reactor.core.publisher.Flux<T>>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber
  super_class: reactor.core.publisher.QueueDrainSubscriber
{
  final org.reactivestreams.Publisher<U> open;
    descriptor: Lorg/reactivestreams/Publisher;
    flags: (0x0010) ACC_FINAL
    Signature: Lorg/reactivestreams/Publisher<TU;>;

  final java.util.function.Function<? super U, ? extends org.reactivestreams.Publisher<V>> close;
    descriptor: Ljava/util/function/Function;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/Function<-TU;+Lorg/reactivestreams/Publisher<TV;>;>;

  final java.util.function.Supplier<? extends java.util.Queue<T>> processorQueueSupplier;
    descriptor: Ljava/util/function/Supplier;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;

  final reactor.core.Disposable$Composite resources;
    descriptor: Lreactor/core/Disposable$Composite;
    flags: (0x0010) ACC_FINAL

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

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

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

  final java.util.List<reactor.core.publisher.Sinks$Many<T>> windows;
    descriptor: Ljava/util/List;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/List<Lreactor/core/publisher/Sinks$Many<TT;>;>;

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

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 113
            ldc Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber;
            ldc Lreactor/core/Disposable;
            ldc "boundary"
            invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         1: .line 112
            putstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.BOUNDARY:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         2: .line 119
            ldc Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber;
            ldc "openWindowCount"
            invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         3: .line 118
            putstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.OPEN_WINDOW_COUNT:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         4: .line 119
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(reactor.core.CoreSubscriber<? super reactor.core.publisher.Flux<T>>, org.reactivestreams.Publisher<U>, java.util.function.Function<? super U, ? extends org.reactivestreams.Publisher<V>>, java.util.function.Supplier<? extends java.util.Queue<T>>);
    descriptor: (Lreactor/core/CoreSubscriber;Lorg/reactivestreams/Publisher;Ljava/util/function/Function;Ljava/util/function/Supplier;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // reactor.core.CoreSubscriber actual
        start local 2 // org.reactivestreams.Publisher open
        start local 3 // java.util.function.Function close
        start local 4 // java.util.function.Supplier processorQueueSupplier
         0: .line 124
            aload 0 /* this */
            aload 1 /* actual */
            invokestatic reactor.util.concurrent.Queues.unboundedMultiproducer:()Ljava/util/function/Supplier;
            invokeinterface java.util.function.Supplier.get:()Ljava/lang/Object;
            checkcast java.util.Queue
            invokespecial reactor.core.publisher.QueueDrainSubscriber.<init>:(Lreactor/core/CoreSubscriber;Ljava/util/Queue;)V
         1: .line 125
            aload 0 /* this */
            aload 2 /* open */
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.open:Lorg/reactivestreams/Publisher;
         2: .line 126
            aload 0 /* this */
            aload 3 /* close */
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.close:Ljava/util/function/Function;
         3: .line 127
            aload 0 /* this */
            aload 4 /* processorQueueSupplier */
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.processorQueueSupplier:Ljava/util/function/Supplier;
         4: .line 128
            aload 0 /* this */
            invokestatic reactor.core.Disposables.composite:()Lreactor/core/Disposable$Composite;
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.resources:Lreactor/core/Disposable$Composite;
         5: .line 129
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.windows:Ljava/util/List;
         6: .line 130
            getstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.OPEN_WINDOW_COUNT:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lconst_1
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.lazySet:(Ljava/lang/Object;J)V
         7: .line 131
            return
        end local 4 // java.util.function.Supplier processorQueueSupplier
        end local 3 // java.util.function.Function close
        end local 2 // org.reactivestreams.Publisher open
        end local 1 // reactor.core.CoreSubscriber actual
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0    8     0                    this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            0    8     1                  actual  Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/Flux<TT;>;>;
            0    8     2                    open  Lorg/reactivestreams/Publisher<TU;>;
            0    8     3                   close  Ljava/util/function/Function<-TU;+Lorg/reactivestreams/Publisher<TV;>;>;
            0    8     4  processorQueueSupplier  Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
    Signature: (Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/Flux<TT;>;>;Lorg/reactivestreams/Publisher<TU;>;Ljava/util/function/Function<-TU;+Lorg/reactivestreams/Publisher<TV;>;>;Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;)V
    MethodParameters:
                        Name  Flags
      actual                  
      open                    
      close                   
      processorQueueSupplier  

  public void onSubscribe(org.reactivestreams.Subscription);
    descriptor: (Lorg/reactivestreams/Subscription;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 135
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.s:Lorg/reactivestreams/Subscription;
            aload 1 /* s */
            invokestatic reactor.core.publisher.Operators.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
            ifeq 3
         1: .line 136
            aload 0 /* this */
            aload 1 /* s */
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.s:Lorg/reactivestreams/Subscription;
         2: .line 137
            aload 1 /* s */
            ldc 9223372036854775807
            invokeinterface org.reactivestreams.Subscription.request:(J)V
         3: .line 139
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            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=3, locals=4, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // java.lang.Object t
         0: .line 143
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.done:Z
            ifeq 3
         1: .line 144
            aload 1 /* t */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
            invokestatic reactor.core.publisher.Operators.onNextDropped:(Ljava/lang/Object;Lreactor/util/context/Context;)V
         2: .line 145
            return
         3: .line 147
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.fastEnter:()Z
            ifeq 10
         4: .line 148
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.windows:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 7
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.lang.Object top java.util.Iterator
      StackMap stack:
         5: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast reactor.core.publisher.Sinks$Many
            astore 2 /* w */
        start local 2 // reactor.core.publisher.Sinks$Many w
         6: .line 149
            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
        end local 2 // reactor.core.publisher.Sinks$Many w
         7: .line 148
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         8: .line 151
            aload 0 /* this */
            iconst_m1
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.leave:(I)I
            ifne 13
         9: .line 152
            return
        10: .line 155
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.queue:Ljava/util/Queue;
            aload 1 /* t */
            invokeinterface java.util.Queue.offer:(Ljava/lang/Object;)Z
            pop
        11: .line 156
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.enter:()Z
            ifne 13
        12: .line 157
            return
        13: .line 160
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.drainLoop:()V
        14: .line 161
            return
        end local 1 // java.lang.Object t
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   15     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            0   15     1     t  TT;
            6    7     2     w  Lreactor/core/publisher/Sinks$Many<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=4, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 165
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.done:Z
            ifeq 3
         1: .line 166
            aload 1 /* t */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.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
         2: .line 167
            return
         3: .line 169
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* t */
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.error:Ljava/lang/Throwable;
         4: .line 170
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.done:Z
         5: .line 172
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.enter:()Z
            ifeq 7
         6: .line 173
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.drainLoop:()V
         7: .line 176
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.OPEN_WINDOW_COUNT:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
            lconst_0
            lcmp
            ifne 9
         8: .line 177
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.resources:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
         9: .line 179
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable t
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            0   10     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
         0: .line 183
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.done:Z
            ifeq 2
         1: .line 184
            return
         2: .line 186
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.done:Z
         3: .line 188
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.enter:()Z
            ifeq 5
         4: .line 189
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.drainLoop:()V
         5: .line 192
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.OPEN_WINDOW_COUNT:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
            lconst_0
            lcmp
            ifne 7
         6: .line 193
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.resources:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
         7: .line 195
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;

  void error(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 198
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.s:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         1: .line 199
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.resources:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
         2: .line 200
            getstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.BOUNDARY:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            invokestatic reactor.core.publisher.OperatorDisposables.dispose:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;)Z
            pop
         3: .line 202
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 1 /* t */
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
         4: .line 203
            return
        end local 1 // java.lang.Throwable t
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            0    5     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void request(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // long n
         0: .line 207
            aload 0 /* this */
            lload 1 /* n */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.requested:(J)V
         1: .line 208
            return
        end local 1 // long n
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            0    2     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.FluxWindowWhen$WindowWhenMainSubscriber this
         0: .line 212
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.cancelled:Z
         1: .line 213
            return
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;

  void dispose();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
         0: .line 216
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.resources:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
         1: .line 217
            getstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.BOUNDARY:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            invokestatic reactor.core.publisher.OperatorDisposables.dispose:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;)Z
            pop
         2: .line 218
            return
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;

  void drainLoop();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=14, args_size=1
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
         0: .line 221
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.queue:Ljava/util/Queue;
            astore 1 /* q */
        start local 1 // java.util.Queue q
         1: .line 222
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            astore 2 /* a */
        start local 2 // org.reactivestreams.Subscriber a
         2: .line 223
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.windows:Ljava/util/List;
            astore 3 /* ws */
        start local 3 // java.util.List ws
         3: .line 224
            iconst_1
            istore 4 /* missed */
        start local 4 // int missed
         4: .line 229
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.util.Queue org.reactivestreams.Subscriber java.util.List int
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.done:Z
            istore 5 /* d */
        start local 5 // boolean d
         5: .line 230
            aload 1 /* q */
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            astore 6 /* o */
        start local 6 // java.lang.Object o
         6: .line 232
            aload 6 /* o */
            ifnonnull 7
            iconst_1
            goto 8
      StackMap locals: int java.lang.Object
      StackMap stack:
         7: iconst_0
      StackMap locals:
      StackMap stack: int
         8: istore 7 /* empty */
        start local 7 // boolean empty
         9: .line 234
            iload 5 /* d */
            ifeq 26
            iload 7 /* empty */
            ifeq 26
        10: .line 235
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.dispose:()V
        11: .line 236
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.error:Ljava/lang/Throwable;
            astore 8 /* e */
        start local 8 // java.lang.Throwable e
        12: .line 237
            aload 8 /* e */
            ifnull 19
        13: .line 238
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 8 /* e */
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
        14: .line 239
            aload 3 /* ws */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 10
            goto 17
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.util.Queue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int java.lang.Throwable top java.util.Iterator
      StackMap stack:
        15: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast reactor.core.publisher.Sinks$Many
            astore 9 /* w */
        start local 9 // reactor.core.publisher.Sinks$Many w
        16: .line 240
            aload 9 /* w */
            aload 8 /* e */
            getstatic reactor.core.publisher.Sinks$EmitFailureHandler.FAIL_FAST:Lreactor/core/publisher/Sinks$EmitFailureHandler;
            invokeinterface reactor.core.publisher.Sinks$Many.emitError:(Ljava/lang/Throwable;Lreactor/core/publisher/Sinks$EmitFailureHandler;)V
        end local 9 // reactor.core.publisher.Sinks$Many w
        17: .line 239
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 15
        18: .line 242
            goto 24
        19: .line 243
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.util.Queue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int java.lang.Throwable
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.onComplete:()V
        20: .line 244
            aload 3 /* ws */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 10
            goto 23
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.util.Queue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int java.lang.Throwable top java.util.Iterator
      StackMap stack:
        21: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast reactor.core.publisher.Sinks$Many
            astore 9 /* w */
        start local 9 // reactor.core.publisher.Sinks$Many w
        22: .line 245
            aload 9 /* 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
        end local 9 // reactor.core.publisher.Sinks$Many w
        23: .line 244
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 21
        24: .line 248
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.util.Queue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int java.lang.Throwable
      StackMap stack:
            aload 3 /* ws */
            invokeinterface java.util.List.clear:()V
        25: .line 249
            return
        end local 8 // java.lang.Throwable e
        26: .line 252
      StackMap locals:
      StackMap stack:
            iload 7 /* empty */
            ifeq 28
        27: .line 253
            goto 67
        28: .line 256
      StackMap locals:
      StackMap stack:
            aload 6 /* o */
            instanceof reactor.core.publisher.FluxWindowWhen$WindowOperation
            ifeq 61
        29: .line 258
            aload 6 /* o */
            checkcast reactor.core.publisher.FluxWindowWhen$WindowOperation
            astore 8 /* wo */
        start local 8 // reactor.core.publisher.FluxWindowWhen$WindowOperation wo
        30: .line 260
            aload 8 /* wo */
            getfield reactor.core.publisher.FluxWindowWhen$WindowOperation.w:Lreactor/core/publisher/Sinks$Many;
            astore 9 /* w */
        start local 9 // reactor.core.publisher.Sinks$Many w
        31: .line 261
            aload 9 /* w */
            ifnull 37
        32: .line 262
            aload 3 /* ws */
            aload 8 /* wo */
            getfield reactor.core.publisher.FluxWindowWhen$WindowOperation.w:Lreactor/core/publisher/Sinks$Many;
            invokeinterface java.util.List.remove:(Ljava/lang/Object;)Z
            ifeq 4
        33: .line 263
            aload 8 /* wo */
            getfield reactor.core.publisher.FluxWindowWhen$WindowOperation.w:Lreactor/core/publisher/Sinks$Many;
            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
        34: .line 265
            getstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.OPEN_WINDOW_COUNT:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
            lconst_0
            lcmp
            ifne 4
        35: .line 266
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.dispose:()V
        36: .line 267
            return
        37: .line 273
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowOperation reactor.core.publisher.Sinks$Many
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.cancelled:Z
            ifeq 39
        38: .line 274
            goto 4
        39: .line 278
      StackMap locals:
      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;
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.processorQueueSupplier:Ljava/util/function/Supplier;
            invokeinterface java.util.function.Supplier.get:()Ljava/lang/Object;
            checkcast java.util.Queue
            invokeinterface reactor.core.publisher.Sinks$UnicastSpec.onBackpressureBuffer:(Ljava/util/Queue;)Lreactor/core/publisher/Sinks$Many;
            astore 9 /* w */
        40: .line 280
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.requested:()J
            lstore 10 /* r */
        start local 10 // long r
        41: .line 281
            lload 10 /* r */
            lconst_0
            lcmp
            ifeq 47
        42: .line 282
            aload 3 /* ws */
            aload 9 /* w */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        43: .line 283
            aload 2 /* a */
            aload 9 /* w */
            invokeinterface reactor.core.publisher.Sinks$Many.asFlux:()Lreactor/core/publisher/Flux;
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        44: .line 284
            lload 10 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 50
        45: .line 285
            aload 0 /* this */
            lconst_1
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.produced:(J)J
            pop2
        46: .line 287
            goto 50
        47: .line 288
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.cancelled:Z
        48: .line 289
            aload 2 /* a */
            ldc "Could not deliver new window due to lack of requests"
            invokestatic reactor.core.Exceptions.failWithOverflow:(Ljava/lang/String;)Ljava/lang/IllegalStateException;
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        49: .line 290
            goto 4
        50: .line 296
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.close:Ljava/util/function/Function;
            aload 8 /* wo */
            getfield reactor.core.publisher.FluxWindowWhen$WindowOperation.open:Ljava/lang/Object;
            invokeinterface java.util.function.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
            ldc "The publisher supplied is null"
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
            astore 12 /* p */
        start local 12 // org.reactivestreams.Publisher p
        51: .line 297
            goto 56
        end local 12 // org.reactivestreams.Publisher p
      StackMap locals:
      StackMap stack: java.lang.Throwable
        52: astore 13 /* e */
        start local 13 // java.lang.Throwable e
        53: .line 298
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.cancelled:Z
        54: .line 299
            aload 2 /* a */
            aload 13 /* e */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        55: .line 300
            goto 4
        end local 13 // java.lang.Throwable e
        start local 12 // org.reactivestreams.Publisher p
        56: .line 303
      StackMap locals: org.reactivestreams.Publisher
      StackMap stack:
            new reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber
            dup
            aload 0 /* this */
            aload 9 /* w */
            invokespecial reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber.<init>:(Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber;Lreactor/core/publisher/Sinks$Many;)V
            astore 13 /* cl */
        start local 13 // reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber cl
        57: .line 305
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.resources:Lreactor/core/Disposable$Composite;
            aload 13 /* cl */
            invokeinterface reactor.core.Disposable$Composite.add:(Lreactor/core/Disposable;)Z
            ifeq 4
        58: .line 306
            getstatic reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.OPEN_WINDOW_COUNT:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.getAndIncrement:(Ljava/lang/Object;)J
            pop2
        59: .line 308
            aload 12 /* p */
            aload 13 /* cl */
            invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
        60: .line 311
            goto 4
        end local 13 // reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber cl
        end local 12 // org.reactivestreams.Publisher p
        end local 10 // long r
        end local 9 // reactor.core.publisher.Sinks$Many w
        end local 8 // reactor.core.publisher.FluxWindowWhen$WindowOperation wo
        61: .line 314
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.util.Queue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int
      StackMap stack:
            aload 3 /* ws */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 9
            goto 65
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.util.Queue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int top java.util.Iterator
      StackMap stack:
        62: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast reactor.core.publisher.Sinks$Many
            astore 8 /* w */
        start local 8 // reactor.core.publisher.Sinks$Many w
        63: .line 316
            aload 6 /* o */
            astore 10 /* t */
        start local 10 // java.lang.Object t
        64: .line 317
            aload 8 /* w */
            aload 10 /* 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
        end local 10 // java.lang.Object t
        end local 8 // reactor.core.publisher.Sinks$Many w
        65: .line 314
      StackMap locals:
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 62
        end local 7 // boolean empty
        end local 6 // java.lang.Object o
        end local 5 // boolean d
        66: .line 228
            goto 4
        67: .line 321
      StackMap locals: reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber java.util.Queue org.reactivestreams.Subscriber java.util.List int
      StackMap stack:
            aload 0 /* this */
            iload 4 /* missed */
            ineg
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.leave:(I)I
            istore 4 /* missed */
        68: .line 322
            iload 4 /* missed */
            ifne 4
        69: .line 326
            return
        end local 4 // int missed
        end local 3 // java.util.List ws
        end local 2 // org.reactivestreams.Subscriber a
        end local 1 // java.util.Queue q
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   70     0    this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            1   70     1       q  Ljava/util/Queue<Ljava/lang/Object;>;
            2   70     2       a  Lorg/reactivestreams/Subscriber<-Lreactor/core/publisher/Flux<TT;>;>;
            3   70     3      ws  Ljava/util/List<Lreactor/core/publisher/Sinks$Many<TT;>;>;
            4   70     4  missed  I
            5   66     5       d  Z
            6   66     6       o  Ljava/lang/Object;
            9   66     7   empty  Z
           12   26     8       e  Ljava/lang/Throwable;
           16   17     9       w  Lreactor/core/publisher/Sinks$Many<TT;>;
           22   23     9       w  Lreactor/core/publisher/Sinks$Many<TT;>;
           30   61     8      wo  Lreactor/core/publisher/FluxWindowWhen$WindowOperation<TT;TU;>;
           31   61     9       w  Lreactor/core/publisher/Sinks$Many<TT;>;
           41   61    10       r  J
           51   52    12       p  Lorg/reactivestreams/Publisher<TV;>;
           56   61    12       p  Lorg/reactivestreams/Publisher<TV;>;
           53   56    13       e  Ljava/lang/Throwable;
           57   61    13      cl  Lreactor/core/publisher/FluxWindowWhen$WindowWhenCloseSubscriber<TT;TV;>;
           63   65     8       w  Lreactor/core/publisher/Sinks$Many<TT;>;
           64   65    10       t  TT;
      Exception table:
        from    to  target  type
          50    51      52  Class java.lang.Throwable

  void open();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // java.lang.Object b
         0: .line 329
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.queue:Ljava/util/Queue;
            new reactor.core.publisher.FluxWindowWhen$WindowOperation
            dup
            aconst_null
            aload 1 /* b */
            invokespecial reactor.core.publisher.FluxWindowWhen$WindowOperation.<init>:(Lreactor/core/publisher/Sinks$Many;Ljava/lang/Object;)V
            invokeinterface java.util.Queue.offer:(Ljava/lang/Object;)Z
            pop
         1: .line 330
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.enter:()Z
            ifeq 3
         2: .line 331
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.drainLoop:()V
         3: .line 333
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object b
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            0    4     1     b  TU;
    Signature: (TU;)V
    MethodParameters:
      Name  Flags
      b     

  void close(reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber<T, V>);
    descriptor: (Lreactor/core/publisher/FluxWindowWhen$WindowWhenCloseSubscriber;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber w
         0: .line 336
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.resources:Lreactor/core/Disposable$Composite;
            aload 1 /* w */
            invokeinterface reactor.core.Disposable$Composite.remove:(Lreactor/core/Disposable;)Z
            pop
         1: .line 337
            aload 0 /* this */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.queue:Ljava/util/Queue;
            new reactor.core.publisher.FluxWindowWhen$WindowOperation
            dup
            aload 1 /* w */
            getfield reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber.w:Lreactor/core/publisher/Sinks$Many;
            aconst_null
            invokespecial reactor.core.publisher.FluxWindowWhen$WindowOperation.<init>:(Lreactor/core/publisher/Sinks$Many;Ljava/lang/Object;)V
            invokeinterface java.util.Queue.offer:(Ljava/lang/Object;)Z
            pop
         2: .line 338
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.enter:()Z
            ifeq 4
         3: .line 339
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber.drainLoop:()V
         4: .line 341
      StackMap locals:
      StackMap stack:
            return
        end local 1 // reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber w
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            0    5     1     w  Lreactor/core/publisher/FluxWindowWhen$WindowWhenCloseSubscriber<TT;TV;>;
    Signature: (Lreactor/core/publisher/FluxWindowWhen$WindowWhenCloseSubscriber<TT;TV;>;)V
    MethodParameters:
      Name  Flags
      w     

  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.FluxWindowWhen$WindowWhenMainSubscriber this
        start local 1 // reactor.core.Scannable$Attr key
         0: .line 345
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
            if_acmpne 1
            getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
            areturn
         1: .line 346
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* key */
            invokespecial reactor.core.publisher.QueueDrainSubscriber.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
            areturn
        end local 1 // reactor.core.Scannable$Attr key
        end local 0 // reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxWindowWhen$WindowWhenMainSubscriber<TT;TU;TV;>;
            0    2     1   key  Lreactor/core/Scannable$Attr;
    MethodParameters:
      Name  Flags
      key   
}
Signature: <T:Ljava/lang/Object;U:Ljava/lang/Object;V:Ljava/lang/Object;>Lreactor/core/publisher/QueueDrainSubscriber<TT;Ljava/lang/Object;Lreactor/core/publisher/Flux<TT;>;>;
SourceFile: "FluxWindowWhen.java"
NestHost: reactor.core.publisher.FluxWindowWhen
InnerClasses:
  public abstract Composite = reactor.core.Disposable$Composite of reactor.core.Disposable
  public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
  public final RunStyle = reactor.core.Scannable$Attr$RunStyle of reactor.core.Scannable$Attr
  final WindowOperation = reactor.core.publisher.FluxWindowWhen$WindowOperation of reactor.core.publisher.FluxWindowWhen
  final WindowWhenCloseSubscriber = reactor.core.publisher.FluxWindowWhen$WindowWhenCloseSubscriber of reactor.core.publisher.FluxWindowWhen
  final WindowWhenMainSubscriber = reactor.core.publisher.FluxWindowWhen$WindowWhenMainSubscriber of reactor.core.publisher.FluxWindowWhen
  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