final class java.util.ArraysParallelSortHelpers$FJInt$Merger extends java.util.concurrent.CountedCompleter<java.lang.Void>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: java.util.ArraysParallelSortHelpers$FJInt$Merger
  super_class: java.util.concurrent.CountedCompleter
{
  static final long serialVersionUID;
    descriptor: J
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 2446542900576103244

  final int[] a;
    descriptor: [I
    flags: (0x0010) ACC_FINAL

  final int[] w;
    descriptor: [I
    flags: (0x0010) ACC_FINAL

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

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

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

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

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

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

  void <init>(java.util.concurrent.CountedCompleter<?>, int[], int[], int, int, int, int, int, );
    descriptor: (Ljava/util/concurrent/CountedCompleter;[I[IIIIIII)V
    flags: (0x0000) 
    Code:
      stack=2, locals=10, args_size=10
        start local 0 // java.util.ArraysParallelSortHelpers$FJInt$Merger this
        start local 1 // java.util.concurrent.CountedCompleter par
        start local 2 // int[] a
        start local 3 // int[] w
        start local 4 // int lbase
        start local 5 // int lsize
        start local 6 // int rbase
        start local 7 // int rsize
        start local 8 // int wbase
        start local 9 // int gran
         0: .line 608
            aload 0 /* this */
            aload 1 /* par */
            invokespecial java.util.concurrent.CountedCompleter.<init>:(Ljava/util/concurrent/CountedCompleter;)V
         1: .line 609
            aload 0 /* this */
            aload 2 /* a */
            putfield java.util.ArraysParallelSortHelpers$FJInt$Merger.a:[I
            aload 0 /* this */
            aload 3 /* w */
            putfield java.util.ArraysParallelSortHelpers$FJInt$Merger.w:[I
         2: .line 610
            aload 0 /* this */
            iload 4 /* lbase */
            putfield java.util.ArraysParallelSortHelpers$FJInt$Merger.lbase:I
            aload 0 /* this */
            iload 5 /* lsize */
            putfield java.util.ArraysParallelSortHelpers$FJInt$Merger.lsize:I
         3: .line 611
            aload 0 /* this */
            iload 6 /* rbase */
            putfield java.util.ArraysParallelSortHelpers$FJInt$Merger.rbase:I
            aload 0 /* this */
            iload 7 /* rsize */
            putfield java.util.ArraysParallelSortHelpers$FJInt$Merger.rsize:I
         4: .line 612
            aload 0 /* this */
            iload 8 /* wbase */
            putfield java.util.ArraysParallelSortHelpers$FJInt$Merger.wbase:I
            aload 0 /* this */
            iload 9 /* gran */
            putfield java.util.ArraysParallelSortHelpers$FJInt$Merger.gran:I
         5: .line 613
            return
        end local 9 // int gran
        end local 8 // int wbase
        end local 7 // int rsize
        end local 6 // int rbase
        end local 5 // int lsize
        end local 4 // int lbase
        end local 3 // int[] w
        end local 2 // int[] a
        end local 1 // java.util.concurrent.CountedCompleter par
        end local 0 // java.util.ArraysParallelSortHelpers$FJInt$Merger this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Ljava/util/ArraysParallelSortHelpers$FJInt$Merger;
            0    6     1    par  Ljava/util/concurrent/CountedCompleter<*>;
            0    6     2      a  [I
            0    6     3      w  [I
            0    6     4  lbase  I
            0    6     5  lsize  I
            0    6     6  rbase  I
            0    6     7  rsize  I
            0    6     8  wbase  I
            0    6     9   gran  I
    Signature: (Ljava/util/concurrent/CountedCompleter<*>;[I[IIIIIII)V
    MethodParameters:
       Name  Flags
      par    
      a      
      w      
      lbase  
      lsize  
      rbase  
      rsize  
      wbase  
      gran   

  public final void compute();
    descriptor: ()V
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=11, locals=14, args_size=1
        start local 0 // java.util.ArraysParallelSortHelpers$FJInt$Merger this
         0: .line 616
            aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJInt$Merger.a:[I
            astore 1 /* a */
        start local 1 // int[] a
         1: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJInt$Merger.w:[I
            astore 2 /* w */
        start local 2 // int[] w
         2: .line 617
            aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJInt$Merger.lbase:I
            istore 3 /* lb */
        start local 3 // int lb
         3: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJInt$Merger.lsize:I
            istore 4 /* ln */
        start local 4 // int ln
         4: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJInt$Merger.rbase:I
            istore 5 /* rb */
        start local 5 // int rb
         5: .line 618
            aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJInt$Merger.rsize:I
            istore 6 /* rn */
        start local 6 // int rn
         6: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJInt$Merger.wbase:I
            istore 7 /* k */
        start local 7 // int k
         7: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJInt$Merger.gran:I
            istore 8 /* g */
        start local 8 // int g
         8: .line 619
            aload 1 /* a */
            ifnull 9
            aload 2 /* w */
            ifnull 9
            iload 3 /* lb */
            iflt 9
            iload 5 /* rb */
            iflt 9
            iload 7 /* k */
            ifge 10
         9: .line 620
      StackMap locals: java.util.ArraysParallelSortHelpers$FJInt$Merger int[] int[] int int int int int int
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            invokespecial java.lang.IllegalStateException.<init>:()V
            athrow
        10: .line 622
      StackMap locals:
      StackMap stack:
            iload 4 /* ln */
            iload 6 /* rn */
            if_icmplt 24
        11: .line 623
            iload 4 /* ln */
            iload 8 /* g */
            if_icmpgt 13
        12: .line 624
            goto 45
        13: .line 625
      StackMap locals:
      StackMap stack:
            iload 6 /* rn */
            istore 10 /* rh */
        start local 10 // int rh
        14: .line 626
            aload 1 /* a */
            iload 4 /* ln */
            iconst_1
            iushr
            dup
            istore 9 /* lh */
        start local 9 // int lh
        15: iload 3 /* lb */
            iadd
            iaload
            istore 11 /* split */
        start local 11 // int split
        16: .line 627
            iconst_0
            istore 12 /* lo */
        start local 12 // int lo
        17: goto 22
        18: .line 628
      StackMap locals: java.util.ArraysParallelSortHelpers$FJInt$Merger int[] int[] int int int int int int int int int int
      StackMap stack:
            iload 12 /* lo */
            iload 10 /* rh */
            iadd
            iconst_1
            iushr
            istore 13 /* rm */
        start local 13 // int rm
        19: .line 629
            iload 11 /* split */
            aload 1 /* a */
            iload 13 /* rm */
            iload 5 /* rb */
            iadd
            iaload
            if_icmpgt 21
        20: .line 630
            iload 13 /* rm */
            istore 10 /* rh */
            goto 22
        21: .line 632
      StackMap locals: int
      StackMap stack:
            iload 13 /* rm */
            iconst_1
            iadd
            istore 12 /* lo */
        end local 13 // int rm
        22: .line 627
      StackMap locals:
      StackMap stack:
            iload 12 /* lo */
            iload 10 /* rh */
            if_icmplt 18
        end local 12 // int lo
        end local 11 // int split
        23: .line 634
            goto 36
        end local 10 // int rh
        end local 9 // int lh
        24: .line 636
      StackMap locals: java.util.ArraysParallelSortHelpers$FJInt$Merger int[] int[] int int int int int int
      StackMap stack:
            iload 6 /* rn */
            iload 8 /* g */
            if_icmpgt 26
        25: .line 637
            goto 45
        26: .line 638
      StackMap locals:
      StackMap stack:
            iload 4 /* ln */
            istore 9 /* lh */
        start local 9 // int lh
        27: .line 639
            aload 1 /* a */
            iload 6 /* rn */
            iconst_1
            iushr
            dup
            istore 10 /* rh */
        start local 10 // int rh
        28: iload 5 /* rb */
            iadd
            iaload
            istore 11 /* split */
        start local 11 // int split
        29: .line 640
            iconst_0
            istore 12 /* lo */
        start local 12 // int lo
        30: goto 35
        31: .line 641
      StackMap locals: java.util.ArraysParallelSortHelpers$FJInt$Merger int[] int[] int int int int int int int int int int
      StackMap stack:
            iload 12 /* lo */
            iload 9 /* lh */
            iadd
            iconst_1
            iushr
            istore 13 /* lm */
        start local 13 // int lm
        32: .line 642
            iload 11 /* split */
            aload 1 /* a */
            iload 13 /* lm */
            iload 3 /* lb */
            iadd
            iaload
            if_icmpgt 34
        33: .line 643
            iload 13 /* lm */
            istore 9 /* lh */
            goto 35
        34: .line 645
      StackMap locals: int
      StackMap stack:
            iload 13 /* lm */
            iconst_1
            iadd
            istore 12 /* lo */
        end local 13 // int lm
        35: .line 640
      StackMap locals:
      StackMap stack:
            iload 12 /* lo */
            iload 9 /* lh */
            if_icmplt 31
        end local 12 // int lo
        end local 11 // int split
        36: .line 648
      StackMap locals:
      StackMap stack:
            new java.util.ArraysParallelSortHelpers$FJInt$Merger
            dup
            aload 0 /* this */
            aload 1 /* a */
            aload 2 /* w */
            iload 3 /* lb */
            iload 9 /* lh */
            iadd
            iload 4 /* ln */
            iload 9 /* lh */
            isub
        37: .line 649
            iload 5 /* rb */
            iload 10 /* rh */
            iadd
            iload 6 /* rn */
            iload 10 /* rh */
            isub
        38: .line 650
            iload 7 /* k */
            iload 9 /* lh */
            iadd
            iload 10 /* rh */
            iadd
            iload 8 /* g */
        39: .line 648
            invokespecial java.util.ArraysParallelSortHelpers$FJInt$Merger.<init>:(Ljava/util/concurrent/CountedCompleter;[I[IIIIIII)V
            astore 11 /* m */
        start local 11 // java.util.ArraysParallelSortHelpers$FJInt$Merger m
        40: .line 651
            iload 10 /* rh */
            istore 6 /* rn */
        41: .line 652
            iload 9 /* lh */
            istore 4 /* ln */
        42: .line 653
            aload 0 /* this */
            iconst_1
            invokevirtual java.util.ArraysParallelSortHelpers$FJInt$Merger.addToPendingCount:(I)V
        43: .line 654
            aload 11 /* m */
            invokevirtual java.util.ArraysParallelSortHelpers$FJInt$Merger.fork:()Ljava/util/concurrent/ForkJoinTask;
            pop
        end local 11 // java.util.ArraysParallelSortHelpers$FJInt$Merger m
        end local 10 // int rh
        end local 9 // int lh
        44: .line 621
            goto 10
        45: .line 657
      StackMap locals:
      StackMap stack:
            iload 3 /* lb */
            iload 4 /* ln */
            iadd
            istore 9 /* lf */
        start local 9 // int lf
        46: iload 5 /* rb */
            iload 6 /* rn */
            iadd
            istore 10 /* rf */
        start local 10 // int rf
        47: .line 658
            goto 55
        48: .line 660
      StackMap locals: int int
      StackMap stack:
            aload 1 /* a */
            iload 3 /* lb */
            iaload
            dup
            istore 12 /* al */
        start local 12 // int al
        49: aload 1 /* a */
            iload 5 /* rb */
            iaload
            dup
            istore 13 /* ar */
        start local 13 // int ar
        50: if_icmpgt 53
        51: .line 661
            iinc 3 /* lb */ 1
            iload 12 /* al */
            istore 11 /* t */
        start local 11 // int t
        52: .line 662
            goto 54
        end local 11 // int t
        53: .line 664
      StackMap locals: java.util.ArraysParallelSortHelpers$FJInt$Merger int[] int[] int int int int int int int int top int int
      StackMap stack:
            iinc 5 /* rb */ 1
            iload 13 /* ar */
            istore 11 /* t */
        start local 11 // int t
        54: .line 666
      StackMap locals: java.util.ArraysParallelSortHelpers$FJInt$Merger int[] int[] int int int int int int int int int int int
      StackMap stack:
            aload 2 /* w */
            iload 7 /* k */
            iinc 7 /* k */ 1
            iload 11 /* t */
            iastore
        end local 13 // int ar
        end local 12 // int al
        end local 11 // int t
        55: .line 658
      StackMap locals:
      StackMap stack:
            iload 3 /* lb */
            iload 9 /* lf */
            if_icmpge 56
            iload 5 /* rb */
            iload 10 /* rf */
            if_icmplt 48
        56: .line 668
      StackMap locals:
      StackMap stack:
            iload 5 /* rb */
            iload 10 /* rf */
            if_icmpge 58
        57: .line 669
            aload 1 /* a */
            iload 5 /* rb */
            aload 2 /* w */
            iload 7 /* k */
            iload 10 /* rf */
            iload 5 /* rb */
            isub
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
            goto 60
        58: .line 670
      StackMap locals:
      StackMap stack:
            iload 3 /* lb */
            iload 9 /* lf */
            if_icmpge 60
        59: .line 671
            aload 1 /* a */
            iload 3 /* lb */
            aload 2 /* w */
            iload 7 /* k */
            iload 9 /* lf */
            iload 3 /* lb */
            isub
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        60: .line 672
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.ArraysParallelSortHelpers$FJInt$Merger.tryComplete:()V
        61: .line 673
            return
        end local 10 // int rf
        end local 9 // int lf
        end local 8 // int g
        end local 7 // int k
        end local 6 // int rn
        end local 5 // int rb
        end local 4 // int ln
        end local 3 // int lb
        end local 2 // int[] w
        end local 1 // int[] a
        end local 0 // java.util.ArraysParallelSortHelpers$FJInt$Merger this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   62     0   this  Ljava/util/ArraysParallelSortHelpers$FJInt$Merger;
            1   62     1      a  [I
            2   62     2      w  [I
            3   62     3     lb  I
            4   62     4     ln  I
            5   62     5     rb  I
            6   62     6     rn  I
            7   62     7      k  I
            8   62     8      g  I
           15   24     9     lh  I
           27   44     9     lh  I
           14   24    10     rh  I
           28   44    10     rh  I
           16   23    11  split  I
           17   23    12     lo  I
           19   22    13     rm  I
           29   36    11  split  I
           30   36    12     lo  I
           32   35    13     lm  I
           40   44    11      m  Ljava/util/ArraysParallelSortHelpers$FJInt$Merger;
           46   62     9     lf  I
           47   62    10     rf  I
           52   53    11      t  I
           54   55    11      t  I
           49   55    12     al  I
           50   55    13     ar  I
}
Signature: Ljava/util/concurrent/CountedCompleter<Ljava/lang/Void;>;
SourceFile: "ArraysParallelSortHelpers.java"
NestHost: java.util.ArraysParallelSortHelpers
InnerClasses:
  final FJInt = java.util.ArraysParallelSortHelpers$FJInt of java.util.ArraysParallelSortHelpers
  final Merger = java.util.ArraysParallelSortHelpers$FJInt$Merger of java.util.ArraysParallelSortHelpers$FJInt