final class io.reactivex.internal.operators.flowable.FlowableGroupBy$State<T, K> extends io.reactivex.internal.subscriptions.BasicIntQueueSubscription<T> implements org.reactivestreams.Publisher<T>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.reactivex.internal.operators.flowable.FlowableGroupBy$State
  super_class: io.reactivex.internal.subscriptions.BasicIntQueueSubscription
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -3852313036005250360

  final K key;
    descriptor: Ljava/lang/Object;
    flags: (0x0010) ACC_FINAL
    Signature: TK;

  final io.reactivex.internal.queue.SpscLinkedArrayQueue<T> queue;
    descriptor: Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
    flags: (0x0010) ACC_FINAL
    Signature: Lio/reactivex/internal/queue/SpscLinkedArrayQueue<TT;>;

  final io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber<?, K, T> parent;
    descriptor: Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
    flags: (0x0010) ACC_FINAL
    Signature: Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber<*TK;TT;>;

  final boolean delayError;
    descriptor: Z
    flags: (0x0010) ACC_FINAL

  final java.util.concurrent.atomic.AtomicLong requested;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0010) ACC_FINAL

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

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

  final java.util.concurrent.atomic.AtomicBoolean cancelled;
    descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
    flags: (0x0010) ACC_FINAL

  final java.util.concurrent.atomic.AtomicReference<org.reactivestreams.Subscriber<? super T>> actual;
    descriptor: Ljava/util/concurrent/atomic/AtomicReference;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReference<Lorg/reactivestreams/Subscriber<-TT;>;>;

  final java.util.concurrent.atomic.AtomicBoolean once;
    descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
    flags: (0x0010) ACC_FINAL

  boolean outputFused;
    descriptor: Z
    flags: (0x0000) 

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

  void <init>(int, io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber<?, K, T>, K, );
    descriptor: (ILio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;Ljava/lang/Object;Z)V
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
        start local 1 // int bufferSize
        start local 2 // io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber parent
        start local 3 // java.lang.Object key
        start local 4 // boolean delayError
         0: .line 503
            aload 0 /* this */
            invokespecial io.reactivex.internal.subscriptions.BasicIntQueueSubscription.<init>:()V
         1: .line 488
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.requested:Ljava/util/concurrent/atomic/AtomicLong;
         2: .line 493
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicBoolean
            dup
            invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.cancelled:Ljava/util/concurrent/atomic/AtomicBoolean;
         3: .line 495
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicReference
            dup
            invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
         4: .line 497
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicBoolean
            dup
            invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.once:Ljava/util/concurrent/atomic/AtomicBoolean;
         5: .line 504
            aload 0 /* this */
            new io.reactivex.internal.queue.SpscLinkedArrayQueue
            dup
            iload 1 /* bufferSize */
            invokespecial io.reactivex.internal.queue.SpscLinkedArrayQueue.<init>:(I)V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
         6: .line 505
            aload 0 /* this */
            aload 2 /* parent */
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.parent:Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
         7: .line 506
            aload 0 /* this */
            aload 3 /* key */
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.key:Ljava/lang/Object;
         8: .line 507
            aload 0 /* this */
            iload 4 /* delayError */
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.delayError:Z
         9: .line 508
            return
        end local 4 // boolean delayError
        end local 3 // java.lang.Object key
        end local 2 // io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber parent
        end local 1 // int bufferSize
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   10     0        this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            0   10     1  bufferSize  I
            0   10     2      parent  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber<*TK;TT;>;
            0   10     3         key  TK;
            0   10     4  delayError  Z
    Signature: (ILio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber<*TK;TT;>;TK;Z)V
    MethodParameters:
            Name  Flags
      bufferSize  
      parent      
      key         
      delayError  

  public void request(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
        start local 1 // long n
         0: .line 512
            lload 1 /* n */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(J)Z
            ifeq 3
         1: .line 513
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lload 1 /* n */
            invokestatic io.reactivex.internal.util.BackpressureHelper.add:(Ljava/util/concurrent/atomic/AtomicLong;J)J
            pop2
         2: .line 514
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
         3: .line 516
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long n
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            0    4     1     n  J
    MethodParameters:
      Name  Flags
      n     

  public void cancel();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
         0: .line 520
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.cancelled:Ljava/util/concurrent/atomic/AtomicBoolean;
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
            ifeq 2
         1: .line 521
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.parent:Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.key:Ljava/lang/Object;
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber.cancel:(Ljava/lang/Object;)V
         2: .line 523
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;

  public void subscribe(org.reactivestreams.Subscriber<? super T>);
    descriptor: (Lorg/reactivestreams/Subscriber;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
        start local 1 // org.reactivestreams.Subscriber s
         0: .line 527
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.once:Ljava/util/concurrent/atomic/AtomicBoolean;
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
            ifeq 5
         1: .line 528
            aload 1 /* s */
            aload 0 /* this */
            invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         2: .line 529
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
            aload 1 /* s */
            invokevirtual java.util.concurrent.atomic.AtomicReference.lazySet:(Ljava/lang/Object;)V
         3: .line 530
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
         4: .line 531
            goto 6
         5: .line 532
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            ldc "Only one Subscriber allowed!"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            aload 1 /* s */
            invokestatic io.reactivex.internal.subscriptions.EmptySubscription.error:(Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;)V
         6: .line 534
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscriber s
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            0    7     1     s  Lorg/reactivestreams/Subscriber<-TT;>;
    Signature: (Lorg/reactivestreams/Subscriber<-TT;>;)V
    MethodParameters:
      Name  Flags
      s     

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
        start local 1 // java.lang.Object t
         0: .line 537
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            aload 1 /* t */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.offer:(Ljava/lang/Object;)Z
            pop
         1: .line 538
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
         2: .line 539
            return
        end local 1 // java.lang.Object t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            0    3     1     t  TT;
    Signature: (TT;)V
    MethodParameters:
      Name  Flags
      t     

  public void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
        start local 1 // java.lang.Throwable e
         0: .line 542
            aload 0 /* this */
            aload 1 /* e */
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
         1: .line 543
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
         2: .line 544
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
         3: .line 545
            return
        end local 1 // java.lang.Throwable e
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            0    4     1     e  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      e     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
         0: .line 548
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
         1: .line 549
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
         2: .line 550
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;

  void drain();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
         0: .line 553
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.getAndIncrement:()I
            ifeq 2
         1: .line 554
            return
         2: .line 556
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.outputFused:Z
            ifeq 5
         3: .line 557
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drainFused:()V
         4: .line 558
            goto 6
         5: .line 559
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drainNormal:()V
         6: .line 561
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;

  void drainFused();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=6, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
         0: .line 564
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         1: .line 566
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            astore 2 /* q */
        start local 2 // io.reactivex.internal.queue.SpscLinkedArrayQueue q
         2: .line 567
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.reactivestreams.Subscriber
            astore 3 /* a */
        start local 3 // org.reactivestreams.Subscriber a
         3: .line 570
      StackMap locals: int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber
      StackMap stack:
            aload 3 /* a */
            ifnull 22
         4: .line 571
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.cancelled:Ljava/util/concurrent/atomic/AtomicBoolean;
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.get:()Z
            ifeq 7
         5: .line 572
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
         6: .line 573
            return
         7: .line 576
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
            istore 4 /* d */
        start local 4 // boolean d
         8: .line 578
            iload 4 /* d */
            ifeq 14
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.delayError:Z
            ifne 14
         9: .line 579
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
            astore 5 /* ex */
        start local 5 // java.lang.Throwable ex
        10: .line 580
            aload 5 /* ex */
            ifnull 14
        11: .line 581
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
        12: .line 582
            aload 3 /* a */
            aload 5 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        13: .line 583
            return
        end local 5 // java.lang.Throwable ex
        14: .line 587
      StackMap locals: int
      StackMap stack:
            aload 3 /* a */
            aconst_null
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        15: .line 589
            iload 4 /* d */
            ifeq 22
        16: .line 590
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
            astore 5 /* ex */
        start local 5 // java.lang.Throwable ex
        17: .line 591
            aload 5 /* ex */
            ifnull 20
        18: .line 592
            aload 3 /* a */
            aload 5 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        19: .line 593
            goto 21
        20: .line 594
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 3 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        21: .line 596
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.lang.Throwable ex
        end local 4 // boolean d
        22: .line 600
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.addAndGet:(I)I
            istore 1 /* missed */
        23: .line 601
            iload 1 /* missed */
            ifne 25
        24: .line 602
            return
        25: .line 605
      StackMap locals:
      StackMap stack:
            aload 3 /* a */
            ifnonnull 3
        26: .line 606
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.reactivestreams.Subscriber
            astore 3 /* a */
        27: .line 569
            goto 3
        end local 3 // org.reactivestreams.Subscriber a
        end local 2 // io.reactivex.internal.queue.SpscLinkedArrayQueue q
        end local 1 // int missed
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   28     0    this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            1   28     1  missed  I
            2   28     2       q  Lio/reactivex/internal/queue/SpscLinkedArrayQueue<TT;>;
            3   28     3       a  Lorg/reactivestreams/Subscriber<-TT;>;
            8   22     4       d  Z
           10   14     5      ex  Ljava/lang/Throwable;
           17   22     5      ex  Ljava/lang/Throwable;

  void drainNormal();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=12, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
         0: .line 612
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         1: .line 614
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            astore 2 /* q */
        start local 2 // io.reactivex.internal.queue.SpscLinkedArrayQueue q
         2: .line 615
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.delayError:Z
            istore 3 /* delayError */
        start local 3 // boolean delayError
         3: .line 616
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.reactivestreams.Subscriber
            astore 4 /* a */
        start local 4 // org.reactivestreams.Subscriber a
         4: .line 618
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupBy$State int io.reactivex.internal.queue.SpscLinkedArrayQueue int org.reactivestreams.Subscriber
      StackMap stack:
            aload 4 /* a */
            ifnull 26
         5: .line 619
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.requested:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            lstore 5 /* r */
        start local 5 // long r
         6: .line 620
            lconst_0
            lstore 7 /* e */
        start local 7 // long e
         7: .line 622
            goto 19
         8: .line 623
      StackMap locals: long long
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
            istore 9 /* d */
        start local 9 // boolean d
         9: .line 624
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.poll:()Ljava/lang/Object;
            astore 10 /* v */
        start local 10 // java.lang.Object v
        10: .line 625
            aload 10 /* v */
            ifnonnull 11
            iconst_1
            goto 12
      StackMap locals: int java.lang.Object
      StackMap stack:
        11: iconst_0
      StackMap locals:
      StackMap stack: int
        12: istore 11 /* empty */
        start local 11 // boolean empty
        13: .line 627
            aload 0 /* this */
            iload 9 /* d */
            iload 11 /* empty */
            aload 4 /* a */
            iload 3 /* delayError */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.checkTerminated:(ZZLorg/reactivestreams/Subscriber;Z)Z
            ifeq 15
        14: .line 628
            return
        15: .line 631
      StackMap locals: int
      StackMap stack:
            iload 11 /* empty */
            ifeq 17
        16: .line 632
            goto 20
        17: .line 635
      StackMap locals:
      StackMap stack:
            aload 4 /* a */
            aload 10 /* v */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        18: .line 637
            lload 7 /* e */
            lconst_1
            ladd
            lstore 7 /* e */
        end local 11 // boolean empty
        end local 10 // java.lang.Object v
        end local 9 // boolean d
        19: .line 622
      StackMap locals:
      StackMap stack:
            lload 7 /* e */
            lload 5 /* r */
            lcmp
            ifne 8
        20: .line 640
      StackMap locals:
      StackMap stack:
            lload 7 /* e */
            lload 5 /* r */
            lcmp
            ifne 22
            aload 0 /* this */
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.isEmpty:()Z
            aload 4 /* a */
            iload 3 /* delayError */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.checkTerminated:(ZZLorg/reactivestreams/Subscriber;Z)Z
            ifeq 22
        21: .line 641
            return
        22: .line 644
      StackMap locals:
      StackMap stack:
            lload 7 /* e */
            lconst_0
            lcmp
            ifeq 26
        23: .line 645
            lload 5 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 25
        24: .line 646
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lload 7 /* e */
            lneg
            invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
            pop2
        25: .line 648
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.parent:Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber.upstream:Lorg/reactivestreams/Subscription;
            lload 7 /* e */
            invokeinterface org.reactivestreams.Subscription.request:(J)V
        end local 7 // long e
        end local 5 // long r
        26: .line 652
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.addAndGet:(I)I
            istore 1 /* missed */
        27: .line 653
            iload 1 /* missed */
            ifne 29
        28: .line 654
            goto 32
        29: .line 656
      StackMap locals:
      StackMap stack:
            aload 4 /* a */
            ifnonnull 4
        30: .line 657
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.reactivestreams.Subscriber
            astore 4 /* a */
        31: .line 617
            goto 4
        32: .line 660
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.reactivestreams.Subscriber a
        end local 3 // boolean delayError
        end local 2 // io.reactivex.internal.queue.SpscLinkedArrayQueue q
        end local 1 // int missed
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   33     0        this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            1   33     1      missed  I
            2   33     2           q  Lio/reactivex/internal/queue/SpscLinkedArrayQueue<TT;>;
            3   33     3  delayError  Z
            4   33     4           a  Lorg/reactivestreams/Subscriber<-TT;>;
            6   26     5           r  J
            7   26     7           e  J
            9   19     9           d  Z
           10   19    10           v  TT;
           13   19    11       empty  Z

  boolean checkTerminated(boolean, boolean, org.reactivestreams.Subscriber<? super T>, );
    descriptor: (ZZLorg/reactivestreams/Subscriber;Z)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=6, args_size=5
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
        start local 1 // boolean d
        start local 2 // boolean empty
        start local 3 // org.reactivestreams.Subscriber a
        start local 4 // boolean delayError
         0: .line 663
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.cancelled:Ljava/util/concurrent/atomic/AtomicBoolean;
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.get:()Z
            ifeq 3
         1: .line 664
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
         2: .line 665
            iconst_1
            ireturn
         3: .line 668
      StackMap locals:
      StackMap stack:
            iload 1 /* d */
            ifeq 20
         4: .line 669
            iload 4 /* delayError */
            ifeq 12
         5: .line 670
            iload 2 /* empty */
            ifeq 20
         6: .line 671
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
            astore 5 /* e */
        start local 5 // java.lang.Throwable e
         7: .line 672
            aload 5 /* e */
            ifnull 10
         8: .line 673
            aload 3 /* a */
            aload 5 /* e */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         9: .line 674
            goto 11
        10: .line 675
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 3 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        11: .line 677
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 5 // java.lang.Throwable e
        12: .line 680
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
            astore 5 /* e */
        start local 5 // java.lang.Throwable e
        13: .line 681
            aload 5 /* e */
            ifnull 17
        14: .line 682
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
        15: .line 683
            aload 3 /* a */
            aload 5 /* e */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        16: .line 684
            iconst_1
            ireturn
        17: .line 686
      StackMap locals: java.lang.Throwable
      StackMap stack:
            iload 2 /* empty */
            ifeq 20
        18: .line 687
            aload 3 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        19: .line 688
            iconst_1
            ireturn
        end local 5 // java.lang.Throwable e
        20: .line 693
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // boolean delayError
        end local 3 // org.reactivestreams.Subscriber a
        end local 2 // boolean empty
        end local 1 // boolean d
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   21     0        this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            0   21     1           d  Z
            0   21     2       empty  Z
            0   21     3           a  Lorg/reactivestreams/Subscriber<-TT;>;
            0   21     4  delayError  Z
            7   12     5           e  Ljava/lang/Throwable;
           13   20     5           e  Ljava/lang/Throwable;
    Signature: (ZZLorg/reactivestreams/Subscriber<-TT;>;Z)Z
    MethodParameters:
            Name  Flags
      d           
      empty       
      a           
      delayError  

  public int requestFusion(int);
    descriptor: (I)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
        start local 1 // int mode
         0: .line 698
            iload 1 /* mode */
            iconst_2
            iand
            ifeq 3
         1: .line 699
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.outputFused:Z
         2: .line 700
            iconst_2
            ireturn
         3: .line 702
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // int mode
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            0    4     1  mode  I
    MethodParameters:
      Name  Flags
      mode  

  public T poll();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
         0: .line 708
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.poll:()Ljava/lang/Object;
            astore 1 /* v */
        start local 1 // java.lang.Object v
         1: .line 709
            aload 1 /* v */
            ifnull 4
         2: .line 710
            aload 0 /* this */
            dup
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.produced:I
            iconst_1
            iadd
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.produced:I
         3: .line 711
            aload 1 /* v */
            areturn
         4: .line 713
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.produced:I
            istore 2 /* p */
        start local 2 // int p
         5: .line 714
            iload 2 /* p */
            ifeq 8
         6: .line 715
            aload 0 /* this */
            iconst_0
            putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.produced:I
         7: .line 716
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.parent:Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber.upstream:Lorg/reactivestreams/Subscription;
            iload 2 /* p */
            i2l
            invokeinterface org.reactivestreams.Subscription.request:(J)V
         8: .line 718
      StackMap locals: int
      StackMap stack:
            aconst_null
            areturn
        end local 2 // int p
        end local 1 // java.lang.Object v
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
            1    9     1     v  TT;
            5    9     2     p  I
    Signature: ()TT;
    RuntimeInvisibleAnnotations: 
      io.reactivex.annotations.Nullable()

  public boolean isEmpty();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
         0: .line 723
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.isEmpty:()Z
            ireturn
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
         0: .line 728
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
         1: .line 729
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupBy$State this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
}
Signature: <T:Ljava/lang/Object;K:Ljava/lang/Object;>Lio/reactivex/internal/subscriptions/BasicIntQueueSubscription<TT;>;Lorg/reactivestreams/Publisher<TT;>;
SourceFile: "FlowableGroupBy.java"
NestHost: io.reactivex.internal.operators.flowable.FlowableGroupBy
InnerClasses:
  public final GroupBySubscriber = io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber of io.reactivex.internal.operators.flowable.FlowableGroupBy
  final State = io.reactivex.internal.operators.flowable.FlowableGroupBy$State of io.reactivex.internal.operators.flowable.FlowableGroupBy