final class reactor.core.publisher.FluxGroupBy$GroupByMain<T, K, V> implements reactor.core.Fuseable$QueueSubscription<reactor.core.publisher.GroupedFlux<K, V>>, reactor.core.publisher.InnerOperator<T, reactor.core.publisher.GroupedFlux<K, V>>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: reactor.core.publisher.FluxGroupBy$GroupByMain
  super_class: java.lang.Object
{
  final java.util.function.Function<? super T, ? extends K> keySelector;
    descriptor: Ljava/util/function/Function;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/Function<-TT;+TK;>;

  final java.util.function.Function<? super T, ? extends V> valueSelector;
    descriptor: Ljava/util/function/Function;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/Function<-TT;+TV;>;

  final java.util.Queue<reactor.core.publisher.GroupedFlux<K, V>> queue;
    descriptor: Ljava/util/Queue;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;

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

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

  final java.util.Map<K, reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux<K, V>> groupMap;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<TK;Lreactor/core/publisher/FluxGroupBy$UnicastGroupedFlux<TK;TV;>;>;

  final reactor.core.CoreSubscriber<? super reactor.core.publisher.GroupedFlux<K, V>> actual;
    descriptor: Lreactor/core/CoreSubscriber;
    flags: (0x0010) ACC_FINAL
    Signature: Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;

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

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

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

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

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

  volatile java.lang.Throwable error;
    descriptor: Ljava/lang/Throwable;
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.publisher.FluxGroupBy$GroupByMain, java.lang.Throwable> ERROR;
    descriptor: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Lreactor/core/publisher/FluxGroupBy$GroupByMain;Ljava/lang/Throwable;>;

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

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

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

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

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

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 116
            ldc Lreactor/core/publisher/FluxGroupBy$GroupByMain;
            ldc "wip"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         1: .line 115
            putstatic reactor.core.publisher.FluxGroupBy$GroupByMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         2: .line 121
            ldc Lreactor/core/publisher/FluxGroupBy$GroupByMain;
            ldc "requested"
            invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         3: .line 120
            putstatic reactor.core.publisher.FluxGroupBy$GroupByMain.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         4: .line 127
            ldc Lreactor/core/publisher/FluxGroupBy$GroupByMain;
         5: .line 128
            ldc Ljava/lang/Throwable;
         6: .line 129
            ldc "error"
         7: .line 127
            invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         8: .line 126
            putstatic reactor.core.publisher.FluxGroupBy$GroupByMain.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         9: .line 134
            ldc Lreactor/core/publisher/FluxGroupBy$GroupByMain;
            ldc "cancelled"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        10: .line 133
            putstatic reactor.core.publisher.FluxGroupBy$GroupByMain.CANCELLED:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        11: .line 139
            ldc Lreactor/core/publisher/FluxGroupBy$GroupByMain;
            ldc "groupCount"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        12: .line 138
            putstatic reactor.core.publisher.FluxGroupBy$GroupByMain.GROUP_COUNT:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        13: .line 139
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(reactor.core.CoreSubscriber<? super reactor.core.publisher.GroupedFlux<K, V>>, java.util.Queue<reactor.core.publisher.GroupedFlux<K, V>>, java.util.function.Supplier<? extends java.util.Queue<V>>, int, java.util.function.Function<? super T, ? extends K>, java.util.function.Function<? super T, ? extends V>);
    descriptor: (Lreactor/core/CoreSubscriber;Ljava/util/Queue;Ljava/util/function/Supplier;ILjava/util/function/Function;Ljava/util/function/Function;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=7, args_size=7
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
        start local 1 // reactor.core.CoreSubscriber actual
        start local 2 // java.util.Queue queue
        start local 3 // java.util.function.Supplier groupQueueSupplier
        start local 4 // int prefetch
        start local 5 // java.util.function.Function keySelector
        start local 6 // java.util.function.Function valueSelector
         0: .line 145
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 151
            aload 0 /* this */
            aload 1 /* actual */
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.actual:Lreactor/core/CoreSubscriber;
         2: .line 152
            aload 0 /* this */
            aload 2 /* queue */
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
         3: .line 153
            aload 0 /* this */
            aload 3 /* groupQueueSupplier */
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupQueueSupplier:Ljava/util/function/Supplier;
         4: .line 154
            aload 0 /* this */
            iload 4 /* prefetch */
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.prefetch:I
         5: .line 155
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
         6: .line 156
            aload 0 /* this */
            aload 5 /* keySelector */
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.keySelector:Ljava/util/function/Function;
         7: .line 157
            aload 0 /* this */
            aload 6 /* valueSelector */
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.valueSelector:Ljava/util/function/Function;
         8: .line 158
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.GROUP_COUNT:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
         9: .line 159
            return
        end local 6 // java.util.function.Function valueSelector
        end local 5 // java.util.function.Function keySelector
        end local 4 // int prefetch
        end local 3 // java.util.function.Supplier groupQueueSupplier
        end local 2 // java.util.Queue queue
        end local 1 // reactor.core.CoreSubscriber actual
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   10     0                this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0   10     1              actual  Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
            0   10     2               queue  Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
            0   10     3  groupQueueSupplier  Ljava/util/function/Supplier<+Ljava/util/Queue<TV;>;>;
            0   10     4            prefetch  I
            0   10     5         keySelector  Ljava/util/function/Function<-TT;+TK;>;
            0   10     6       valueSelector  Ljava/util/function/Function<-TT;+TV;>;
    Signature: (Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;Ljava/util/function/Supplier<+Ljava/util/Queue<TV;>;>;ILjava/util/function/Function<-TT;+TK;>;Ljava/util/function/Function<-TT;+TV;>;)V
    MethodParameters:
                    Name  Flags
      actual              
      queue               
      groupQueueSupplier  
      prefetch            
      keySelector         
      valueSelector       

  public final reactor.core.CoreSubscriber<? super reactor.core.publisher.GroupedFlux<K, V>> actual();
    descriptor: ()Lreactor/core/CoreSubscriber;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 163
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.actual:Lreactor/core/CoreSubscriber;
            areturn
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
    Signature: ()Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;

  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.FluxGroupBy$GroupByMain this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 168
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.s:Lorg/reactivestreams/Subscription;
            aload 1 /* s */
            invokestatic reactor.core.publisher.Operators.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
            ifeq 4
         1: .line 169
            aload 0 /* this */
            aload 1 /* s */
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.s:Lorg/reactivestreams/Subscription;
         2: .line 170
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.actual:Lreactor/core/CoreSubscriber;
            aload 0 /* this */
            invokeinterface reactor.core.CoreSubscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         3: .line 171
            aload 1 /* s */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.prefetch:I
            invokestatic reactor.core.publisher.Operators.unboundedOrPrefetch:(I)J
            invokeinterface org.reactivestreams.Subscription.request:(J)V
         4: .line 173
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0    5     1     s  Lorg/reactivestreams/Subscription;
    MethodParameters:
      Name  Flags
      s     

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=2
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
        start local 1 // java.lang.Object t
         0: .line 177
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.done:Z
            ifeq 3
         1: .line 178
            aload 1 /* t */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.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 179
            return
         3: .line 186
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.keySelector:Ljava/util/function/Function;
            aload 1 /* t */
            invokeinterface java.util.function.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
            ldc "The keySelector returned a null value"
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            astore 2 /* key */
        start local 2 // java.lang.Object key
         4: .line 187
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.valueSelector:Ljava/util/function/Function;
            aload 1 /* t */
            invokeinterface java.util.function.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
            ldc "The valueSelector returned a null value"
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            astore 3 /* value */
        start local 3 // java.lang.Object value
         5: .line 188
            goto 9
        end local 3 // java.lang.Object value
        end local 2 // java.lang.Object key
         6: .line 189
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 4 /* ex */
        start local 4 // java.lang.Throwable ex
         7: .line 190
            aload 0 /* this */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.s:Lorg/reactivestreams/Subscription;
            aload 4 /* ex */
            aload 1 /* t */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.onError:(Ljava/lang/Throwable;)V
         8: .line 191
            return
        end local 4 // java.lang.Throwable ex
        start local 2 // java.lang.Object key
        start local 3 // java.lang.Object value
         9: .line 194
      StackMap locals: java.lang.Object java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
            aload 2 /* key */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux
            astore 4 /* g */
        start local 4 // reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux g
        10: .line 196
            aload 4 /* g */
            ifnonnull 20
        11: .line 198
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.cancelled:I
            ifne 21
        12: .line 199
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupQueueSupplier:Ljava/util/function/Supplier;
            invokeinterface java.util.function.Supplier.get:()Ljava/lang/Object;
            checkcast java.util.Queue
            astore 5 /* q */
        start local 5 // java.util.Queue q
        13: .line 201
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.GROUP_COUNT:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            pop
        14: .line 202
            new reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux
            dup
            aload 2 /* key */
            aload 5 /* q */
            aload 0 /* this */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.prefetch:I
            invokespecial reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux.<init>:(Ljava/lang/Object;Ljava/util/Queue;Lreactor/core/publisher/FluxGroupBy$GroupByMain;I)V
            astore 4 /* g */
        15: .line 203
            aload 4 /* g */
            aload 3 /* value */
            invokevirtual reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux.onNext:(Ljava/lang/Object;)V
        16: .line 204
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
            aload 2 /* key */
            aload 4 /* g */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        17: .line 206
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            aload 4 /* g */
            invokeinterface java.util.Queue.offer:(Ljava/lang/Object;)Z
            pop
        18: .line 207
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.drain:()V
        end local 5 // java.util.Queue q
        19: .line 209
            goto 21
        20: .line 211
      StackMap locals: reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux
      StackMap stack:
            aload 4 /* g */
            aload 3 /* value */
            invokevirtual reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux.onNext:(Ljava/lang/Object;)V
        21: .line 213
      StackMap locals:
      StackMap stack:
            return
        end local 4 // reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux g
        end local 3 // java.lang.Object value
        end local 2 // java.lang.Object key
        end local 1 // java.lang.Object t
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   22     0   this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0   22     1      t  TT;
            4    6     2    key  TK;
            9   22     2    key  TK;
            5    6     3  value  TV;
            9   22     3  value  TV;
            7    9     4     ex  Ljava/lang/Throwable;
           10   22     4      g  Lreactor/core/publisher/FluxGroupBy$UnicastGroupedFlux<TK;TV;>;
           13   19     5      q  Ljava/util/Queue<TV;>;
      Exception table:
        from    to  target  type
           3     5       6  Class java.lang.Throwable
    Signature: (TT;)V
    MethodParameters:
      Name  Flags
      t     

  public void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
        start local 1 // java.lang.Throwable t
         0: .line 217
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 1 /* t */
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            ifeq 4
         1: .line 218
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.done:Z
         2: .line 219
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.drain:()V
         3: .line 220
            goto 5
         4: .line 222
      StackMap locals:
      StackMap stack:
            aload 1 /* t */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.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
         5: .line 224
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable t
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0    6     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 228
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.done:Z
            ifeq 2
         1: .line 229
            return
         2: .line 231
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 5
      StackMap locals: reactor.core.publisher.FluxGroupBy$GroupByMain top java.util.Iterator
      StackMap stack:
         3: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux
            astore 1 /* g */
        start local 1 // reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux g
         4: .line 232
            aload 1 /* g */
            invokevirtual reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux.onComplete:()V
        end local 1 // reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux g
         5: .line 231
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 234
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         7: .line 235
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.done:Z
         8: .line 236
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.drain:()V
         9: .line 237
            return
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            4    5     1     g  Lreactor/core/publisher/FluxGroupBy$UnicastGroupedFlux<TK;TV;>;

  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.FluxGroupBy$GroupByMain this
        start local 1 // reactor.core.Scannable$Attr key
         0: .line 242
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.PARENT:Lreactor/core/Scannable$Attr;
            if_acmpne 1
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.s:Lorg/reactivestreams/Subscription;
            areturn
         1: .line 243
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.TERMINATED:Lreactor/core/Scannable$Attr;
            if_acmpne 2
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.done:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         2: .line 244
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.REQUESTED_FROM_DOWNSTREAM:Lreactor/core/Scannable$Attr;
            if_acmpne 3
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.requested:J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
         3: .line 245
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.PREFETCH:Lreactor/core/Scannable$Attr;
            if_acmpne 4
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.prefetch:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
         4: .line 246
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.BUFFERED:Lreactor/core/Scannable$Attr;
            if_acmpne 5
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.size:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
         5: .line 247
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.CANCELLED:Lreactor/core/Scannable$Attr;
            if_acmpne 7
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.cancelled:I
            iconst_1
            if_icmpne 6
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
      StackMap locals:
      StackMap stack:
         6: iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         7: .line 248
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.ERROR:Lreactor/core/Scannable$Attr;
            if_acmpne 8
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.error:Ljava/lang/Throwable;
            areturn
         8: .line 249
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
            if_acmpne 9
            getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
            areturn
         9: .line 251
      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.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0   10     1   key  Lreactor/core/Scannable$Attr;
    RuntimeVisibleAnnotations: 
      reactor.util.annotation.Nullable()
    MethodParameters:
      Name  Flags
      key   

  public java.util.stream.Stream<? extends reactor.core.Scannable> inners();
    descriptor: ()Ljava/util/stream/Stream;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 256
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.stream:()Ljava/util/stream/Stream;
            areturn
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
    Signature: ()Ljava/util/stream/Stream<+Lreactor/core/Scannable;>;

  void signalAsyncError();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 260
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            invokestatic reactor.core.Exceptions.terminate:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;)Ljava/lang/Throwable;
            astore 1 /* e */
        start local 1 // java.lang.Throwable e
         1: .line 261
            aload 1 /* e */
            ifnonnull 3
         2: .line 262
            new java.lang.IllegalStateException
            dup
            ldc "FluxGroupBy.signalAsyncError called without error set"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            astore 1 /* e */
         3: .line 264
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupCount:I
         4: .line 265
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 7
      StackMap locals: reactor.core.publisher.FluxGroupBy$GroupByMain java.lang.Throwable top java.util.Iterator
      StackMap stack:
         5: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux
            astore 2 /* g */
        start local 2 // reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux g
         6: .line 266
            aload 2 /* g */
            aload 1 /* e */
            invokevirtual reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux.onError:(Ljava/lang/Throwable;)V
        end local 2 // reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux g
         7: .line 265
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         8: .line 268
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.actual:Lreactor/core/CoreSubscriber;
            aload 1 /* e */
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
         9: .line 269
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
        10: .line 270
            return
        end local 1 // java.lang.Throwable e
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            1   11     1     e  Ljava/lang/Throwable;
            6    7     2     g  Lreactor/core/publisher/FluxGroupBy$UnicastGroupedFlux<TK;TV;>;

  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.FluxGroupBy$GroupByMain this
        start local 1 // long n
         0: .line 274
            lload 1 /* n */
            invokestatic reactor.core.publisher.Operators.validate:(J)Z
            ifeq 3
         1: .line 275
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.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 276
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.drain:()V
         3: .line 278
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long n
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0    4     1     n  J
    MethodParameters:
      Name  Flags
      n     

  public void cancel();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 282
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.CANCELLED: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 13
         1: .line 283
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.GROUP_COUNT:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            ifne 4
         2: .line 284
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.s:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         3: .line 285
            goto 13
         4: .line 286
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.enableAsyncFusion:Z
            ifne 13
         5: .line 287
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifne 13
         6: .line 290
            goto 8
        start local 1 // reactor.core.publisher.GroupedFlux g
         7: .line 291
      StackMap locals: reactor.core.publisher.GroupedFlux
      StackMap stack:
            aload 1 /* g */
            checkcast reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux
            invokevirtual reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux.cancel:()V
        end local 1 // reactor.core.publisher.GroupedFlux g
         8: .line 290
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            checkcast reactor.core.publisher.GroupedFlux
            dup
            astore 1 /* g */
        start local 1 // reactor.core.publisher.GroupedFlux g
         9: ifnonnull 7
        10: .line 294
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            ifne 12
        11: .line 295
            return
        12: .line 298
      StackMap locals: reactor.core.publisher.GroupedFlux
      StackMap stack:
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.drainLoop:()V
        end local 1 // reactor.core.publisher.GroupedFlux g
        13: .line 302
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   14     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            7    8     1     g  Lreactor/core/publisher/GroupedFlux<TK;TV;>;
            9   13     1     g  Lreactor/core/publisher/GroupedFlux<TK;TV;>;

  void groupTerminated();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
        start local 1 // java.lang.Object key
         0: .line 305
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupCount:I
            ifne 2
         1: .line 306
            return
         2: .line 308
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.groupMap:Ljava/util/Map;
            aload 1 /* key */
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 309
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.GROUP_COUNT:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            ifne 5
         4: .line 310
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.s:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         5: .line 312
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object key
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0    6     1   key  TK;
    Signature: (TK;)V
    MethodParameters:
      Name  Flags
      key   

  void drain();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 315
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifeq 2
         1: .line 316
            return
         2: .line 319
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.enableAsyncFusion:Z
            ifeq 5
         3: .line 320
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.drainFused:()V
         4: .line 321
            goto 6
         5: .line 323
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.drainLoop:()V
         6: .line 325
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;

  void drainFused();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=6, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 328
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         1: .line 330
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.actual:Lreactor/core/CoreSubscriber;
            astore 2 /* a */
        start local 2 // org.reactivestreams.Subscriber a
         2: .line 331
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            astore 3 /* q */
        start local 3 // java.util.Queue q
         3: .line 335
      StackMap locals: int org.reactivestreams.Subscriber java.util.Queue
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.cancelled:I
            ifeq 6
         4: .line 336
            aload 3 /* q */
            invokeinterface java.util.Queue.clear:()V
         5: .line 337
            return
         6: .line 340
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.done:Z
            istore 4 /* d */
        start local 4 // boolean d
         7: .line 342
            aload 2 /* a */
            aconst_null
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
         8: .line 344
            iload 4 /* d */
            ifeq 15
         9: .line 345
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.error:Ljava/lang/Throwable;
            astore 5 /* ex */
        start local 5 // java.lang.Throwable ex
        10: .line 346
            aload 5 /* ex */
            ifnull 13
        11: .line 347
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.signalAsyncError:()V
        12: .line 348
            goto 14
        13: .line 350
      StackMap locals: int java.lang.Throwable
      StackMap stack:
            aload 2 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        14: .line 352
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.lang.Throwable ex
        15: .line 355
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.addAndGet:(Ljava/lang/Object;I)I
            istore 1 /* missed */
        16: .line 356
            iload 1 /* missed */
            ifne 3
        end local 4 // boolean d
        17: .line 360
            return
        end local 3 // java.util.Queue q
        end local 2 // org.reactivestreams.Subscriber a
        end local 1 // int missed
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   18     0    this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            1   18     1  missed  I
            2   18     2       a  Lorg/reactivestreams/Subscriber<-Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
            3   18     3       q  Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
            7   17     4       d  Z
           10   15     5      ex  Ljava/lang/Throwable;

  void drainLoop();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=11, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 364
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         1: .line 366
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.actual:Lreactor/core/CoreSubscriber;
            astore 2 /* a */
        start local 2 // org.reactivestreams.Subscriber a
         2: .line 367
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            astore 3 /* q */
        start local 3 // java.util.Queue q
         3: .line 371
      StackMap locals: int org.reactivestreams.Subscriber java.util.Queue
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.requested:J
            lstore 4 /* r */
        start local 4 // long r
         4: .line 372
            lconst_0
            lstore 6 /* e */
        start local 6 // long e
         5: .line 374
            goto 17
         6: .line 375
      StackMap locals: long long
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.done:Z
            istore 8 /* d */
        start local 8 // boolean d
         7: .line 376
            aload 3 /* q */
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            checkcast reactor.core.publisher.GroupedFlux
            astore 9 /* v */
        start local 9 // reactor.core.publisher.GroupedFlux v
         8: .line 377
            aload 9 /* v */
            ifnonnull 9
            iconst_1
            goto 10
      StackMap locals: int reactor.core.publisher.GroupedFlux
      StackMap stack:
         9: iconst_0
      StackMap locals:
      StackMap stack: int
        10: istore 10 /* empty */
        start local 10 // boolean empty
        11: .line 379
            aload 0 /* this */
            iload 8 /* d */
            iload 10 /* empty */
            aload 2 /* a */
            aload 3 /* q */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.checkTerminated:(ZZLorg/reactivestreams/Subscriber;Ljava/util/Queue;)Z
            ifeq 13
        12: .line 380
            return
        13: .line 383
      StackMap locals: int
      StackMap stack:
            iload 10 /* empty */
            ifeq 15
        14: .line 384
            goto 18
        15: .line 387
      StackMap locals:
      StackMap stack:
            aload 2 /* a */
            aload 9 /* v */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        16: .line 389
            lload 6 /* e */
            lconst_1
            ladd
            lstore 6 /* e */
        end local 10 // boolean empty
        end local 9 // reactor.core.publisher.GroupedFlux v
        end local 8 // boolean d
        17: .line 374
      StackMap locals:
      StackMap stack:
            lload 6 /* e */
            lload 4 /* r */
            lcmp
            ifne 6
        18: .line 392
      StackMap locals:
      StackMap stack:
            lload 6 /* e */
            lload 4 /* r */
            lcmp
            ifne 21
        19: .line 393
            aload 0 /* this */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.done:Z
            aload 3 /* q */
            invokeinterface java.util.Queue.isEmpty:()Z
            aload 2 /* a */
            aload 3 /* q */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.checkTerminated:(ZZLorg/reactivestreams/Subscriber;Ljava/util/Queue;)Z
            ifeq 21
        20: .line 394
            return
        21: .line 398
      StackMap locals:
      StackMap stack:
            lload 6 /* e */
            lconst_0
            lcmp
            ifeq 25
        22: .line 400
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.s:Lorg/reactivestreams/Subscription;
            lload 6 /* e */
            invokeinterface org.reactivestreams.Subscription.request:(J)V
        23: .line 402
            lload 4 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 25
        24: .line 403
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lload 6 /* e */
            lneg
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.addAndGet:(Ljava/lang/Object;J)J
            pop2
        25: .line 407
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxGroupBy$GroupByMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.addAndGet:(Ljava/lang/Object;I)I
            istore 1 /* missed */
        26: .line 408
            iload 1 /* missed */
            ifne 3
        end local 6 // long e
        end local 4 // long r
        27: .line 412
            return
        end local 3 // java.util.Queue q
        end local 2 // org.reactivestreams.Subscriber a
        end local 1 // int missed
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   28     0    this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            1   28     1  missed  I
            2   28     2       a  Lorg/reactivestreams/Subscriber<-Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
            3   28     3       q  Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
            4   27     4       r  J
            5   27     6       e  J
            7   17     8       d  Z
            8   17     9       v  Lreactor/core/publisher/GroupedFlux<TK;TV;>;
           11   17    10   empty  Z

  boolean checkTerminated(boolean, boolean, org.reactivestreams.Subscriber<?>, java.util.Queue<reactor.core.publisher.GroupedFlux<K, V>>);
    descriptor: (ZZLorg/reactivestreams/Subscriber;Ljava/util/Queue;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=6, args_size=5
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
        start local 1 // boolean d
        start local 2 // boolean empty
        start local 3 // org.reactivestreams.Subscriber a
        start local 4 // java.util.Queue q
         0: .line 418
            iload 1 /* d */
            ifeq 9
         1: .line 419
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.error:Ljava/lang/Throwable;
            astore 5 /* e */
        start local 5 // java.lang.Throwable e
         2: .line 420
            aload 5 /* e */
            ifnull 6
            aload 5 /* e */
            getstatic reactor.core.Exceptions.TERMINATED:Ljava/lang/Throwable;
            if_acmpeq 6
         3: .line 421
            aload 4 /* q */
            invokeinterface java.util.Queue.clear:()V
         4: .line 422
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.signalAsyncError:()V
         5: .line 423
            iconst_1
            ireturn
         6: .line 425
      StackMap locals: java.lang.Throwable
      StackMap stack:
            iload 2 /* empty */
            ifeq 9
         7: .line 426
            aload 3 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
         8: .line 427
            iconst_1
            ireturn
        end local 5 // java.lang.Throwable e
         9: .line 431
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // java.util.Queue q
        end local 3 // org.reactivestreams.Subscriber a
        end local 2 // boolean empty
        end local 1 // boolean d
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   10     0   this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0   10     1      d  Z
            0   10     2  empty  Z
            0   10     3      a  Lorg/reactivestreams/Subscriber<*>;
            0   10     4      q  Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
            2    9     5      e  Ljava/lang/Throwable;
    Signature: (ZZLorg/reactivestreams/Subscriber<*>;Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;)Z
    MethodParameters:
       Name  Flags
      d      
      empty  
      a      
      q      

  public reactor.core.publisher.GroupedFlux<K, V> poll();
    descriptor: ()Lreactor/core/publisher/GroupedFlux;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 437
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            checkcast reactor.core.publisher.GroupedFlux
            areturn
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
    Signature: ()Lreactor/core/publisher/GroupedFlux<TK;TV;>;
    RuntimeVisibleAnnotations: 
      reactor.util.annotation.Nullable()

  public int size();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 442
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.size:()I
            ireturn
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;

  public boolean isEmpty();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 447
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.isEmpty:()Z
            ireturn
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
         0: .line 452
            aload 0 /* this */
            getfield reactor.core.publisher.FluxGroupBy$GroupByMain.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.clear:()V
         1: .line 453
            return
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;

  public int requestFusion(int);
    descriptor: (I)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
        start local 1 // int requestedMode
         0: .line 457
            iload 1 /* requestedMode */
            iconst_2
            iand
            ifeq 3
         1: .line 458
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.FluxGroupBy$GroupByMain.enableAsyncFusion:Z
         2: .line 459
            iconst_2
            ireturn
         3: .line 461
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // int requestedMode
        end local 0 // reactor.core.publisher.FluxGroupBy$GroupByMain this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    4     0           this  Lreactor/core/publisher/FluxGroupBy$GroupByMain<TT;TK;TV;>;
            0    4     1  requestedMode  I
    MethodParameters:
               Name  Flags
      requestedMode  

  public java.lang.Object poll();
    descriptor: ()Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual reactor.core.publisher.FluxGroupBy$GroupByMain.poll:()Lreactor/core/publisher/GroupedFlux;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
Signature: <T:Ljava/lang/Object;K:Ljava/lang/Object;V:Ljava/lang/Object;>Ljava/lang/Object;Lreactor/core/Fuseable$QueueSubscription<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;Lreactor/core/publisher/InnerOperator<TT;Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
SourceFile: "FluxGroupBy.java"
NestHost: reactor.core.publisher.FluxGroupBy
InnerClasses:
  public abstract QueueSubscription = reactor.core.Fuseable$QueueSubscription of reactor.core.Fuseable
  public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
  public final RunStyle = reactor.core.Scannable$Attr$RunStyle of reactor.core.Scannable$Attr
  final GroupByMain = reactor.core.publisher.FluxGroupBy$GroupByMain of reactor.core.publisher.FluxGroupBy
  final UnicastGroupedFlux = reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux of reactor.core.publisher.FluxGroupBy