public final class org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner<T, BT extends org.eclipse.collections.api.block.procedure.primitive.ObjectIntProcedure<? super T>>
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner
  super_class: java.lang.Object
{
  private final org.eclipse.collections.api.block.function.Function<org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask<T, BT>, BT> procedureFunction;
    descriptor: Lorg/eclipse/collections/api/block/function/Function;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lorg/eclipse/collections/api/block/function/Function<Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask<TT;TBT;>;TBT;>;

  private org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask<T, BT>[] procedures;
    descriptor: [Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask;
    flags: (0x0002) ACC_PRIVATE
    Signature: [Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask<TT;TBT;>;

  private java.lang.Throwable error;
    descriptor: Ljava/lang/Throwable;
    flags: (0x0002) ACC_PRIVATE

  private final org.eclipse.collections.impl.parallel.Combiner<BT> combiner;
    descriptor: Lorg/eclipse/collections/impl/parallel/Combiner;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;

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

  private final java.util.concurrent.BlockingQueue<BT> outputQueue;
    descriptor: Ljava/util/concurrent/BlockingQueue;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/BlockingQueue<TBT;>;

  private final java.util.concurrent.CountDownLatch latch;
    descriptor: Ljava/util/concurrent/CountDownLatch;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>(org.eclipse.collections.impl.parallel.Combiner<BT>, );
    descriptor: (Lorg/eclipse/collections/impl/parallel/Combiner;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
        start local 1 // org.eclipse.collections.impl.parallel.Combiner newCombiner
        start local 2 // int taskCount
         0: .line 35
            aload 0 /* this */
            aload 1 /* newCombiner */
            iload 2 /* taskCount */
         1: .line 36
            aload 1 /* newCombiner */
            iload 2 /* taskCount */
            invokestatic org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.buildQueue:(Lorg/eclipse/collections/impl/parallel/Combiner;I)Ljava/util/concurrent/ArrayBlockingQueue;
         2: .line 37
            aload 1 /* newCombiner */
            iload 2 /* taskCount */
            invokestatic org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.buildCountDownLatch:(Lorg/eclipse/collections/impl/parallel/Combiner;I)Ljava/util/concurrent/CountDownLatch;
            invokespecial org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.<init>:(Lorg/eclipse/collections/impl/parallel/Combiner;ILjava/util/concurrent/BlockingQueue;Ljava/util/concurrent/CountDownLatch;)V
         3: .line 38
            return
        end local 2 // int taskCount
        end local 1 // org.eclipse.collections.impl.parallel.Combiner newCombiner
        end local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner<TT;TBT;>;
            0    4     1  newCombiner  Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;
            0    4     2    taskCount  I
    Signature: (Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;I)V
    MethodParameters:
             Name  Flags
      newCombiner  
      taskCount    

  void <init>(org.eclipse.collections.impl.parallel.Combiner<BT>, int, java.util.concurrent.BlockingQueue<BT>, java.util.concurrent.CountDownLatch);
    descriptor: (Lorg/eclipse/collections/impl/parallel/Combiner;ILjava/util/concurrent/BlockingQueue;Ljava/util/concurrent/CountDownLatch;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
        start local 1 // org.eclipse.collections.impl.parallel.Combiner newCombiner
        start local 2 // int taskCount
        start local 3 // java.util.concurrent.BlockingQueue queue
        start local 4 // java.util.concurrent.CountDownLatch latch
         0: .line 40
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 25
            aload 0 /* this */
            new org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner$ObjectIntProcedureExtractor
            dup
            aload 0 /* this */
            invokespecial org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner$ObjectIntProcedureExtractor.<init>:(Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner;)V
            putfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.procedureFunction:Lorg/eclipse/collections/api/block/function/Function;
         2: .line 42
            aload 0 /* this */
            aload 1 /* newCombiner */
            putfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.combiner:Lorg/eclipse/collections/impl/parallel/Combiner;
         3: .line 43
            aload 0 /* this */
            iload 2 /* taskCount */
            putfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.taskCount:I
         4: .line 44
            aload 0 /* this */
            aload 3 /* queue */
            putfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.outputQueue:Ljava/util/concurrent/BlockingQueue;
         5: .line 45
            aload 0 /* this */
            aload 4 /* latch */
            putfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.latch:Ljava/util/concurrent/CountDownLatch;
         6: .line 46
            return
        end local 4 // java.util.concurrent.CountDownLatch latch
        end local 3 // java.util.concurrent.BlockingQueue queue
        end local 2 // int taskCount
        end local 1 // org.eclipse.collections.impl.parallel.Combiner newCombiner
        end local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner<TT;TBT;>;
            0    7     1  newCombiner  Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;
            0    7     2    taskCount  I
            0    7     3        queue  Ljava/util/concurrent/BlockingQueue<TBT;>;
            0    7     4        latch  Ljava/util/concurrent/CountDownLatch;
    Signature: (Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;ILjava/util/concurrent/BlockingQueue<TBT;>;Ljava/util/concurrent/CountDownLatch;)V
    MethodParameters:
             Name  Flags
      newCombiner  
      taskCount    
      queue        
      latch        

  private static <BT> java.util.concurrent.CountDownLatch buildCountDownLatch(org.eclipse.collections.impl.parallel.Combiner<BT>, int);
    descriptor: (Lorg/eclipse/collections/impl/parallel/Combiner;I)Ljava/util/concurrent/CountDownLatch;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.eclipse.collections.impl.parallel.Combiner newCombiner
        start local 1 // int taskCount
         0: .line 50
            aload 0 /* newCombiner */
            invokeinterface org.eclipse.collections.impl.parallel.Combiner.useCombineOne:()Z
            ifeq 1
            aconst_null
            goto 2
      StackMap locals:
      StackMap stack:
         1: new java.util.concurrent.CountDownLatch
            dup
            iload 1 /* taskCount */
            invokespecial java.util.concurrent.CountDownLatch.<init>:(I)V
      StackMap locals:
      StackMap stack: java.util.concurrent.CountDownLatch
         2: areturn
        end local 1 // int taskCount
        end local 0 // org.eclipse.collections.impl.parallel.Combiner newCombiner
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0  newCombiner  Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;
            0    3     1    taskCount  I
    Signature: <BT:Ljava/lang/Object;>(Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;I)Ljava/util/concurrent/CountDownLatch;
    MethodParameters:
             Name  Flags
      newCombiner  
      taskCount    

  private static <BT> java.util.concurrent.ArrayBlockingQueue<BT> buildQueue(org.eclipse.collections.impl.parallel.Combiner<BT>, int);
    descriptor: (Lorg/eclipse/collections/impl/parallel/Combiner;I)Ljava/util/concurrent/ArrayBlockingQueue;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.eclipse.collections.impl.parallel.Combiner newCombiner
        start local 1 // int taskCount
         0: .line 55
            aload 0 /* newCombiner */
            invokeinterface org.eclipse.collections.impl.parallel.Combiner.useCombineOne:()Z
            ifeq 1
            new java.util.concurrent.ArrayBlockingQueue
            dup
            iload 1 /* taskCount */
            invokespecial java.util.concurrent.ArrayBlockingQueue.<init>:(I)V
            goto 2
      StackMap locals:
      StackMap stack:
         1: aconst_null
      StackMap locals:
      StackMap stack: java.util.concurrent.ArrayBlockingQueue
         2: areturn
        end local 1 // int taskCount
        end local 0 // org.eclipse.collections.impl.parallel.Combiner newCombiner
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0  newCombiner  Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;
            0    3     1    taskCount  I
    Signature: <BT:Ljava/lang/Object;>(Lorg/eclipse/collections/impl/parallel/Combiner<TBT;>;I)Ljava/util/concurrent/ArrayBlockingQueue<TBT;>;
    MethodParameters:
             Name  Flags
      newCombiner  
      taskCount    

  private void createAndExecuteTasks(java.util.concurrent.Executor, org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory<BT>, java.util.List<T>);
    descriptor: (Ljava/util/concurrent/Executor;Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFactory;Ljava/util/List;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=10, locals=7, args_size=4
        start local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
        start local 1 // java.util.concurrent.Executor executor
        start local 2 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory procedureFactory
        start local 3 // java.util.List list
         0: .line 60
            aload 0 /* this */
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.taskCount:I
            anewarray org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask
            putfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.procedures:[Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask;
         1: .line 62
            aload 3 /* list */
            invokeinterface java.util.List.size:()I
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.taskCount:I
            idiv
            istore 4 /* sectionSize */
        start local 4 // int sectionSize
         2: .line 63
            iconst_0
            istore 5 /* index */
        start local 5 // int index
         3: goto 11
         4: .line 66
      StackMap locals: int int
      StackMap stack:
            new org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask
            dup
            aload 0 /* this */
            aload 2 /* procedureFactory */
            aload 3 /* list */
            iload 5 /* index */
            iload 4 /* sectionSize */
            iload 5 /* index */
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.taskCount:I
            iconst_1
            isub
            if_icmpne 5
            iconst_1
            goto 6
      StackMap locals: org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner java.util.concurrent.Executor org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory java.util.List int int
      StackMap stack: new 4 new 4 org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory java.util.List int int
         5: iconst_0
      StackMap locals: org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner java.util.concurrent.Executor org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory java.util.List int int
      StackMap stack: new 4 new 4 org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory java.util.List int int int
         6: invokespecial org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask.<init>:(Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner;Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFactory;Ljava/util/List;IIZ)V
         7: .line 65
            astore 6 /* procedureFJTask */
        start local 6 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask procedureFJTask
         8: .line 67
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.procedures:[Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask;
            iload 5 /* index */
            aload 6 /* procedureFJTask */
            aastore
         9: .line 68
            aload 1 /* executor */
            aload 6 /* procedureFJTask */
            invokeinterface java.util.concurrent.Executor.execute:(Ljava/lang/Runnable;)V
        end local 6 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask procedureFJTask
        10: .line 63
            iinc 5 /* index */ 1
      StackMap locals:
      StackMap stack:
        11: iload 5 /* index */
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.taskCount:I
            if_icmplt 4
        end local 5 // int index
        12: .line 70
            return
        end local 4 // int sectionSize
        end local 3 // java.util.List list
        end local 2 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory procedureFactory
        end local 1 // java.util.concurrent.Executor executor
        end local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   13     0              this  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner<TT;TBT;>;
            0   13     1          executor  Ljava/util/concurrent/Executor;
            0   13     2  procedureFactory  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFactory<TBT;>;
            0   13     3              list  Ljava/util/List<TT;>;
            2   13     4       sectionSize  I
            3   12     5             index  I
            8   10     6   procedureFJTask  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask<TT;TBT;>;
    Signature: (Ljava/util/concurrent/Executor;Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFactory<TBT;>;Ljava/util/List<TT;>;)V
    MethodParameters:
                  Name  Flags
      executor          
      procedureFactory  
      list              

  public void setFailed(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
        start local 1 // java.lang.Throwable newError
         0: .line 74
            aload 0 /* this */
            aload 1 /* newError */
            putfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.error:Ljava/lang/Throwable;
         1: .line 75
            return
        end local 1 // java.lang.Throwable newError
        end local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner<TT;TBT;>;
            0    2     1  newError  Ljava/lang/Throwable;
    MethodParameters:
          Name  Flags
      newError  

  public void taskCompleted(org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask<T, BT>);
    descriptor: (Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
        start local 1 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask task
         0: .line 79
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.combiner:Lorg/eclipse/collections/impl/parallel/Combiner;
            invokeinterface org.eclipse.collections.impl.parallel.Combiner.useCombineOne:()Z
            ifeq 3
         1: .line 81
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.outputQueue:Ljava/util/concurrent/BlockingQueue;
            aload 1 /* task */
            invokevirtual org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask.getProcedure:()Lorg/eclipse/collections/api/block/procedure/primitive/ObjectIntProcedure;
            invokeinterface java.util.concurrent.BlockingQueue.add:(Ljava/lang/Object;)Z
            pop
         2: .line 82
            goto 4
         3: .line 85
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.latch:Ljava/util/concurrent/CountDownLatch;
            invokevirtual java.util.concurrent.CountDownLatch.countDown:()V
         4: .line 87
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTask task
        end local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner<TT;TBT;>;
            0    5     1  task  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask<TT;TBT;>;
    Signature: (Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask<TT;TBT;>;)V
    MethodParameters:
      Name  Flags
      task  

  public void executeAndCombine(java.util.concurrent.Executor, org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory<BT>, java.util.List<T>);
    descriptor: (Ljava/util/concurrent/Executor;Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFactory;Ljava/util/List;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
        start local 1 // java.util.concurrent.Executor executor
        start local 2 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory procedureFactory
        start local 3 // java.util.List list
         0: .line 91
            aload 0 /* this */
            aload 1 /* executor */
            aload 2 /* procedureFactory */
            aload 3 /* list */
            invokevirtual org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.createAndExecuteTasks:(Ljava/util/concurrent/Executor;Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFactory;Ljava/util/List;)V
         1: .line 92
            aload 0 /* this */
            invokevirtual org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.join:()V
         2: .line 93
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.error:Ljava/lang/Throwable;
            ifnull 4
         3: .line 95
            new java.lang.RuntimeException
            dup
            ldc "One or more parallel tasks failed"
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.error:Ljava/lang/Throwable;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
         4: .line 98
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.combineTasks:()V
         5: .line 99
            return
        end local 3 // java.util.List list
        end local 2 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFactory procedureFactory
        end local 1 // java.util.concurrent.Executor executor
        end local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    6     0              this  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner<TT;TBT;>;
            0    6     1          executor  Ljava/util/concurrent/Executor;
            0    6     2  procedureFactory  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFactory<TBT;>;
            0    6     3              list  Ljava/util/List<TT;>;
    Signature: (Ljava/util/concurrent/Executor;Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFactory<TBT;>;Ljava/util/List<TT;>;)V
    MethodParameters:
                  Name  Flags
      executor          
      procedureFactory  
      list              

  private void join();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
         0: .line 105
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.combiner:Lorg/eclipse/collections/impl/parallel/Combiner;
            invokeinterface org.eclipse.collections.impl.parallel.Combiner.useCombineOne:()Z
            ifeq 7
         1: .line 107
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.taskCount:I
            istore 1 /* remaingTaskCount */
        start local 1 // int remaingTaskCount
         2: .line 108
            goto 5
         3: .line 110
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.combiner:Lorg/eclipse/collections/impl/parallel/Combiner;
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.outputQueue:Ljava/util/concurrent/BlockingQueue;
            invokeinterface java.util.concurrent.BlockingQueue.take:()Ljava/lang/Object;
            checkcast org.eclipse.collections.api.block.procedure.primitive.ObjectIntProcedure
            invokeinterface org.eclipse.collections.impl.parallel.Combiner.combineOne:(Ljava/lang/Object;)V
         4: .line 111
            iinc 1 /* remaingTaskCount */ -1
         5: .line 108
      StackMap locals:
      StackMap stack:
            iload 1 /* remaingTaskCount */
            ifgt 3
        end local 1 // int remaingTaskCount
         6: .line 113
            goto 11
         7: .line 116
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.latch:Ljava/util/concurrent/CountDownLatch;
            invokevirtual java.util.concurrent.CountDownLatch.await:()V
         8: .line 118
            goto 11
         9: .line 119
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
            astore 1 /* e */
        start local 1 // java.lang.InterruptedException e
        10: .line 121
            new java.lang.RuntimeException
            dup
            ldc "Combine failed"
            aload 1 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.lang.InterruptedException e
        11: .line 123
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   12     0              this  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner<TT;TBT;>;
            2    6     1  remaingTaskCount  I
           10   11     1                 e  Ljava/lang/InterruptedException;
      Exception table:
        from    to  target  type
           0     8       9  Class java.lang.InterruptedException

  private void combineTasks();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
         0: .line 127
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.combiner:Lorg/eclipse/collections/impl/parallel/Combiner;
            invokeinterface org.eclipse.collections.impl.parallel.Combiner.useCombineOne:()Z
            ifne 2
         1: .line 129
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.combiner:Lorg/eclipse/collections/impl/parallel/Combiner;
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.procedures:[Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTask;
            aload 0 /* this */
            getfield org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner.procedureFunction:Lorg/eclipse/collections/api/block/function/Function;
            invokestatic org.eclipse.collections.impl.utility.ArrayIterate.collect:([Ljava/lang/Object;Lorg/eclipse/collections/api/block/function/Function;)Lorg/eclipse/collections/api/list/MutableList;
            invokeinterface org.eclipse.collections.impl.parallel.Combiner.combineAll:(Ljava/lang/Iterable;)V
         2: .line 131
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/eclipse/collections/impl/parallel/ObjectIntProcedureFJTaskRunner<TT;TBT;>;
}
Signature: <T:Ljava/lang/Object;BT::Lorg/eclipse/collections/api/block/procedure/primitive/ObjectIntProcedure<-TT;>;>Ljava/lang/Object;
SourceFile: "ObjectIntProcedureFJTaskRunner.java"
NestMembers:
  org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner$ObjectIntProcedureExtractor
InnerClasses:
  private final ObjectIntProcedureExtractor = org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner$ObjectIntProcedureExtractor of org.eclipse.collections.impl.parallel.ObjectIntProcedureFJTaskRunner