public class org.apache.lucene.search.grouping.BlockGroupingCollector extends org.apache.lucene.search.SimpleCollector
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.lucene.search.grouping.BlockGroupingCollector
  super_class: org.apache.lucene.search.SimpleCollector
{
  private int[] pendingSubDocs;
    descriptor: [I
    flags: (0x0002) ACC_PRIVATE

  private float[] pendingSubScores;
    descriptor: [F
    flags: (0x0002) ACC_PRIVATE

  private int subDocUpto;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private final org.apache.lucene.search.Sort groupSort;
    descriptor: Lorg/apache/lucene/search/Sort;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final int topNGroups;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.lucene.search.Weight lastDocPerGroup;
    descriptor: Lorg/apache/lucene/search/Weight;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final boolean needsScores;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.lucene.search.FieldComparator<?>[] comparators;
    descriptor: [Lorg/apache/lucene/search/FieldComparator;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: [Lorg/apache/lucene/search/FieldComparator<*>;

  private final org.apache.lucene.search.LeafFieldComparator[] leafComparators;
    descriptor: [Lorg/apache/lucene/search/LeafFieldComparator;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final int[] reversed;
    descriptor: [I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final int compIDXEnd;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private int bottomSlot;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private boolean queueFull;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private org.apache.lucene.index.LeafReaderContext currentReaderContext;
    descriptor: Lorg/apache/lucene/index/LeafReaderContext;
    flags: (0x0002) ACC_PRIVATE

  private int topGroupDoc;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int totalHitCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int totalGroupCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int docBase;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int groupEndDocID;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private org.apache.lucene.search.DocIdSetIterator lastDocPerGroupBits;
    descriptor: Lorg/apache/lucene/search/DocIdSetIterator;
    flags: (0x0002) ACC_PRIVATE

  private org.apache.lucene.search.Scorable scorer;
    descriptor: Lorg/apache/lucene/search/Scorable;
    flags: (0x0002) ACC_PRIVATE

  private final org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue groupQueue;
    descriptor: Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private boolean groupCompetes;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 70
            ldc Lorg/apache/lucene/search/grouping/BlockGroupingCollector;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.apache.lucene.search.grouping.BlockGroupingCollector.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void processGroup();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
         0: .line 142
            aload 0 /* this */
            dup
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.totalGroupCount:I
            iconst_1
            iadd
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.totalGroupCount:I
         1: .line 144
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupCompetes:Z
            ifeq 45
         2: .line 145
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.queueFull:Z
            ifne 27
         3: .line 147
            new org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
            dup
            invokespecial org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.<init>:()V
            astore 1 /* og */
        start local 1 // org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup og
         4: .line 148
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.count:I
         5: .line 149
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.docBase:I
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.topGroupDoc:I
            iadd
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.topGroupDoc:I
         6: .line 150
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.docs:[I
         7: .line 151
            aload 0 /* this */
            bipush 10
            newarray 10
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
         8: .line 152
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.needsScores:Z
            ifeq 11
         9: .line 153
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.scores:[F
        10: .line 154
            aload 0 /* this */
            bipush 10
            newarray 6
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
        11: .line 156
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
      StackMap stack:
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.currentReaderContext:Lorg/apache/lucene/index/LeafReaderContext;
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.readerContext:Lorg/apache/lucene/index/LeafReaderContext;
        12: .line 158
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.comparatorSlot:I
        13: .line 159
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            aload 1 /* og */
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.add:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
            astore 2 /* bottomGroup */
        start local 2 // org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup bottomGroup
        14: .line 161
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.size:()I
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.topNGroups:I
            if_icmpne 15
            iconst_1
            goto 16
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
      StackMap stack: org.apache.lucene.search.grouping.BlockGroupingCollector
        15: iconst_0
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
      StackMap stack: org.apache.lucene.search.grouping.BlockGroupingCollector int
        16: putfield org.apache.lucene.search.grouping.BlockGroupingCollector.queueFull:Z
        17: .line 162
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.queueFull:Z
            ifeq 25
        18: .line 165
            aload 0 /* this */
            aload 2 /* bottomGroup */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.comparatorSlot:I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
        19: .line 167
            iconst_0
            istore 3 /* i */
        start local 3 // int i
        20: goto 23
        21: .line 168
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            iload 3 /* i */
            aaload
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            invokeinterface org.apache.lucene.search.LeafFieldComparator.setBottom:(I)V
        22: .line 167
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        23: iload 3 /* i */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            arraylength
            if_icmplt 21
        end local 3 // int i
        24: .line 171
            goto 45
        25: .line 173
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.size:()I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
        end local 2 // org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup bottomGroup
        end local 1 // org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup og
        26: .line 175
            goto 45
        27: .line 177
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.top:()Ljava/lang/Object;
            checkcast org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
            astore 1 /* og */
        start local 1 // org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup og
        28: .line 178
            getstatic org.apache.lucene.search.grouping.BlockGroupingCollector.$assertionsDisabled:Z
            ifne 29
            aload 1 /* og */
            ifnonnull 29
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        29: .line 179
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
      StackMap stack:
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.count:I
        30: .line 180
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.docBase:I
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.topGroupDoc:I
            iadd
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.topGroupDoc:I
        31: .line 182
            aload 1 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.docs:[I
            astore 2 /* savDocs */
        start local 2 // int[] savDocs
        32: .line 183
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.docs:[I
        33: .line 184
            aload 0 /* this */
            aload 2 /* savDocs */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
        34: .line 185
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.needsScores:Z
            ifeq 38
        35: .line 187
            aload 1 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.scores:[F
            astore 3 /* savScores */
        start local 3 // float[] savScores
        36: .line 188
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.scores:[F
        37: .line 189
            aload 0 /* this */
            aload 3 /* savScores */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
        end local 3 // float[] savScores
        38: .line 191
      StackMap locals: int[]
      StackMap stack:
            aload 1 /* og */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.currentReaderContext:Lorg/apache/lucene/index/LeafReaderContext;
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.readerContext:Lorg/apache/lucene/index/LeafReaderContext;
        39: .line 193
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.updateTop:()Ljava/lang/Object;
            checkcast org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.comparatorSlot:I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
        40: .line 196
            iconst_0
            istore 3 /* i */
        start local 3 // int i
        41: goto 44
        42: .line 197
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            iload 3 /* i */
            aaload
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            invokeinterface org.apache.lucene.search.LeafFieldComparator.setBottom:(I)V
        43: .line 196
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        44: iload 3 /* i */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            arraylength
            if_icmplt 42
        end local 3 // int i
        end local 2 // int[] savDocs
        end local 1 // org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup og
        45: .line 201
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
        46: .line 202
            return
        end local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   47     0         this  Lorg/apache/lucene/search/grouping/BlockGroupingCollector;
            4   26     1           og  Lorg/apache/lucene/search/grouping/BlockGroupingCollector$OneGroup;
           14   26     2  bottomGroup  Lorg/apache/lucene/search/grouping/BlockGroupingCollector$OneGroup;
           20   24     3            i  I
           28   45     1           og  Lorg/apache/lucene/search/grouping/BlockGroupingCollector$OneGroup;
           32   45     2      savDocs  [I
           36   38     3    savScores  [F
           41   45     3            i  I
    Exceptions:
      throws java.io.IOException

  public void <init>(org.apache.lucene.search.Sort, int, boolean, org.apache.lucene.search.Weight);
    descriptor: (Lorg/apache/lucene/search/Sort;IZLorg/apache/lucene/search/Weight;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=8, args_size=5
        start local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
        start local 1 // org.apache.lucene.search.Sort groupSort
        start local 2 // int topNGroups
        start local 3 // boolean needsScores
        start local 4 // org.apache.lucene.search.Weight lastDocPerGroup
         0: .line 222
            aload 0 /* this */
            invokespecial org.apache.lucene.search.SimpleCollector.<init>:()V
         1: .line 224
            iload 2 /* topNGroups */
            iconst_1
            if_icmpge 3
         2: .line 225
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "topNGroups must be >= 1 (got "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 2 /* topNGroups */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 228
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.Sort int int org.apache.lucene.search.Weight
      StackMap stack:
            aload 0 /* this */
            new org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue
            dup
            aload 0 /* this */
            iload 2 /* topNGroups */
            invokespecial org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.<init>:(Lorg/apache/lucene/search/grouping/BlockGroupingCollector;I)V
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
         4: .line 229
            aload 0 /* this */
            bipush 10
            newarray 10
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
         5: .line 230
            iload 3 /* needsScores */
            ifeq 7
         6: .line 231
            aload 0 /* this */
            bipush 10
            newarray 6
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
         7: .line 234
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 3 /* needsScores */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.needsScores:Z
         8: .line 235
            aload 0 /* this */
            aload 4 /* lastDocPerGroup */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.lastDocPerGroup:Lorg/apache/lucene/search/Weight;
         9: .line 237
            aload 0 /* this */
            aload 1 /* groupSort */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupSort:Lorg/apache/lucene/search/Sort;
        10: .line 239
            aload 0 /* this */
            iload 2 /* topNGroups */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.topNGroups:I
        11: .line 241
            aload 1 /* groupSort */
            invokevirtual org.apache.lucene.search.Sort.getSort:()[Lorg/apache/lucene/search/SortField;
            astore 5 /* sortFields */
        start local 5 // org.apache.lucene.search.SortField[] sortFields
        12: .line 242
            aload 0 /* this */
            aload 5 /* sortFields */
            arraylength
            anewarray org.apache.lucene.search.FieldComparator
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
        13: .line 243
            aload 0 /* this */
            aload 5 /* sortFields */
            arraylength
            anewarray org.apache.lucene.search.LeafFieldComparator
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
        14: .line 244
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            arraylength
            iconst_1
            isub
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.compIDXEnd:I
        15: .line 245
            aload 0 /* this */
            aload 5 /* sortFields */
            arraylength
            newarray 10
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.reversed:[I
        16: .line 246
            iconst_0
            istore 6 /* i */
        start local 6 // int i
        17: goto 24
        18: .line 247
      StackMap locals: org.apache.lucene.search.SortField[] int
      StackMap stack:
            aload 5 /* sortFields */
            iload 6 /* i */
            aaload
            astore 7 /* sortField */
        start local 7 // org.apache.lucene.search.SortField sortField
        19: .line 248
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            iload 6 /* i */
            aload 7 /* sortField */
            iload 2 /* topNGroups */
            iload 6 /* i */
            invokevirtual org.apache.lucene.search.SortField.getComparator:(II)Lorg/apache/lucene/search/FieldComparator;
            aastore
        20: .line 249
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.reversed:[I
            iload 6 /* i */
            aload 7 /* sortField */
            invokevirtual org.apache.lucene.search.SortField.getReverse:()Z
            ifeq 21
            iconst_m1
            goto 22
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.Sort int int org.apache.lucene.search.Weight org.apache.lucene.search.SortField[] int org.apache.lucene.search.SortField
      StackMap stack: int[] int
        21: iconst_1
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.Sort int int org.apache.lucene.search.Weight org.apache.lucene.search.SortField[] int org.apache.lucene.search.SortField
      StackMap stack: int[] int int
        22: iastore
        end local 7 // org.apache.lucene.search.SortField sortField
        23: .line 246
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        24: iload 6 /* i */
            aload 5 /* sortFields */
            arraylength
            if_icmplt 18
        end local 6 // int i
        25: .line 251
            return
        end local 5 // org.apache.lucene.search.SortField[] sortFields
        end local 4 // org.apache.lucene.search.Weight lastDocPerGroup
        end local 3 // boolean needsScores
        end local 2 // int topNGroups
        end local 1 // org.apache.lucene.search.Sort groupSort
        end local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   26     0             this  Lorg/apache/lucene/search/grouping/BlockGroupingCollector;
            0   26     1        groupSort  Lorg/apache/lucene/search/Sort;
            0   26     2       topNGroups  I
            0   26     3      needsScores  Z
            0   26     4  lastDocPerGroup  Lorg/apache/lucene/search/Weight;
           12   26     5       sortFields  [Lorg/apache/lucene/search/SortField;
           17   25     6                i  I
           19   23     7        sortField  Lorg/apache/lucene/search/SortField;
    MethodParameters:
                 Name  Flags
      groupSort        
      topNGroups       
      needsScores      
      lastDocPerGroup  

  public org.apache.lucene.search.grouping.TopGroups<?> getTopGroups(org.apache.lucene.search.Sort, int, int, int);
    descriptor: (Lorg/apache/lucene/search/Sort;III)Lorg/apache/lucene/search/grouping/TopGroups;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=11, locals=16, args_size=5
        start local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
        start local 1 // org.apache.lucene.search.Sort withinGroupSort
        start local 2 // int groupOffset
        start local 3 // int withinGroupOffset
        start local 4 // int maxDocsPerGroup
         0: .line 281
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            ifeq 2
         1: .line 282
            aload 0 /* this */
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector.processGroup:()V
         2: .line 284
      StackMap locals:
      StackMap stack:
            iload 2 /* groupOffset */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.size:()I
            if_icmplt 4
         3: .line 285
            aconst_null
            areturn
         4: .line 287
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 5 /* totalGroupedHitCount */
        start local 5 // int totalGroupedHitCount
         5: .line 289
            new org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc
            dup
            invokespecial org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc.<init>:()V
            astore 6 /* fakeScorer */
        start local 6 // org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc fakeScorer
         6: .line 291
            ldc 1.4E-45
            fstore 7 /* maxScore */
        start local 7 // float maxScore
         7: .line 294
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.size:()I
            iload 2 /* groupOffset */
            isub
            anewarray org.apache.lucene.search.grouping.GroupDocs
            astore 8 /* groups */
        start local 8 // org.apache.lucene.search.grouping.GroupDocs[] groups
         8: .line 295
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.size:()I
            iload 2 /* groupOffset */
            isub
            iconst_1
            isub
            istore 9 /* downTo */
        start local 9 // int downTo
         9: goto 49
        10: .line 296
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.Sort int int int int org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc float org.apache.lucene.search.grouping.GroupDocs[] int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupQueue:Lorg/apache/lucene/search/grouping/BlockGroupingCollector$GroupQueue;
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue.pop:()Ljava/lang/Object;
            checkcast org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
            astore 10 /* og */
        start local 10 // org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup og
        11: .line 301
            aload 1 /* withinGroupSort */
            getstatic org.apache.lucene.search.Sort.RELEVANCE:Lorg/apache/lucene/search/Sort;
            invokevirtual org.apache.lucene.search.Sort.equals:(Ljava/lang/Object;)Z
            ifeq 16
        12: .line 303
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.needsScores:Z
            ifne 14
        13: .line 304
            new java.lang.IllegalArgumentException
            dup
            ldc "cannot sort by relevance within group: needsScores=false"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 306
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup
      StackMap stack:
            iload 4 /* maxDocsPerGroup */
            ldc 2147483647
            invokestatic org.apache.lucene.search.TopScoreDocCollector.create:(II)Lorg/apache/lucene/search/TopScoreDocCollector;
            astore 11 /* collector */
        start local 11 // org.apache.lucene.search.TopDocsCollector collector
        15: .line 307
            goto 17
        end local 11 // org.apache.lucene.search.TopDocsCollector collector
        16: .line 309
      StackMap locals:
      StackMap stack:
            aload 1 /* withinGroupSort */
            iload 4 /* maxDocsPerGroup */
            ldc 2147483647
            invokestatic org.apache.lucene.search.TopFieldCollector.create:(Lorg/apache/lucene/search/Sort;II)Lorg/apache/lucene/search/TopFieldCollector;
            astore 11 /* collector */
        start local 11 // org.apache.lucene.search.TopDocsCollector collector
        17: .line 312
      StackMap locals: org.apache.lucene.search.TopDocsCollector
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.needsScores:Z
            ifeq 18
            ldc -Infinity
            goto 19
      StackMap locals:
      StackMap stack:
        18: ldc NaN
      StackMap locals:
      StackMap stack: float
        19: fstore 12 /* groupMaxScore */
        start local 12 // float groupMaxScore
        20: .line 313
            aload 11 /* collector */
            aload 10 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.readerContext:Lorg/apache/lucene/index/LeafReaderContext;
            invokevirtual org.apache.lucene.search.TopDocsCollector.getLeafCollector:(Lorg/apache/lucene/index/LeafReaderContext;)Lorg/apache/lucene/search/LeafCollector;
            astore 13 /* leafCollector */
        start local 13 // org.apache.lucene.search.LeafCollector leafCollector
        21: .line 314
            aload 13 /* leafCollector */
            aload 6 /* fakeScorer */
            invokeinterface org.apache.lucene.search.LeafCollector.setScorer:(Lorg/apache/lucene/search/Scorable;)V
        22: .line 315
            iconst_0
            istore 14 /* docIDX */
        start local 14 // int docIDX
        23: goto 31
        24: .line 316
      StackMap locals: float org.apache.lucene.search.LeafCollector int
      StackMap stack:
            aload 10 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.docs:[I
            iload 14 /* docIDX */
            iaload
            istore 15 /* doc */
        start local 15 // int doc
        25: .line 317
            aload 6 /* fakeScorer */
            iload 15 /* doc */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc.doc:I
        26: .line 318
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.needsScores:Z
            ifeq 29
        27: .line 319
            aload 6 /* fakeScorer */
            aload 10 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.scores:[F
            iload 14 /* docIDX */
            faload
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc.score:F
        28: .line 320
            fload 12 /* groupMaxScore */
            aload 6 /* fakeScorer */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc.score:F
            invokestatic java.lang.Math.max:(FF)F
            fstore 12 /* groupMaxScore */
        29: .line 322
      StackMap locals: int
      StackMap stack:
            aload 13 /* leafCollector */
            iload 15 /* doc */
            invokeinterface org.apache.lucene.search.LeafCollector.collect:(I)V
        end local 15 // int doc
        30: .line 315
            iinc 14 /* docIDX */ 1
      StackMap locals:
      StackMap stack:
        31: iload 14 /* docIDX */
            aload 10 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.count:I
            if_icmplt 24
        end local 14 // int docIDX
        32: .line 324
            iload 5 /* totalGroupedHitCount */
            aload 10 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.count:I
            iadd
            istore 5 /* totalGroupedHitCount */
        33: .line 328
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            arraylength
            anewarray java.lang.Comparable
            astore 14 /* groupSortValues */
        start local 14 // java.lang.Object[] groupSortValues
        34: .line 329
            iconst_0
            istore 15 /* sortFieldIDX */
        start local 15 // int sortFieldIDX
        35: goto 38
        36: .line 330
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.Sort int int int int org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc float org.apache.lucene.search.grouping.GroupDocs[] int org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup org.apache.lucene.search.TopDocsCollector float org.apache.lucene.search.LeafCollector java.lang.Object[] int
      StackMap stack:
            aload 14 /* groupSortValues */
            iload 15 /* sortFieldIDX */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            iload 15 /* sortFieldIDX */
            aaload
            aload 10 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.comparatorSlot:I
            invokevirtual org.apache.lucene.search.FieldComparator.value:(I)Ljava/lang/Object;
            aastore
        37: .line 329
            iinc 15 /* sortFieldIDX */ 1
      StackMap locals:
      StackMap stack:
        38: iload 15 /* sortFieldIDX */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            arraylength
            if_icmplt 36
        end local 15 // int sortFieldIDX
        39: .line 333
            aload 11 /* collector */
            iload 3 /* withinGroupOffset */
            iload 4 /* maxDocsPerGroup */
            invokevirtual org.apache.lucene.search.TopDocsCollector.topDocs:(II)Lorg/apache/lucene/search/TopDocs;
            astore 15 /* topDocs */
        start local 15 // org.apache.lucene.search.TopDocs topDocs
        40: .line 337
            aload 8 /* groups */
            iload 9 /* downTo */
            new org.apache.lucene.search.grouping.GroupDocs
            dup
            ldc NaN
        41: .line 338
            fload 12 /* groupMaxScore */
        42: .line 339
            new org.apache.lucene.search.TotalHits
            dup
            aload 10 /* og */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup.count:I
            i2l
            getstatic org.apache.lucene.search.TotalHits$Relation.EQUAL_TO:Lorg/apache/lucene/search/TotalHits$Relation;
            invokespecial org.apache.lucene.search.TotalHits.<init>:(JLorg/apache/lucene/search/TotalHits$Relation;)V
        43: .line 340
            aload 15 /* topDocs */
            getfield org.apache.lucene.search.TopDocs.scoreDocs:[Lorg/apache/lucene/search/ScoreDoc;
        44: .line 341
            aconst_null
        45: .line 342
            aload 14 /* groupSortValues */
            invokespecial org.apache.lucene.search.grouping.GroupDocs.<init>:(FFLorg/apache/lucene/search/TotalHits;[Lorg/apache/lucene/search/ScoreDoc;Ljava/lang/Object;[Ljava/lang/Object;)V
        46: .line 337
            aastore
        47: .line 343
            fload 7 /* maxScore */
            fload 12 /* groupMaxScore */
            invokestatic java.lang.Math.max:(FF)F
            fstore 7 /* maxScore */
        end local 15 // org.apache.lucene.search.TopDocs topDocs
        end local 14 // java.lang.Object[] groupSortValues
        end local 13 // org.apache.lucene.search.LeafCollector leafCollector
        end local 12 // float groupMaxScore
        end local 11 // org.apache.lucene.search.TopDocsCollector collector
        end local 10 // org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup og
        48: .line 295
            iinc 9 /* downTo */ -1
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.Sort int int int int org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc float org.apache.lucene.search.grouping.GroupDocs[] int
      StackMap stack:
        49: iload 9 /* downTo */
            ifge 10
        end local 9 // int downTo
        50: .line 354
            new org.apache.lucene.search.grouping.TopGroups
            dup
            new org.apache.lucene.search.grouping.TopGroups
            dup
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupSort:Lorg/apache/lucene/search/Sort;
            invokevirtual org.apache.lucene.search.Sort.getSort:()[Lorg/apache/lucene/search/SortField;
        51: .line 355
            aload 1 /* withinGroupSort */
            invokevirtual org.apache.lucene.search.Sort.getSort:()[Lorg/apache/lucene/search/SortField;
        52: .line 356
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.totalHitCount:I
            iload 5 /* totalGroupedHitCount */
            aload 8 /* groups */
            fload 7 /* maxScore */
            invokespecial org.apache.lucene.search.grouping.TopGroups.<init>:([Lorg/apache/lucene/search/SortField;[Lorg/apache/lucene/search/SortField;II[Lorg/apache/lucene/search/grouping/GroupDocs;F)V
        53: .line 357
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.totalGroupCount:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
        54: .line 354
            invokespecial org.apache.lucene.search.grouping.TopGroups.<init>:(Lorg/apache/lucene/search/grouping/TopGroups;Ljava/lang/Integer;)V
            areturn
        end local 8 // org.apache.lucene.search.grouping.GroupDocs[] groups
        end local 7 // float maxScore
        end local 6 // org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc fakeScorer
        end local 5 // int totalGroupedHitCount
        end local 4 // int maxDocsPerGroup
        end local 3 // int withinGroupOffset
        end local 2 // int groupOffset
        end local 1 // org.apache.lucene.search.Sort withinGroupSort
        end local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   55     0                  this  Lorg/apache/lucene/search/grouping/BlockGroupingCollector;
            0   55     1       withinGroupSort  Lorg/apache/lucene/search/Sort;
            0   55     2           groupOffset  I
            0   55     3     withinGroupOffset  I
            0   55     4       maxDocsPerGroup  I
            5   55     5  totalGroupedHitCount  I
            6   55     6            fakeScorer  Lorg/apache/lucene/search/grouping/BlockGroupingCollector$ScoreAndDoc;
            7   55     7              maxScore  F
            8   55     8                groups  [Lorg/apache/lucene/search/grouping/GroupDocs;
            9   50     9                downTo  I
           11   48    10                    og  Lorg/apache/lucene/search/grouping/BlockGroupingCollector$OneGroup;
           15   16    11             collector  Lorg/apache/lucene/search/TopDocsCollector<*>;
           17   48    11             collector  Lorg/apache/lucene/search/TopDocsCollector<*>;
           20   48    12         groupMaxScore  F
           21   48    13         leafCollector  Lorg/apache/lucene/search/LeafCollector;
           23   32    14                docIDX  I
           25   30    15                   doc  I
           34   48    14       groupSortValues  [Ljava/lang/Object;
           35   39    15          sortFieldIDX  I
           40   48    15               topDocs  Lorg/apache/lucene/search/TopDocs;
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/apache/lucene/search/Sort;III)Lorg/apache/lucene/search/grouping/TopGroups<*>;
    MethodParameters:
                   Name  Flags
      withinGroupSort    
      groupOffset        
      withinGroupOffset  
      maxDocsPerGroup    

  public void setScorer(org.apache.lucene.search.Scorable);
    descriptor: (Lorg/apache/lucene/search/Scorable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=2
        start local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
        start local 1 // org.apache.lucene.search.Scorable scorer
         0: .line 362
            aload 0 /* this */
            aload 1 /* scorer */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.scorer:Lorg/apache/lucene/search/Scorable;
         1: .line 363
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 5
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector org.apache.lucene.search.Scorable top int int org.apache.lucene.search.LeafFieldComparator[]
      StackMap stack:
         2: aload 5
            iload 3
            aaload
            astore 2 /* comparator */
        start local 2 // org.apache.lucene.search.LeafFieldComparator comparator
         3: .line 364
            aload 2 /* comparator */
            aload 1 /* scorer */
            invokeinterface org.apache.lucene.search.LeafFieldComparator.setScorer:(Lorg/apache/lucene/search/Scorable;)V
        end local 2 // org.apache.lucene.search.LeafFieldComparator comparator
         4: .line 363
            iinc 3 1
      StackMap locals:
      StackMap stack:
         5: iload 3
            iload 4
            if_icmplt 2
         6: .line 366
            return
        end local 1 // org.apache.lucene.search.Scorable scorer
        end local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    7     0        this  Lorg/apache/lucene/search/grouping/BlockGroupingCollector;
            0    7     1      scorer  Lorg/apache/lucene/search/Scorable;
            3    4     2  comparator  Lorg/apache/lucene/search/LeafFieldComparator;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
        Name  Flags
      scorer  

  public void collect(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=2
        start local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
        start local 1 // int doc
         0: .line 373
            iload 1 /* doc */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupEndDocID:I
            if_icmple 8
         1: .line 375
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            ifeq 3
         2: .line 376
            aload 0 /* this */
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector.processGroup:()V
         3: .line 378
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.lastDocPerGroupBits:Lorg/apache/lucene/search/DocIdSetIterator;
            iload 1 /* doc */
            invokevirtual org.apache.lucene.search.DocIdSetIterator.advance:(I)I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupEndDocID:I
         4: .line 380
            aload 0 /* this */
            iconst_0
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
         5: .line 381
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.queueFull:Z
            ifeq 6
            iconst_0
            goto 7
      StackMap locals:
      StackMap stack: org.apache.lucene.search.grouping.BlockGroupingCollector
         6: iconst_1
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector int
      StackMap stack: org.apache.lucene.search.grouping.BlockGroupingCollector int
         7: putfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupCompetes:Z
         8: .line 384
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.totalHitCount:I
            iconst_1
            iadd
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.totalHitCount:I
         9: .line 387
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
            arraylength
            if_icmpne 11
        10: .line 388
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
            invokestatic org.apache.lucene.util.ArrayUtil.grow:([I)[I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
        11: .line 390
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubDocs:[I
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            iload 1 /* doc */
            iastore
        12: .line 391
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.needsScores:Z
            ifeq 16
        13: .line 392
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
            arraylength
            if_icmpne 15
        14: .line 393
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
            invokestatic org.apache.lucene.util.ArrayUtil.grow:([F)[F
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
        15: .line 395
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.pendingSubScores:[F
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.scorer:Lorg/apache/lucene/search/Scorable;
            invokevirtual org.apache.lucene.search.Scorable.score:()F
            fastore
        16: .line 397
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            iconst_1
            iadd
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
        17: .line 399
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupCompetes:Z
            ifeq 45
        18: .line 400
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            iconst_1
            if_icmpne 28
        19: .line 401
            getstatic org.apache.lucene.search.grouping.BlockGroupingCollector.$assertionsDisabled:Z
            ifne 20
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.queueFull:Z
            ifeq 20
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        20: .line 404
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 25
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector int top int int org.apache.lucene.search.LeafFieldComparator[]
      StackMap stack:
        21: aload 5
            iload 3
            aaload
            astore 2 /* fc */
        start local 2 // org.apache.lucene.search.LeafFieldComparator fc
        22: .line 405
            aload 2 /* fc */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            iload 1 /* doc */
            invokeinterface org.apache.lucene.search.LeafFieldComparator.copy:(II)V
        23: .line 406
            aload 2 /* fc */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            invokeinterface org.apache.lucene.search.LeafFieldComparator.setBottom:(I)V
        end local 2 // org.apache.lucene.search.LeafFieldComparator fc
        24: .line 404
            iinc 3 1
      StackMap locals:
      StackMap stack:
        25: iload 3
            iload 4
            if_icmplt 21
        26: .line 408
            aload 0 /* this */
            iload 1 /* doc */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.topGroupDoc:I
        27: .line 409
            goto 62
        28: .line 411
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector int
      StackMap stack:
            iconst_0
            istore 2 /* compIDX */
        start local 2 // int compIDX
        29: .line 412
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.reversed:[I
            iload 2 /* compIDX */
            iaload
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            iload 2 /* compIDX */
            aaload
            iload 1 /* doc */
            invokeinterface org.apache.lucene.search.LeafFieldComparator.compareBottom:(I)I
            imul
            istore 3 /* c */
        start local 3 // int c
        30: .line 413
            iload 3 /* c */
            ifge 32
        31: .line 415
            return
        32: .line 416
      StackMap locals: int
      StackMap stack:
            iload 3 /* c */
            ifle 34
        33: .line 418
            goto 37
        34: .line 419
      StackMap locals:
      StackMap stack:
            iload 2 /* compIDX */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.compIDXEnd:I
            if_icmpne 36
        35: .line 423
            return
        end local 3 // int c
        36: .line 411
      StackMap locals:
      StackMap stack:
            iinc 2 /* compIDX */ 1
            goto 29
        end local 2 // int compIDX
        37: .line 429
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 42
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector int top int int org.apache.lucene.search.LeafFieldComparator[]
      StackMap stack:
        38: aload 5
            iload 3
            aaload
            astore 2 /* fc */
        start local 2 // org.apache.lucene.search.LeafFieldComparator fc
        39: .line 430
            aload 2 /* fc */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            iload 1 /* doc */
            invokeinterface org.apache.lucene.search.LeafFieldComparator.copy:(II)V
        40: .line 434
            aload 2 /* fc */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            invokeinterface org.apache.lucene.search.LeafFieldComparator.setBottom:(I)V
        end local 2 // org.apache.lucene.search.LeafFieldComparator fc
        41: .line 429
            iinc 3 1
      StackMap locals:
      StackMap stack:
        42: iload 3
            iload 4
            if_icmplt 38
        43: .line 436
            aload 0 /* this */
            iload 1 /* doc */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.topGroupDoc:I
        44: .line 438
            goto 62
        45: .line 441
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector int
      StackMap stack:
            iconst_0
            istore 2 /* compIDX */
        start local 2 // int compIDX
        46: .line 442
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.reversed:[I
            iload 2 /* compIDX */
            iaload
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            iload 2 /* compIDX */
            aaload
            iload 1 /* doc */
            invokeinterface org.apache.lucene.search.LeafFieldComparator.compareBottom:(I)I
            imul
            istore 3 /* c */
        start local 3 // int c
        47: .line 443
            iload 3 /* c */
            ifge 49
        48: .line 446
            return
        49: .line 447
      StackMap locals: int
      StackMap stack:
            iload 3 /* c */
            ifle 51
        50: .line 449
            goto 54
        51: .line 450
      StackMap locals:
      StackMap stack:
            iload 2 /* compIDX */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.compIDXEnd:I
            if_icmpne 53
        52: .line 455
            return
        end local 3 // int c
        53: .line 441
      StackMap locals:
      StackMap stack:
            iinc 2 /* compIDX */ 1
            goto 46
        end local 2 // int compIDX
        54: .line 458
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupCompetes:Z
        55: .line 459
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 60
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector int top int int org.apache.lucene.search.LeafFieldComparator[]
      StackMap stack:
        56: aload 5
            iload 3
            aaload
            astore 2 /* fc */
        start local 2 // org.apache.lucene.search.LeafFieldComparator fc
        57: .line 460
            aload 2 /* fc */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            iload 1 /* doc */
            invokeinterface org.apache.lucene.search.LeafFieldComparator.copy:(II)V
        58: .line 464
            aload 2 /* fc */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.bottomSlot:I
            invokeinterface org.apache.lucene.search.LeafFieldComparator.setBottom:(I)V
        end local 2 // org.apache.lucene.search.LeafFieldComparator fc
        59: .line 459
            iinc 3 1
      StackMap locals:
      StackMap stack:
        60: iload 3
            iload 4
            if_icmplt 56
        61: .line 466
            aload 0 /* this */
            iload 1 /* doc */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.topGroupDoc:I
        62: .line 469
      StackMap locals: org.apache.lucene.search.grouping.BlockGroupingCollector int
      StackMap stack:
            return
        end local 1 // int doc
        end local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   63     0     this  Lorg/apache/lucene/search/grouping/BlockGroupingCollector;
            0   63     1      doc  I
           22   24     2       fc  Lorg/apache/lucene/search/LeafFieldComparator;
           29   37     2  compIDX  I
           30   36     3        c  I
           39   41     2       fc  Lorg/apache/lucene/search/LeafFieldComparator;
           46   54     2  compIDX  I
           47   53     3        c  I
           57   59     2       fc  Lorg/apache/lucene/search/LeafFieldComparator;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      doc   

  protected void doSetNextReader(org.apache.lucene.index.LeafReaderContext);
    descriptor: (Lorg/apache/lucene/index/LeafReaderContext;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
        start local 1 // org.apache.lucene.index.LeafReaderContext readerContext
         0: .line 473
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
            ifeq 2
         1: .line 474
            aload 0 /* this */
            invokevirtual org.apache.lucene.search.grouping.BlockGroupingCollector.processGroup:()V
         2: .line 476
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.subDocUpto:I
         3: .line 477
            aload 0 /* this */
            aload 1 /* readerContext */
            getfield org.apache.lucene.index.LeafReaderContext.docBase:I
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.docBase:I
         4: .line 479
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.lastDocPerGroup:Lorg/apache/lucene/search/Weight;
            aload 1 /* readerContext */
            invokevirtual org.apache.lucene.search.Weight.scorer:(Lorg/apache/lucene/index/LeafReaderContext;)Lorg/apache/lucene/search/Scorer;
            astore 2 /* s */
        start local 2 // org.apache.lucene.search.Scorer s
         5: .line 480
            aload 2 /* s */
            ifnonnull 8
         6: .line 481
            aload 0 /* this */
            aconst_null
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.lastDocPerGroupBits:Lorg/apache/lucene/search/DocIdSetIterator;
         7: .line 482
            goto 9
         8: .line 483
      StackMap locals: org.apache.lucene.search.Scorer
      StackMap stack:
            aload 0 /* this */
            aload 2 /* s */
            invokevirtual org.apache.lucene.search.Scorer.iterator:()Lorg/apache/lucene/search/DocIdSetIterator;
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.lastDocPerGroupBits:Lorg/apache/lucene/search/DocIdSetIterator;
         9: .line 485
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_m1
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.groupEndDocID:I
        10: .line 487
            aload 0 /* this */
            aload 1 /* readerContext */
            putfield org.apache.lucene.search.grouping.BlockGroupingCollector.currentReaderContext:Lorg/apache/lucene/index/LeafReaderContext;
        11: .line 488
            iconst_0
            istore 3 /* i */
        start local 3 // int i
        12: goto 15
        13: .line 489
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.leafComparators:[Lorg/apache/lucene/search/LeafFieldComparator;
            iload 3 /* i */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            iload 3 /* i */
            aaload
            aload 1 /* readerContext */
            invokevirtual org.apache.lucene.search.FieldComparator.getLeafComparator:(Lorg/apache/lucene/index/LeafReaderContext;)Lorg/apache/lucene/search/LeafFieldComparator;
            aastore
        14: .line 488
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        15: iload 3 /* i */
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.comparators:[Lorg/apache/lucene/search/FieldComparator;
            arraylength
            if_icmplt 13
        end local 3 // int i
        16: .line 491
            return
        end local 2 // org.apache.lucene.search.Scorer s
        end local 1 // org.apache.lucene.index.LeafReaderContext readerContext
        end local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   17     0           this  Lorg/apache/lucene/search/grouping/BlockGroupingCollector;
            0   17     1  readerContext  Lorg/apache/lucene/index/LeafReaderContext;
            5   17     2              s  Lorg/apache/lucene/search/Scorer;
           12   16     3              i  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
               Name  Flags
      readerContext  

  public org.apache.lucene.search.ScoreMode scoreMode();
    descriptor: ()Lorg/apache/lucene/search/ScoreMode;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
         0: .line 495
            aload 0 /* this */
            getfield org.apache.lucene.search.grouping.BlockGroupingCollector.needsScores:Z
            ifeq 1
            getstatic org.apache.lucene.search.ScoreMode.COMPLETE:Lorg/apache/lucene/search/ScoreMode;
            goto 2
      StackMap locals:
      StackMap stack:
         1: getstatic org.apache.lucene.search.ScoreMode.COMPLETE_NO_SCORES:Lorg/apache/lucene/search/ScoreMode;
      StackMap locals:
      StackMap stack: org.apache.lucene.search.ScoreMode
         2: areturn
        end local 0 // org.apache.lucene.search.grouping.BlockGroupingCollector this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/lucene/search/grouping/BlockGroupingCollector;
}
SourceFile: "BlockGroupingCollector.java"
NestMembers:
  org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue  org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup  org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc
InnerClasses:
  public final Relation = org.apache.lucene.search.TotalHits$Relation of org.apache.lucene.search.TotalHits
  private final GroupQueue = org.apache.lucene.search.grouping.BlockGroupingCollector$GroupQueue of org.apache.lucene.search.grouping.BlockGroupingCollector
  private final OneGroup = org.apache.lucene.search.grouping.BlockGroupingCollector$OneGroup of org.apache.lucene.search.grouping.BlockGroupingCollector
  private ScoreAndDoc = org.apache.lucene.search.grouping.BlockGroupingCollector$ScoreAndDoc of org.apache.lucene.search.grouping.BlockGroupingCollector