final class java.util.ArraysParallelSortHelpers$FJByte$Sorter 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$FJByte$Sorter
  super_class: java.util.concurrent.CountedCompleter
{
  static final long serialVersionUID;
    descriptor: J
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 2446542900576103244

  final byte[] a;
    descriptor: [B
    flags: (0x0010) ACC_FINAL

  final byte[] w;
    descriptor: [B
    flags: (0x0010) ACC_FINAL

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

  final int size;
    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<?>, byte[], byte[], int, int, int, );
    descriptor: (Ljava/util/concurrent/CountedCompleter;[B[BIIII)V
    flags: (0x0000) 
    Code:
      stack=2, locals=8, args_size=8
        start local 0 // java.util.ArraysParallelSortHelpers$FJByte$Sorter this
        start local 1 // java.util.concurrent.CountedCompleter par
        start local 2 // byte[] a
        start local 3 // byte[] w
        start local 4 // int base
        start local 5 // int size
        start local 6 // int wbase
        start local 7 // int gran
         0: .line 241
            aload 0 /* this */
            aload 1 /* par */
            invokespecial java.util.concurrent.CountedCompleter.<init>:(Ljava/util/concurrent/CountedCompleter;)V
         1: .line 242
            aload 0 /* this */
            aload 2 /* a */
            putfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.a:[B
            aload 0 /* this */
            aload 3 /* w */
            putfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.w:[B
            aload 0 /* this */
            iload 4 /* base */
            putfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.base:I
            aload 0 /* this */
            iload 5 /* size */
            putfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.size:I
         2: .line 243
            aload 0 /* this */
            iload 6 /* wbase */
            putfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.wbase:I
            aload 0 /* this */
            iload 7 /* gran */
            putfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.gran:I
         3: .line 244
            return
        end local 7 // int gran
        end local 6 // int wbase
        end local 5 // int size
        end local 4 // int base
        end local 3 // byte[] w
        end local 2 // byte[] a
        end local 1 // java.util.concurrent.CountedCompleter par
        end local 0 // java.util.ArraysParallelSortHelpers$FJByte$Sorter this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Ljava/util/ArraysParallelSortHelpers$FJByte$Sorter;
            0    4     1    par  Ljava/util/concurrent/CountedCompleter<*>;
            0    4     2      a  [B
            0    4     3      w  [B
            0    4     4   base  I
            0    4     5   size  I
            0    4     6  wbase  I
            0    4     7   gran  I
    Signature: (Ljava/util/concurrent/CountedCompleter<*>;[B[BIIII)V
    MethodParameters:
       Name  Flags
      par    
      a      
      w      
      base   
      size   
      wbase  
      gran   

  public final void compute();
    descriptor: ()V
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=13, locals=14, args_size=1
        start local 0 // java.util.ArraysParallelSortHelpers$FJByte$Sorter this
         0: .line 246
            aload 0 /* this */
            astore 1 /* s */
        start local 1 // java.util.concurrent.CountedCompleter s
         1: .line 247
            aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.a:[B
            astore 2 /* a */
        start local 2 // byte[] a
         2: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.w:[B
            astore 3 /* w */
        start local 3 // byte[] w
         3: .line 248
            aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.base:I
            istore 4 /* b */
        start local 4 // int b
         4: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.size:I
            istore 5 /* n */
        start local 5 // int n
         5: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.wbase:I
            istore 6 /* wb */
        start local 6 // int wb
         6: aload 0 /* this */
            getfield java.util.ArraysParallelSortHelpers$FJByte$Sorter.gran:I
            istore 7 /* g */
        start local 7 // int g
         7: .line 249
            goto 25
         8: .line 250
      StackMap locals: java.util.ArraysParallelSortHelpers$FJByte$Sorter java.util.concurrent.CountedCompleter byte[] byte[] int int int int
      StackMap stack:
            iload 5 /* n */
            iconst_1
            iushr
            istore 8 /* h */
        start local 8 // int h
         9: iload 8 /* h */
            iconst_1
            iushr
            istore 9 /* q */
        start local 9 // int q
        10: iload 8 /* h */
            iload 9 /* q */
            iadd
            istore 10 /* u */
        start local 10 // int u
        11: .line 251
            new java.util.ArraysParallelSortHelpers$Relay
            dup
            new java.util.ArraysParallelSortHelpers$FJByte$Merger
            dup
            aload 1 /* s */
            aload 3 /* w */
            aload 2 /* a */
            iload 6 /* wb */
            iload 8 /* h */
        12: .line 252
            iload 6 /* wb */
            iload 8 /* h */
            iadd
            iload 5 /* n */
            iload 8 /* h */
            isub
            iload 4 /* b */
            iload 7 /* g */
            invokespecial java.util.ArraysParallelSortHelpers$FJByte$Merger.<init>:(Ljava/util/concurrent/CountedCompleter;[B[BIIIIII)V
        13: .line 251
            invokespecial java.util.ArraysParallelSortHelpers$Relay.<init>:(Ljava/util/concurrent/CountedCompleter;)V
            astore 11 /* fc */
        start local 11 // java.util.ArraysParallelSortHelpers$Relay fc
        14: .line 253
            new java.util.ArraysParallelSortHelpers$Relay
            dup
            new java.util.ArraysParallelSortHelpers$FJByte$Merger
            dup
            aload 11 /* fc */
            aload 2 /* a */
            aload 3 /* w */
            iload 4 /* b */
            iload 8 /* h */
            iadd
            iload 9 /* q */
        15: .line 254
            iload 4 /* b */
            iload 10 /* u */
            iadd
            iload 5 /* n */
            iload 10 /* u */
            isub
            iload 6 /* wb */
            iload 8 /* h */
            iadd
            iload 7 /* g */
            invokespecial java.util.ArraysParallelSortHelpers$FJByte$Merger.<init>:(Ljava/util/concurrent/CountedCompleter;[B[BIIIIII)V
        16: .line 253
            invokespecial java.util.ArraysParallelSortHelpers$Relay.<init>:(Ljava/util/concurrent/CountedCompleter;)V
            astore 12 /* rc */
        start local 12 // java.util.ArraysParallelSortHelpers$Relay rc
        17: .line 255
            new java.util.ArraysParallelSortHelpers$FJByte$Sorter
            dup
            aload 12 /* rc */
            aload 2 /* a */
            aload 3 /* w */
            iload 4 /* b */
            iload 10 /* u */
            iadd
            iload 5 /* n */
            iload 10 /* u */
            isub
            iload 6 /* wb */
            iload 10 /* u */
            iadd
            iload 7 /* g */
            invokespecial java.util.ArraysParallelSortHelpers$FJByte$Sorter.<init>:(Ljava/util/concurrent/CountedCompleter;[B[BIIII)V
            invokevirtual java.util.ArraysParallelSortHelpers$FJByte$Sorter.fork:()Ljava/util/concurrent/ForkJoinTask;
            pop
        18: .line 256
            new java.util.ArraysParallelSortHelpers$FJByte$Sorter
            dup
            aload 12 /* rc */
            aload 2 /* a */
            aload 3 /* w */
            iload 4 /* b */
            iload 8 /* h */
            iadd
            iload 9 /* q */
            iload 6 /* wb */
            iload 8 /* h */
            iadd
            iload 7 /* g */
            invokespecial java.util.ArraysParallelSortHelpers$FJByte$Sorter.<init>:(Ljava/util/concurrent/CountedCompleter;[B[BIIII)V
            invokevirtual java.util.ArraysParallelSortHelpers$FJByte$Sorter.fork:()Ljava/util/concurrent/ForkJoinTask;
            pop
        19: .line 257
            new java.util.ArraysParallelSortHelpers$Relay
            dup
            new java.util.ArraysParallelSortHelpers$FJByte$Merger
            dup
            aload 11 /* fc */
            aload 2 /* a */
            aload 3 /* w */
            iload 4 /* b */
            iload 9 /* q */
        20: .line 258
            iload 4 /* b */
            iload 9 /* q */
            iadd
            iload 8 /* h */
            iload 9 /* q */
            isub
            iload 6 /* wb */
            iload 7 /* g */
            invokespecial java.util.ArraysParallelSortHelpers$FJByte$Merger.<init>:(Ljava/util/concurrent/CountedCompleter;[B[BIIIIII)V
        21: .line 257
            invokespecial java.util.ArraysParallelSortHelpers$Relay.<init>:(Ljava/util/concurrent/CountedCompleter;)V
            astore 13 /* bc */
        start local 13 // java.util.ArraysParallelSortHelpers$Relay bc
        22: .line 259
            new java.util.ArraysParallelSortHelpers$FJByte$Sorter
            dup
            aload 13 /* bc */
            aload 2 /* a */
            aload 3 /* w */
            iload 4 /* b */
            iload 9 /* q */
            iadd
            iload 8 /* h */
            iload 9 /* q */
            isub
            iload 6 /* wb */
            iload 9 /* q */
            iadd
            iload 7 /* g */
            invokespecial java.util.ArraysParallelSortHelpers$FJByte$Sorter.<init>:(Ljava/util/concurrent/CountedCompleter;[B[BIIII)V
            invokevirtual java.util.ArraysParallelSortHelpers$FJByte$Sorter.fork:()Ljava/util/concurrent/ForkJoinTask;
            pop
        23: .line 260
            new java.util.ArraysParallelSortHelpers$EmptyCompleter
            dup
            aload 13 /* bc */
            invokespecial java.util.ArraysParallelSortHelpers$EmptyCompleter.<init>:(Ljava/util/concurrent/CountedCompleter;)V
            astore 1 /* s */
        24: .line 261
            iload 9 /* q */
            istore 5 /* n */
        end local 13 // java.util.ArraysParallelSortHelpers$Relay bc
        end local 12 // java.util.ArraysParallelSortHelpers$Relay rc
        end local 11 // java.util.ArraysParallelSortHelpers$Relay fc
        end local 10 // int u
        end local 9 // int q
        end local 8 // int h
        25: .line 249
      StackMap locals:
      StackMap stack:
            iload 5 /* n */
            iload 7 /* g */
            if_icmpgt 8
        26: .line 263
            aload 2 /* a */
            iload 4 /* b */
            iload 4 /* b */
            iload 5 /* n */
            iadd
            iconst_1
            isub
            invokestatic java.util.DualPivotQuicksort.sort:([BII)V
        27: .line 264
            aload 1 /* s */
            invokevirtual java.util.concurrent.CountedCompleter.tryComplete:()V
        28: .line 265
            return
        end local 7 // int g
        end local 6 // int wb
        end local 5 // int n
        end local 4 // int b
        end local 3 // byte[] w
        end local 2 // byte[] a
        end local 1 // java.util.concurrent.CountedCompleter s
        end local 0 // java.util.ArraysParallelSortHelpers$FJByte$Sorter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   29     0  this  Ljava/util/ArraysParallelSortHelpers$FJByte$Sorter;
            1   29     1     s  Ljava/util/concurrent/CountedCompleter<*>;
            2   29     2     a  [B
            3   29     3     w  [B
            4   29     4     b  I
            5   29     5     n  I
            6   29     6    wb  I
            7   29     7     g  I
            9   25     8     h  I
           10   25     9     q  I
           11   25    10     u  I
           14   25    11    fc  Ljava/util/ArraysParallelSortHelpers$Relay;
           17   25    12    rc  Ljava/util/ArraysParallelSortHelpers$Relay;
           22   25    13    bc  Ljava/util/ArraysParallelSortHelpers$Relay;
}
Signature: Ljava/util/concurrent/CountedCompleter<Ljava/lang/Void;>;
SourceFile: "ArraysParallelSortHelpers.java"
NestHost: java.util.ArraysParallelSortHelpers
InnerClasses:
  final EmptyCompleter = java.util.ArraysParallelSortHelpers$EmptyCompleter of java.util.ArraysParallelSortHelpers
  final FJByte = java.util.ArraysParallelSortHelpers$FJByte of java.util.ArraysParallelSortHelpers
  final Merger = java.util.ArraysParallelSortHelpers$FJByte$Merger of java.util.ArraysParallelSortHelpers$FJByte
  final Sorter = java.util.ArraysParallelSortHelpers$FJByte$Sorter of java.util.ArraysParallelSortHelpers$FJByte
  final Relay = java.util.ArraysParallelSortHelpers$Relay of java.util.ArraysParallelSortHelpers