class org.apache.cassandra.repair.RepairRunnable$2 implements com.google.common.util.concurrent.AsyncFunction<java.util.List<org.apache.cassandra.repair.RepairSessionResult>, java.lang.Object>
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.apache.cassandra.repair.RepairRunnable$2
  super_class: java.lang.Object
{
  final org.apache.cassandra.repair.RepairRunnable this$0;
    descriptor: Lorg/apache/cassandra/repair/RepairRunnable;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  private final java.util.Collection val$successfulRanges;
    descriptor: Ljava/util/Collection;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  private final java.util.concurrent.atomic.AtomicBoolean val$hasFailure;
    descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  private final java.util.UUID val$parentSession;
    descriptor: Ljava/util/UUID;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  private final java.util.Set val$allNeighbors;
    descriptor: Ljava/util/Set;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  void <init>(org.apache.cassandra.repair.RepairRunnable, java.util.Collection, java.util.concurrent.atomic.AtomicBoolean, java.util.UUID, java.util.Set);
    descriptor: (Lorg/apache/cassandra/repair/RepairRunnable;Ljava/util/Collection;Ljava/util/concurrent/atomic/AtomicBoolean;Ljava/util/UUID;Ljava/util/Set;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=6, args_size=6
        start local 0 // org.apache.cassandra.repair.RepairRunnable$2 this
         0: .line 292
            aload 0 /* this */
            aload 1
            putfield org.apache.cassandra.repair.RepairRunnable$2.this$0:Lorg/apache/cassandra/repair/RepairRunnable;
            aload 0 /* this */
            aload 2
            putfield org.apache.cassandra.repair.RepairRunnable$2.val$successfulRanges:Ljava/util/Collection;
            aload 0 /* this */
            aload 3
            putfield org.apache.cassandra.repair.RepairRunnable$2.val$hasFailure:Ljava/util/concurrent/atomic/AtomicBoolean;
            aload 0 /* this */
            aload 4
            putfield org.apache.cassandra.repair.RepairRunnable$2.val$parentSession:Ljava/util/UUID;
            aload 0 /* this */
            aload 5
            putfield org.apache.cassandra.repair.RepairRunnable$2.val$allNeighbors:Ljava/util/Set;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.cassandra.repair.RepairRunnable$2 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/repair/RepairRunnable$2;
    MethodParameters:
                      Name  Flags
      this$0                final
      val$successfulRanges  final
      val$hasFailure        final
      val$parentSession     final
      val$allNeighbors      final

  public com.google.common.util.concurrent.ListenableFuture apply(java.util.List<org.apache.cassandra.repair.RepairSessionResult>);
    descriptor: (Ljava/util/List;)Lcom/google/common/util/concurrent/ListenableFuture;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.apache.cassandra.repair.RepairRunnable$2 this
        start local 1 // java.util.List results
         0: .line 298
            aload 1 /* results */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 6
      StackMap locals: org.apache.cassandra.repair.RepairRunnable$2 java.util.List top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.repair.RepairSessionResult
            astore 2 /* sessionResult */
        start local 2 // org.apache.cassandra.repair.RepairSessionResult sessionResult
         2: .line 300
            aload 2 /* sessionResult */
            ifnull 5
         3: .line 302
            aload 0 /* this */
            getfield org.apache.cassandra.repair.RepairRunnable$2.val$successfulRanges:Ljava/util/Collection;
            aload 2 /* sessionResult */
            getfield org.apache.cassandra.repair.RepairSessionResult.ranges:Ljava/util/Collection;
            invokeinterface java.util.Collection.addAll:(Ljava/util/Collection;)Z
            pop
         4: .line 303
            goto 6
         5: .line 306
      StackMap locals: org.apache.cassandra.repair.RepairRunnable$2 java.util.List org.apache.cassandra.repair.RepairSessionResult java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.repair.RepairRunnable$2.val$hasFailure:Ljava/util/concurrent/atomic/AtomicBoolean;
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
            pop
        end local 2 // org.apache.cassandra.repair.RepairSessionResult sessionResult
         6: .line 298
      StackMap locals: org.apache.cassandra.repair.RepairRunnable$2 java.util.List top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         7: .line 309
            getstatic org.apache.cassandra.service.ActiveRepairService.instance:Lorg/apache/cassandra/service/ActiveRepairService;
            aload 0 /* this */
            getfield org.apache.cassandra.repair.RepairRunnable$2.val$parentSession:Ljava/util/UUID;
            aload 0 /* this */
            getfield org.apache.cassandra.repair.RepairRunnable$2.val$allNeighbors:Ljava/util/Set;
            aload 0 /* this */
            getfield org.apache.cassandra.repair.RepairRunnable$2.val$successfulRanges:Ljava/util/Collection;
            invokevirtual org.apache.cassandra.service.ActiveRepairService.finishParentSession:(Ljava/util/UUID;Ljava/util/Set;Ljava/util/Collection;)Lcom/google/common/util/concurrent/ListenableFuture;
            areturn
        end local 1 // java.util.List results
        end local 0 // org.apache.cassandra.repair.RepairRunnable$2 this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    8     0           this  Lorg/apache/cassandra/repair/RepairRunnable$2;
            0    8     1        results  Ljava/util/List<Lorg/apache/cassandra/repair/RepairSessionResult;>;
            2    6     2  sessionResult  Lorg/apache/cassandra/repair/RepairSessionResult;
    Signature: (Ljava/util/List<Lorg/apache/cassandra/repair/RepairSessionResult;>;)Lcom/google/common/util/concurrent/ListenableFuture;
    MethodParameters:
         Name  Flags
      results  

  public com.google.common.util.concurrent.ListenableFuture apply(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Lcom/google/common/util/concurrent/ListenableFuture;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            checkcast java.util.List
            invokevirtual org.apache.cassandra.repair.RepairRunnable$2.apply:(Ljava/util/List;)Lcom/google/common/util/concurrent/ListenableFuture;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Exception
}
Signature: Ljava/lang/Object;Lcom/google/common/util/concurrent/AsyncFunction<Ljava/util/List<Lorg/apache/cassandra/repair/RepairSessionResult;>;Ljava/lang/Object;>;
SourceFile: "RepairRunnable.java"
EnclosingMethod: org.apache.cassandra.repair.RepairRunnable.runMayThrow:()V
NestHost: org.apache.cassandra.repair.RepairRunnable
InnerClasses:
  org.apache.cassandra.repair.RepairRunnable$2