public class org.apache.lucene.search.grouping.TopGroups<T>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.lucene.search.grouping.TopGroups
  super_class: java.lang.Object
{
  public final int totalHitCount;
    descriptor: I
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  public final int totalGroupedHitCount;
    descriptor: I
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  public final java.lang.Integer totalGroupCount;
    descriptor: Ljava/lang/Integer;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  public final org.apache.lucene.search.grouping.GroupDocs<T>[] groups;
    descriptor: [Lorg/apache/lucene/search/grouping/GroupDocs;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Signature: [Lorg/apache/lucene/search/grouping/GroupDocs<TT;>;

  public final org.apache.lucene.search.SortField[] groupSort;
    descriptor: [Lorg/apache/lucene/search/SortField;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  public final org.apache.lucene.search.SortField[] withinGroupSort;
    descriptor: [Lorg/apache/lucene/search/SortField;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  public final float maxScore;
    descriptor: F
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

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

  private static volatile int[] $SWITCH_TABLE$org$apache$lucene$search$grouping$TopGroups$ScoreMergeMode;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 30
            ldc Lorg/apache/lucene/search/grouping/TopGroups;
            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.TopGroups.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(org.apache.lucene.search.SortField[], org.apache.lucene.search.SortField[], int, int, org.apache.lucene.search.grouping.GroupDocs<T>[], );
    descriptor: ([Lorg/apache/lucene/search/SortField;[Lorg/apache/lucene/search/SortField;II[Lorg/apache/lucene/search/grouping/GroupDocs;F)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=7, args_size=7
        start local 0 // org.apache.lucene.search.grouping.TopGroups this
        start local 1 // org.apache.lucene.search.SortField[] groupSort
        start local 2 // org.apache.lucene.search.SortField[] withinGroupSort
        start local 3 // int totalHitCount
        start local 4 // int totalGroupedHitCount
        start local 5 // org.apache.lucene.search.grouping.GroupDocs[] groups
        start local 6 // float maxScore
         0: .line 53
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 54
            aload 0 /* this */
            aload 1 /* groupSort */
            putfield org.apache.lucene.search.grouping.TopGroups.groupSort:[Lorg/apache/lucene/search/SortField;
         2: .line 55
            aload 0 /* this */
            aload 2 /* withinGroupSort */
            putfield org.apache.lucene.search.grouping.TopGroups.withinGroupSort:[Lorg/apache/lucene/search/SortField;
         3: .line 56
            aload 0 /* this */
            iload 3 /* totalHitCount */
            putfield org.apache.lucene.search.grouping.TopGroups.totalHitCount:I
         4: .line 57
            aload 0 /* this */
            iload 4 /* totalGroupedHitCount */
            putfield org.apache.lucene.search.grouping.TopGroups.totalGroupedHitCount:I
         5: .line 58
            aload 0 /* this */
            aload 5 /* groups */
            putfield org.apache.lucene.search.grouping.TopGroups.groups:[Lorg/apache/lucene/search/grouping/GroupDocs;
         6: .line 59
            aload 0 /* this */
            aconst_null
            putfield org.apache.lucene.search.grouping.TopGroups.totalGroupCount:Ljava/lang/Integer;
         7: .line 60
            aload 0 /* this */
            fload 6 /* maxScore */
            putfield org.apache.lucene.search.grouping.TopGroups.maxScore:F
         8: .line 61
            return
        end local 6 // float maxScore
        end local 5 // org.apache.lucene.search.grouping.GroupDocs[] groups
        end local 4 // int totalGroupedHitCount
        end local 3 // int totalHitCount
        end local 2 // org.apache.lucene.search.SortField[] withinGroupSort
        end local 1 // org.apache.lucene.search.SortField[] groupSort
        end local 0 // org.apache.lucene.search.grouping.TopGroups this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0    9     0                  this  Lorg/apache/lucene/search/grouping/TopGroups<TT;>;
            0    9     1             groupSort  [Lorg/apache/lucene/search/SortField;
            0    9     2       withinGroupSort  [Lorg/apache/lucene/search/SortField;
            0    9     3         totalHitCount  I
            0    9     4  totalGroupedHitCount  I
            0    9     5                groups  [Lorg/apache/lucene/search/grouping/GroupDocs;
            0    9     6              maxScore  F
    Signature: ([Lorg/apache/lucene/search/SortField;[Lorg/apache/lucene/search/SortField;II[Lorg/apache/lucene/search/grouping/GroupDocs<TT;>;F)V
    MethodParameters:
                      Name  Flags
      groupSort             
      withinGroupSort       
      totalHitCount         
      totalGroupedHitCount  
      groups                
      maxScore              

  public void <init>(org.apache.lucene.search.grouping.TopGroups<T>, java.lang.Integer);
    descriptor: (Lorg/apache/lucene/search/grouping/TopGroups;Ljava/lang/Integer;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.apache.lucene.search.grouping.TopGroups this
        start local 1 // org.apache.lucene.search.grouping.TopGroups oldTopGroups
        start local 2 // java.lang.Integer totalGroupCount
         0: .line 63
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 64
            aload 0 /* this */
            aload 1 /* oldTopGroups */
            getfield org.apache.lucene.search.grouping.TopGroups.groupSort:[Lorg/apache/lucene/search/SortField;
            putfield org.apache.lucene.search.grouping.TopGroups.groupSort:[Lorg/apache/lucene/search/SortField;
         2: .line 65
            aload 0 /* this */
            aload 1 /* oldTopGroups */
            getfield org.apache.lucene.search.grouping.TopGroups.withinGroupSort:[Lorg/apache/lucene/search/SortField;
            putfield org.apache.lucene.search.grouping.TopGroups.withinGroupSort:[Lorg/apache/lucene/search/SortField;
         3: .line 66
            aload 0 /* this */
            aload 1 /* oldTopGroups */
            getfield org.apache.lucene.search.grouping.TopGroups.totalHitCount:I
            putfield org.apache.lucene.search.grouping.TopGroups.totalHitCount:I
         4: .line 67
            aload 0 /* this */
            aload 1 /* oldTopGroups */
            getfield org.apache.lucene.search.grouping.TopGroups.totalGroupedHitCount:I
            putfield org.apache.lucene.search.grouping.TopGroups.totalGroupedHitCount:I
         5: .line 68
            aload 0 /* this */
            aload 1 /* oldTopGroups */
            getfield org.apache.lucene.search.grouping.TopGroups.groups:[Lorg/apache/lucene/search/grouping/GroupDocs;
            putfield org.apache.lucene.search.grouping.TopGroups.groups:[Lorg/apache/lucene/search/grouping/GroupDocs;
         6: .line 69
            aload 0 /* this */
            aload 1 /* oldTopGroups */
            getfield org.apache.lucene.search.grouping.TopGroups.maxScore:F
            putfield org.apache.lucene.search.grouping.TopGroups.maxScore:F
         7: .line 70
            aload 0 /* this */
            aload 2 /* totalGroupCount */
            putfield org.apache.lucene.search.grouping.TopGroups.totalGroupCount:Ljava/lang/Integer;
         8: .line 71
            return
        end local 2 // java.lang.Integer totalGroupCount
        end local 1 // org.apache.lucene.search.grouping.TopGroups oldTopGroups
        end local 0 // org.apache.lucene.search.grouping.TopGroups this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    9     0             this  Lorg/apache/lucene/search/grouping/TopGroups<TT;>;
            0    9     1     oldTopGroups  Lorg/apache/lucene/search/grouping/TopGroups<TT;>;
            0    9     2  totalGroupCount  Ljava/lang/Integer;
    Signature: (Lorg/apache/lucene/search/grouping/TopGroups<TT;>;Ljava/lang/Integer;)V
    MethodParameters:
                 Name  Flags
      oldTopGroups     
      totalGroupCount  

  public static <T> org.apache.lucene.search.grouping.TopGroups<T> merge(org.apache.lucene.search.grouping.TopGroups<T>[], org.apache.lucene.search.Sort, org.apache.lucene.search.Sort, int, int, org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode);
    descriptor: ([Lorg/apache/lucene/search/grouping/TopGroups;Lorg/apache/lucene/search/Sort;Lorg/apache/lucene/search/Sort;IILorg/apache/lucene/search/grouping/TopGroups$ScoreMergeMode;)Lorg/apache/lucene/search/grouping/TopGroups;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=11, locals=22, args_size=6
        start local 0 // org.apache.lucene.search.grouping.TopGroups[] shardGroups
        start local 1 // org.apache.lucene.search.Sort groupSort
        start local 2 // org.apache.lucene.search.Sort docSort
        start local 3 // int docOffset
        start local 4 // int docTopN
        start local 5 // org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode scoreMergeMode
         0: .line 104
            aload 0 /* shardGroups */
            arraylength
            ifne 2
         1: .line 105
            aconst_null
            areturn
         2: .line 108
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 6 /* totalHitCount */
        start local 6 // int totalHitCount
         3: .line 109
            iconst_0
            istore 7 /* totalGroupedHitCount */
        start local 7 // int totalGroupedHitCount
         4: .line 111
            aconst_null
            astore 8 /* totalGroupCount */
        start local 8 // java.lang.Integer totalGroupCount
         5: .line 113
            aload 0 /* shardGroups */
            iconst_0
            aaload
            getfield org.apache.lucene.search.grouping.TopGroups.groups:[Lorg/apache/lucene/search/grouping/GroupDocs;
            arraylength
            istore 9 /* numGroups */
        start local 9 // int numGroups
         6: .line 114
            aload 0 /* shardGroups */
            dup
            astore 13
            arraylength
            istore 12
            iconst_0
            istore 11
            goto 17
      StackMap locals: org.apache.lucene.search.grouping.TopGroups[] org.apache.lucene.search.Sort org.apache.lucene.search.Sort int int org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode int int java.lang.Integer int top int int org.apache.lucene.search.grouping.TopGroups[]
      StackMap stack:
         7: aload 13
            iload 11
            aaload
            astore 10 /* shard */
        start local 10 // org.apache.lucene.search.grouping.TopGroups shard
         8: .line 115
            iload 9 /* numGroups */
            aload 10 /* shard */
            getfield org.apache.lucene.search.grouping.TopGroups.groups:[Lorg/apache/lucene/search/grouping/GroupDocs;
            arraylength
            if_icmpeq 10
         9: .line 116
            new java.lang.IllegalArgumentException
            dup
            ldc "number of groups differs across shards; you must pass same top groups to all shards' second-pass collector"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 118
      StackMap locals: org.apache.lucene.search.grouping.TopGroups[] org.apache.lucene.search.Sort org.apache.lucene.search.Sort int int org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode int int java.lang.Integer int org.apache.lucene.search.grouping.TopGroups int int org.apache.lucene.search.grouping.TopGroups[]
      StackMap stack:
            iload 6 /* totalHitCount */
            aload 10 /* shard */
            getfield org.apache.lucene.search.grouping.TopGroups.totalHitCount:I
            iadd
            istore 6 /* totalHitCount */
        11: .line 119
            iload 7 /* totalGroupedHitCount */
            aload 10 /* shard */
            getfield org.apache.lucene.search.grouping.TopGroups.totalGroupedHitCount:I
            iadd
            istore 7 /* totalGroupedHitCount */
        12: .line 120
            aload 10 /* shard */
            getfield org.apache.lucene.search.grouping.TopGroups.totalGroupCount:Ljava/lang/Integer;
            ifnull 16
        13: .line 121
            aload 8 /* totalGroupCount */
            ifnonnull 15
        14: .line 122
            iconst_0
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            astore 8 /* totalGroupCount */
        15: .line 125
      StackMap locals:
      StackMap stack:
            aload 8 /* totalGroupCount */
            invokevirtual java.lang.Integer.intValue:()I
            aload 10 /* shard */
            getfield org.apache.lucene.search.grouping.TopGroups.totalGroupCount:Ljava/lang/Integer;
            invokevirtual java.lang.Integer.intValue:()I
            iadd
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            astore 8 /* totalGroupCount */
        end local 10 // org.apache.lucene.search.grouping.TopGroups shard
        16: .line 114
      StackMap locals: org.apache.lucene.search.grouping.TopGroups[] org.apache.lucene.search.Sort org.apache.lucene.search.Sort int int org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode int int java.lang.Integer int top int int org.apache.lucene.search.grouping.TopGroups[]
      StackMap stack:
            iinc 11 1
      StackMap locals:
      StackMap stack:
        17: iload 11
            iload 12
            if_icmplt 7
        18: .line 130
            iload 9 /* numGroups */
            anewarray org.apache.lucene.search.grouping.GroupDocs
            astore 10 /* mergedGroupDocs */
        start local 10 // org.apache.lucene.search.grouping.GroupDocs[] mergedGroupDocs
        19: .line 133
            aload 2 /* docSort */
            getstatic org.apache.lucene.search.Sort.RELEVANCE:Lorg/apache/lucene/search/Sort;
            invokevirtual org.apache.lucene.search.Sort.equals:(Ljava/lang/Object;)Z
            ifeq 22
        20: .line 134
            aload 0 /* shardGroups */
            arraylength
            anewarray org.apache.lucene.search.TopDocs
            astore 11 /* shardTopDocs */
        start local 11 // org.apache.lucene.search.TopDocs[] shardTopDocs
        21: .line 135
            goto 23
        end local 11 // org.apache.lucene.search.TopDocs[] shardTopDocs
        22: .line 136
      StackMap locals: org.apache.lucene.search.grouping.TopGroups[] org.apache.lucene.search.Sort org.apache.lucene.search.Sort int int org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode int int java.lang.Integer int org.apache.lucene.search.grouping.GroupDocs[]
      StackMap stack:
            aload 0 /* shardGroups */
            arraylength
            anewarray org.apache.lucene.search.TopFieldDocs
            astore 11 /* shardTopDocs */
        start local 11 // org.apache.lucene.search.TopDocs[] shardTopDocs
        23: .line 138
      StackMap locals: org.apache.lucene.search.TopDocs[]
      StackMap stack:
            ldc 1.4E-45
            fstore 12 /* totalMaxScore */
        start local 12 // float totalMaxScore
        24: .line 140
            iconst_0
            istore 13 /* groupIDX */
        start local 13 // int groupIDX
        25: goto 91
        26: .line 141
      StackMap locals: float int
      StackMap stack:
            aload 0 /* shardGroups */
            iconst_0
            aaload
            getfield org.apache.lucene.search.grouping.TopGroups.groups:[Lorg/apache/lucene/search/grouping/GroupDocs;
            iload 13 /* groupIDX */
            aaload
            getfield org.apache.lucene.search.grouping.GroupDocs.groupValue:Ljava/lang/Object;
            astore 14 /* groupValue */
        start local 14 // java.lang.Object groupValue
        27: .line 143
            ldc 1.4E-45
            fstore 15 /* maxScore */
        start local 15 // float maxScore
        28: .line 144
            iconst_0
            istore 16 /* totalHits */
        start local 16 // int totalHits
        29: .line 145
            dconst_0
            dstore 17 /* scoreSum */
        start local 17 // double scoreSum
        30: .line 146
            iconst_0
            istore 19 /* shardIDX */
        start local 19 // int shardIDX
        31: goto 53
        32: .line 148
      StackMap locals: org.apache.lucene.search.grouping.TopGroups[] org.apache.lucene.search.Sort org.apache.lucene.search.Sort int int org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode int int java.lang.Integer int org.apache.lucene.search.grouping.GroupDocs[] org.apache.lucene.search.TopDocs[] float int java.lang.Object float int double int
      StackMap stack:
            aload 0 /* shardGroups */
            iload 19 /* shardIDX */
            aaload
            astore 20 /* shard */
        start local 20 // org.apache.lucene.search.grouping.TopGroups shard
        33: .line 149
            aload 20 /* shard */
            getfield org.apache.lucene.search.grouping.TopGroups.groups:[Lorg/apache/lucene/search/grouping/GroupDocs;
            iload 13 /* groupIDX */
            aaload
            astore 21 /* shardGroupDocs */
        start local 21 // org.apache.lucene.search.grouping.GroupDocs shardGroupDocs
        34: .line 150
            aload 14 /* groupValue */
            ifnonnull 37
        35: .line 151
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.groupValue:Ljava/lang/Object;
            ifnull 39
        36: .line 152
            new java.lang.IllegalArgumentException
            dup
            ldc "group values differ across shards; you must pass same top groups to all shards' second-pass collector"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        37: .line 154
      StackMap locals: org.apache.lucene.search.grouping.TopGroups org.apache.lucene.search.grouping.GroupDocs
      StackMap stack:
            aload 14 /* groupValue */
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.groupValue:Ljava/lang/Object;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifne 39
        38: .line 155
            new java.lang.IllegalArgumentException
            dup
            ldc "group values differ across shards; you must pass same top groups to all shards' second-pass collector"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        39: .line 164
      StackMap locals:
      StackMap stack:
            aload 2 /* docSort */
            getstatic org.apache.lucene.search.Sort.RELEVANCE:Lorg/apache/lucene/search/Sort;
            invokevirtual org.apache.lucene.search.Sort.equals:(Ljava/lang/Object;)Z
            ifeq 44
        40: .line 165
            aload 11 /* shardTopDocs */
            iload 19 /* shardIDX */
            new org.apache.lucene.search.TopDocs
            dup
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.totalHits:Lorg/apache/lucene/search/TotalHits;
        41: .line 166
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.scoreDocs:[Lorg/apache/lucene/search/ScoreDoc;
            invokespecial org.apache.lucene.search.TopDocs.<init>:(Lorg/apache/lucene/search/TotalHits;[Lorg/apache/lucene/search/ScoreDoc;)V
        42: .line 165
            aastore
        43: .line 167
            goto 48
        44: .line 168
      StackMap locals:
      StackMap stack:
            aload 11 /* shardTopDocs */
            iload 19 /* shardIDX */
            new org.apache.lucene.search.TopFieldDocs
            dup
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.totalHits:Lorg/apache/lucene/search/TotalHits;
        45: .line 169
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.scoreDocs:[Lorg/apache/lucene/search/ScoreDoc;
        46: .line 170
            aload 2 /* docSort */
            invokevirtual org.apache.lucene.search.Sort.getSort:()[Lorg/apache/lucene/search/SortField;
            invokespecial org.apache.lucene.search.TopFieldDocs.<init>:(Lorg/apache/lucene/search/TotalHits;[Lorg/apache/lucene/search/ScoreDoc;[Lorg/apache/lucene/search/SortField;)V
        47: .line 168
            aastore
        48: .line 172
      StackMap locals:
      StackMap stack:
            fload 15 /* maxScore */
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.maxScore:F
            invokestatic java.lang.Math.max:(FF)F
            fstore 15 /* maxScore */
        49: .line 173
            getstatic org.apache.lucene.search.grouping.TopGroups.$assertionsDisabled:Z
            ifne 50
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.totalHits:Lorg/apache/lucene/search/TotalHits;
            getfield org.apache.lucene.search.TotalHits.relation:Lorg/apache/lucene/search/TotalHits$Relation;
            getstatic org.apache.lucene.search.TotalHits$Relation.EQUAL_TO:Lorg/apache/lucene/search/TotalHits$Relation;
            if_acmpeq 50
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        50: .line 174
      StackMap locals:
      StackMap stack:
            iload 16 /* totalHits */
            i2l
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.totalHits:Lorg/apache/lucene/search/TotalHits;
            getfield org.apache.lucene.search.TotalHits.value:J
            ladd
            l2i
            istore 16 /* totalHits */
        51: .line 175
            dload 17 /* scoreSum */
            aload 21 /* shardGroupDocs */
            getfield org.apache.lucene.search.grouping.GroupDocs.score:F
            f2d
            dadd
            dstore 17 /* scoreSum */
        end local 21 // org.apache.lucene.search.grouping.GroupDocs shardGroupDocs
        end local 20 // org.apache.lucene.search.grouping.TopGroups shard
        52: .line 146
            iinc 19 /* shardIDX */ 1
      StackMap locals:
      StackMap stack:
        53: iload 19 /* shardIDX */
            aload 0 /* shardGroups */
            arraylength
            if_icmplt 32
        end local 19 // int shardIDX
        54: .line 179
            aload 2 /* docSort */
            getstatic org.apache.lucene.search.Sort.RELEVANCE:Lorg/apache/lucene/search/Sort;
            invokevirtual org.apache.lucene.search.Sort.equals:(Ljava/lang/Object;)Z
            ifeq 57
        55: .line 180
            iload 3 /* docOffset */
            iload 4 /* docTopN */
            iadd
            aload 11 /* shardTopDocs */
            invokestatic org.apache.lucene.search.TopDocs.merge:(I[Lorg/apache/lucene/search/TopDocs;)Lorg/apache/lucene/search/TopDocs;
            astore 19 /* mergedTopDocs */
        start local 19 // org.apache.lucene.search.TopDocs mergedTopDocs
        56: .line 181
            goto 58
        end local 19 // org.apache.lucene.search.TopDocs mergedTopDocs
        57: .line 182
      StackMap locals:
      StackMap stack:
            aload 2 /* docSort */
            iload 3 /* docOffset */
            iload 4 /* docTopN */
            iadd
            aload 11 /* shardTopDocs */
            checkcast org.apache.lucene.search.TopFieldDocs[]
            invokestatic org.apache.lucene.search.TopDocs.merge:(Lorg/apache/lucene/search/Sort;I[Lorg/apache/lucene/search/TopFieldDocs;)Lorg/apache/lucene/search/TopFieldDocs;
            astore 19 /* mergedTopDocs */
        start local 19 // org.apache.lucene.search.TopDocs mergedTopDocs
        58: .line 187
      StackMap locals: org.apache.lucene.search.TopDocs
      StackMap stack:
            iload 3 /* docOffset */
            ifne 61
        59: .line 188
            aload 19 /* mergedTopDocs */
            getfield org.apache.lucene.search.TopDocs.scoreDocs:[Lorg/apache/lucene/search/ScoreDoc;
            astore 20 /* mergedScoreDocs */
        start local 20 // org.apache.lucene.search.ScoreDoc[] mergedScoreDocs
        60: .line 189
            goto 71
        end local 20 // org.apache.lucene.search.ScoreDoc[] mergedScoreDocs
      StackMap locals:
      StackMap stack:
        61: iload 3 /* docOffset */
            aload 19 /* mergedTopDocs */
            getfield org.apache.lucene.search.TopDocs.scoreDocs:[Lorg/apache/lucene/search/ScoreDoc;
            arraylength
            if_icmplt 64
        62: .line 190
            iconst_0
            anewarray org.apache.lucene.search.ScoreDoc
            astore 20 /* mergedScoreDocs */
        start local 20 // org.apache.lucene.search.ScoreDoc[] mergedScoreDocs
        63: .line 191
            goto 71
        end local 20 // org.apache.lucene.search.ScoreDoc[] mergedScoreDocs
        64: .line 192
      StackMap locals:
      StackMap stack:
            aload 19 /* mergedTopDocs */
            getfield org.apache.lucene.search.TopDocs.scoreDocs:[Lorg/apache/lucene/search/ScoreDoc;
            arraylength
            iload 3 /* docOffset */
            isub
            anewarray org.apache.lucene.search.ScoreDoc
            astore 20 /* mergedScoreDocs */
        start local 20 // org.apache.lucene.search.ScoreDoc[] mergedScoreDocs
        65: .line 193
            aload 19 /* mergedTopDocs */
            getfield org.apache.lucene.search.TopDocs.scoreDocs:[Lorg/apache/lucene/search/ScoreDoc;
        66: .line 194
            iload 3 /* docOffset */
        67: .line 195
            aload 20 /* mergedScoreDocs */
        68: .line 196
            iconst_0
        69: .line 197
            aload 19 /* mergedTopDocs */
            getfield org.apache.lucene.search.TopDocs.scoreDocs:[Lorg/apache/lucene/search/ScoreDoc;
            arraylength
            iload 3 /* docOffset */
            isub
        70: .line 193
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        71: .line 201
      StackMap locals: org.apache.lucene.search.ScoreDoc[]
      StackMap stack:
            invokestatic org.apache.lucene.search.grouping.TopGroups.$SWITCH_TABLE$org$apache$lucene$search$grouping$TopGroups$ScoreMergeMode:()[I
            aload 5 /* scoreMergeMode */
            invokevirtual org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode.ordinal:()I
            iaload
            tableswitch { // 1 - 3
                    1: 72
                    2: 79
                    3: 74
              default: 81
          }
        72: .line 203
      StackMap locals:
      StackMap stack:
            ldc NaN
            fstore 21 /* groupScore */
        start local 21 // float groupScore
        73: .line 204
            goto 82
        end local 21 // float groupScore
        74: .line 206
      StackMap locals:
      StackMap stack:
            iload 16 /* totalHits */
            ifle 77
        75: .line 207
            dload 17 /* scoreSum */
            iload 16 /* totalHits */
            i2d
            ddiv
            d2f
            fstore 21 /* groupScore */
        start local 21 // float groupScore
        76: .line 208
            goto 82
        end local 21 // float groupScore
        77: .line 209
      StackMap locals:
      StackMap stack:
            ldc NaN
            fstore 21 /* groupScore */
        start local 21 // float groupScore
        78: .line 211
            goto 82
        end local 21 // float groupScore
        79: .line 213
      StackMap locals:
      StackMap stack:
            dload 17 /* scoreSum */
            d2f
            fstore 21 /* groupScore */
        start local 21 // float groupScore
        80: .line 214
            goto 82
        end local 21 // float groupScore
        81: .line 216
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "can't handle ScoreMergeMode "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* scoreMergeMode */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        start local 21 // float groupScore
        82: .line 220
      StackMap locals: float
      StackMap stack:
            aload 10 /* mergedGroupDocs */
            iload 13 /* groupIDX */
            new org.apache.lucene.search.grouping.GroupDocs
            dup
            fload 21 /* groupScore */
        83: .line 221
            fload 15 /* maxScore */
        84: .line 222
            new org.apache.lucene.search.TotalHits
            dup
            iload 16 /* totalHits */
            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
        85: .line 223
            aload 20 /* mergedScoreDocs */
        86: .line 224
            aload 14 /* groupValue */
        87: .line 225
            aload 0 /* shardGroups */
            iconst_0
            aaload
            getfield org.apache.lucene.search.grouping.TopGroups.groups:[Lorg/apache/lucene/search/grouping/GroupDocs;
            iload 13 /* groupIDX */
            aaload
            getfield org.apache.lucene.search.grouping.GroupDocs.groupSortValues:[Ljava/lang/Object;
            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
        88: .line 220
            aastore
        89: .line 226
            fload 12 /* totalMaxScore */
            fload 15 /* maxScore */
            invokestatic java.lang.Math.max:(FF)F
            fstore 12 /* totalMaxScore */
        end local 21 // float groupScore
        end local 20 // org.apache.lucene.search.ScoreDoc[] mergedScoreDocs
        end local 19 // org.apache.lucene.search.TopDocs mergedTopDocs
        end local 17 // double scoreSum
        end local 16 // int totalHits
        end local 15 // float maxScore
        end local 14 // java.lang.Object groupValue
        90: .line 140
            iinc 13 /* groupIDX */ 1
      StackMap locals: org.apache.lucene.search.grouping.TopGroups[] org.apache.lucene.search.Sort org.apache.lucene.search.Sort int int org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode int int java.lang.Integer int org.apache.lucene.search.grouping.GroupDocs[] org.apache.lucene.search.TopDocs[] float int
      StackMap stack:
        91: iload 13 /* groupIDX */
            iload 9 /* numGroups */
            if_icmplt 26
        end local 13 // int groupIDX
        92: .line 229
            aload 8 /* totalGroupCount */
            ifnull 101
        93: .line 230
            new org.apache.lucene.search.grouping.TopGroups
            dup
            aload 1 /* groupSort */
            invokevirtual org.apache.lucene.search.Sort.getSort:()[Lorg/apache/lucene/search/SortField;
        94: .line 231
            aload 2 /* docSort */
            invokevirtual org.apache.lucene.search.Sort.getSort:()[Lorg/apache/lucene/search/SortField;
        95: .line 232
            iload 6 /* totalHitCount */
        96: .line 233
            iload 7 /* totalGroupedHitCount */
        97: .line 234
            aload 10 /* mergedGroupDocs */
        98: .line 235
            fload 12 /* totalMaxScore */
        99: .line 230
            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
            astore 13 /* result */
        start local 13 // org.apache.lucene.search.grouping.TopGroups result
       100: .line 236
            new org.apache.lucene.search.grouping.TopGroups
            dup
            aload 13 /* result */
            aload 8 /* totalGroupCount */
            invokespecial org.apache.lucene.search.grouping.TopGroups.<init>:(Lorg/apache/lucene/search/grouping/TopGroups;Ljava/lang/Integer;)V
            areturn
        end local 13 // org.apache.lucene.search.grouping.TopGroups result
       101: .line 238
      StackMap locals:
      StackMap stack:
            new org.apache.lucene.search.grouping.TopGroups
            dup
            aload 1 /* groupSort */
            invokevirtual org.apache.lucene.search.Sort.getSort:()[Lorg/apache/lucene/search/SortField;
       102: .line 239
            aload 2 /* docSort */
            invokevirtual org.apache.lucene.search.Sort.getSort:()[Lorg/apache/lucene/search/SortField;
       103: .line 240
            iload 6 /* totalHitCount */
       104: .line 241
            iload 7 /* totalGroupedHitCount */
       105: .line 242
            aload 10 /* mergedGroupDocs */
       106: .line 243
            fload 12 /* totalMaxScore */
       107: .line 238
            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
            areturn
        end local 12 // float totalMaxScore
        end local 11 // org.apache.lucene.search.TopDocs[] shardTopDocs
        end local 10 // org.apache.lucene.search.grouping.GroupDocs[] mergedGroupDocs
        end local 9 // int numGroups
        end local 8 // java.lang.Integer totalGroupCount
        end local 7 // int totalGroupedHitCount
        end local 6 // int totalHitCount
        end local 5 // org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode scoreMergeMode
        end local 4 // int docTopN
        end local 3 // int docOffset
        end local 2 // org.apache.lucene.search.Sort docSort
        end local 1 // org.apache.lucene.search.Sort groupSort
        end local 0 // org.apache.lucene.search.grouping.TopGroups[] shardGroups
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0  108     0           shardGroups  [Lorg/apache/lucene/search/grouping/TopGroups;
            0  108     1             groupSort  Lorg/apache/lucene/search/Sort;
            0  108     2               docSort  Lorg/apache/lucene/search/Sort;
            0  108     3             docOffset  I
            0  108     4               docTopN  I
            0  108     5        scoreMergeMode  Lorg/apache/lucene/search/grouping/TopGroups$ScoreMergeMode;
            3  108     6         totalHitCount  I
            4  108     7  totalGroupedHitCount  I
            5  108     8       totalGroupCount  Ljava/lang/Integer;
            6  108     9             numGroups  I
            8   16    10                 shard  Lorg/apache/lucene/search/grouping/TopGroups<TT;>;
           19  108    10       mergedGroupDocs  [Lorg/apache/lucene/search/grouping/GroupDocs;
           21   22    11          shardTopDocs  [Lorg/apache/lucene/search/TopDocs;
           23  108    11          shardTopDocs  [Lorg/apache/lucene/search/TopDocs;
           24  108    12         totalMaxScore  F
           25   92    13              groupIDX  I
           27   90    14            groupValue  TT;
           28   90    15              maxScore  F
           29   90    16             totalHits  I
           30   90    17              scoreSum  D
           31   54    19              shardIDX  I
           33   52    20                 shard  Lorg/apache/lucene/search/grouping/TopGroups<TT;>;
           34   52    21        shardGroupDocs  Lorg/apache/lucene/search/grouping/GroupDocs<*>;
           56   57    19         mergedTopDocs  Lorg/apache/lucene/search/TopDocs;
           58   90    19         mergedTopDocs  Lorg/apache/lucene/search/TopDocs;
           60   61    20       mergedScoreDocs  [Lorg/apache/lucene/search/ScoreDoc;
           63   64    20       mergedScoreDocs  [Lorg/apache/lucene/search/ScoreDoc;
           65   90    20       mergedScoreDocs  [Lorg/apache/lucene/search/ScoreDoc;
           73   74    21            groupScore  F
           76   77    21            groupScore  F
           78   79    21            groupScore  F
           80   81    21            groupScore  F
           82   90    21            groupScore  F
          100  101    13                result  Lorg/apache/lucene/search/grouping/TopGroups<TT;>;
    Signature: <T:Ljava/lang/Object;>([Lorg/apache/lucene/search/grouping/TopGroups<TT;>;Lorg/apache/lucene/search/Sort;Lorg/apache/lucene/search/Sort;IILorg/apache/lucene/search/grouping/TopGroups$ScoreMergeMode;)Lorg/apache/lucene/search/grouping/TopGroups<TT;>;
    MethodParameters:
                Name  Flags
      shardGroups     
      groupSort       
      docSort         
      docOffset       
      docTopN         
      scoreMergeMode  

  static int[] $SWITCH_TABLE$org$apache$lucene$search$grouping$TopGroups$ScoreMergeMode();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 30
            getstatic org.apache.lucene.search.grouping.TopGroups.$SWITCH_TABLE$org$apache$lucene$search$grouping$TopGroups$ScoreMergeMode:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode.values:()[Lorg/apache/lucene/search/grouping/TopGroups$ScoreMergeMode;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode.Avg:Lorg/apache/lucene/search/grouping/TopGroups$ScoreMergeMode;
            invokevirtual org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode.ordinal:()I
            iconst_3
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode.None:Lorg/apache/lucene/search/grouping/TopGroups$ScoreMergeMode;
            invokevirtual org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode.ordinal:()I
            iconst_1
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode.Total:Lorg/apache/lucene/search/grouping/TopGroups$ScoreMergeMode;
            invokevirtual org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode.ordinal:()I
            iconst_2
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            dup
            putstatic org.apache.lucene.search.grouping.TopGroups.$SWITCH_TABLE$org$apache$lucene$search$grouping$TopGroups$ScoreMergeMode:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError
}
Signature: <T:Ljava/lang/Object;>Ljava/lang/Object;
SourceFile: "TopGroups.java"
NestMembers:
  org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode
InnerClasses:
  public final Relation = org.apache.lucene.search.TotalHits$Relation of org.apache.lucene.search.TotalHits
  public final ScoreMergeMode = org.apache.lucene.search.grouping.TopGroups$ScoreMergeMode of org.apache.lucene.search.grouping.TopGroups