final class org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction implements org.apache.cassandra.index.transactions.CleanupTransaction
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction
  super_class: java.lang.Object
{
  private final org.apache.cassandra.db.DecoratedKey key;
    descriptor: Lorg/apache/cassandra/db/DecoratedKey;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.cassandra.db.PartitionColumns columns;
    descriptor: Lorg/apache/cassandra/db/PartitionColumns;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  private final java.util.Collection<org.apache.cassandra.index.Index> indexes;
    descriptor: Ljava/util/Collection;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Collection<Lorg/apache/cassandra/index/Index;>;

  private org.apache.cassandra.db.rows.Row row;
    descriptor: Lorg/apache/cassandra/db/rows/Row;
    flags: (0x0002) ACC_PRIVATE

  private org.apache.cassandra.db.DeletionTime partitionDelete;
    descriptor: Lorg/apache/cassandra/db/DeletionTime;
    flags: (0x0002) ACC_PRIVATE

  private void <init>(org.apache.cassandra.db.DecoratedKey, org.apache.cassandra.db.PartitionColumns, int, java.util.Collection<org.apache.cassandra.index.Index>);
    descriptor: (Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/PartitionColumns;ILjava/util/Collection;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=5, args_size=5
        start local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
        start local 1 // org.apache.cassandra.db.DecoratedKey key
        start local 2 // org.apache.cassandra.db.PartitionColumns columns
        start local 3 // int nowInSec
        start local 4 // java.util.Collection indexes
         0: .line 1106
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 1111
            aload 0 /* this */
            aload 1 /* key */
            putfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.key:Lorg/apache/cassandra/db/DecoratedKey;
         2: .line 1112
            aload 0 /* this */
            aload 2 /* columns */
            putfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.columns:Lorg/apache/cassandra/db/PartitionColumns;
         3: .line 1113
            aload 0 /* this */
            aload 4 /* indexes */
            putfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.indexes:Ljava/util/Collection;
         4: .line 1114
            aload 0 /* this */
            iload 3 /* nowInSec */
            putfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.nowInSec:I
         5: .line 1115
            return
        end local 4 // java.util.Collection indexes
        end local 3 // int nowInSec
        end local 2 // org.apache.cassandra.db.PartitionColumns columns
        end local 1 // org.apache.cassandra.db.DecoratedKey key
        end local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/apache/cassandra/index/SecondaryIndexManager$CleanupGCTransaction;
            0    6     1       key  Lorg/apache/cassandra/db/DecoratedKey;
            0    6     2   columns  Lorg/apache/cassandra/db/PartitionColumns;
            0    6     3  nowInSec  I
            0    6     4   indexes  Ljava/util/Collection<Lorg/apache/cassandra/index/Index;>;
    Signature: (Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/PartitionColumns;ILjava/util/Collection<Lorg/apache/cassandra/index/Index;>;)V
    MethodParameters:
          Name  Flags
      key       
      columns   
      nowInSec  
      indexes   

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=1, args_size=1
        start local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
         0: .line 1119
            return
        end local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/index/SecondaryIndexManager$CleanupGCTransaction;

  public void onPartitionDeletion(org.apache.cassandra.db.DeletionTime);
    descriptor: (Lorg/apache/cassandra/db/DeletionTime;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
        start local 1 // org.apache.cassandra.db.DeletionTime deletionTime
         0: .line 1123
            aload 0 /* this */
            aload 1 /* deletionTime */
            putfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.partitionDelete:Lorg/apache/cassandra/db/DeletionTime;
         1: .line 1124
            return
        end local 1 // org.apache.cassandra.db.DeletionTime deletionTime
        end local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    2     0          this  Lorg/apache/cassandra/index/SecondaryIndexManager$CleanupGCTransaction;
            0    2     1  deletionTime  Lorg/apache/cassandra/db/DeletionTime;
    MethodParameters:
              Name  Flags
      deletionTime  

  public void onRowDelete(org.apache.cassandra.db.rows.Row);
    descriptor: (Lorg/apache/cassandra/db/rows/Row;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
        start local 1 // org.apache.cassandra.db.rows.Row row
         0: .line 1128
            aload 0 /* this */
            aload 1 /* row */
            putfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.row:Lorg/apache/cassandra/db/rows/Row;
         1: .line 1129
            return
        end local 1 // org.apache.cassandra.db.rows.Row row
        end local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/index/SecondaryIndexManager$CleanupGCTransaction;
            0    2     1   row  Lorg/apache/cassandra/db/rows/Row;
    MethodParameters:
      Name  Flags
      row   

  public void commit();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=7, args_size=1
        start local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
         0: .line 1133
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.row:Lorg/apache/cassandra/db/rows/Row;
            ifnonnull 2
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.partitionDelete:Lorg/apache/cassandra/db/DeletionTime;
            ifnonnull 2
         1: .line 1134
            return
         2: .line 1136
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 1
            aconst_null
            astore 2
         3: getstatic org.apache.cassandra.db.Keyspace.writeOrder:Lorg/apache/cassandra/utils/concurrent/OpOrder;
            invokevirtual org.apache.cassandra.utils.concurrent.OpOrder.start:()Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;
            astore 3 /* opGroup */
        start local 3 // org.apache.cassandra.utils.concurrent.OpOrder$Group opGroup
         4: .line 1138
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.indexes:Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 15
      StackMap locals: org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction java.lang.Throwable java.lang.Throwable org.apache.cassandra.utils.concurrent.OpOrder$Group top java.util.Iterator
      StackMap stack:
         5: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.index.Index
            astore 4 /* index */
        start local 4 // org.apache.cassandra.index.Index index
         6: .line 1140
            aload 4 /* index */
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.key:Lorg/apache/cassandra/db/DecoratedKey;
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.columns:Lorg/apache/cassandra/db/PartitionColumns;
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.nowInSec:I
            aload 3 /* opGroup */
            getstatic org.apache.cassandra.index.transactions.IndexTransaction$Type.CLEANUP:Lorg/apache/cassandra/index/transactions/IndexTransaction$Type;
            invokeinterface org.apache.cassandra.index.Index.indexerFor:(Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/PartitionColumns;ILorg/apache/cassandra/utils/concurrent/OpOrder$Group;Lorg/apache/cassandra/index/transactions/IndexTransaction$Type;)Lorg/apache/cassandra/index/Index$Indexer;
            astore 6 /* indexer */
        start local 6 // org.apache.cassandra.index.Index$Indexer indexer
         7: .line 1141
            aload 6 /* indexer */
            ifnonnull 9
         8: .line 1142
            goto 15
         9: .line 1144
      StackMap locals: org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction java.lang.Throwable java.lang.Throwable org.apache.cassandra.utils.concurrent.OpOrder$Group org.apache.cassandra.index.Index java.util.Iterator org.apache.cassandra.index.Index$Indexer
      StackMap stack:
            aload 6 /* indexer */
            invokeinterface org.apache.cassandra.index.Index$Indexer.begin:()V
        10: .line 1146
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.partitionDelete:Lorg/apache/cassandra/db/DeletionTime;
            ifnull 12
        11: .line 1147
            aload 6 /* indexer */
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.partitionDelete:Lorg/apache/cassandra/db/DeletionTime;
            invokeinterface org.apache.cassandra.index.Index$Indexer.partitionDelete:(Lorg/apache/cassandra/db/DeletionTime;)V
        12: .line 1149
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.row:Lorg/apache/cassandra/db/rows/Row;
            ifnull 14
        13: .line 1150
            aload 6 /* indexer */
            aload 0 /* this */
            getfield org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction.row:Lorg/apache/cassandra/db/rows/Row;
            invokeinterface org.apache.cassandra.index.Index$Indexer.removeRow:(Lorg/apache/cassandra/db/rows/Row;)V
        14: .line 1152
      StackMap locals:
      StackMap stack:
            aload 6 /* indexer */
            invokeinterface org.apache.cassandra.index.Index$Indexer.finish:()V
        end local 6 // org.apache.cassandra.index.Index$Indexer indexer
        end local 4 // org.apache.cassandra.index.Index index
        15: .line 1138
      StackMap locals: org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction java.lang.Throwable java.lang.Throwable org.apache.cassandra.utils.concurrent.OpOrder$Group top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        16: .line 1154
            aload 3 /* opGroup */
            ifnull 22
            aload 3 /* opGroup */
            invokevirtual org.apache.cassandra.utils.concurrent.OpOrder$Group.close:()V
            goto 22
      StackMap locals: org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction java.lang.Throwable java.lang.Throwable org.apache.cassandra.utils.concurrent.OpOrder$Group
      StackMap stack: java.lang.Throwable
        17: astore 1
            aload 3 /* opGroup */
            ifnull 18
            aload 3 /* opGroup */
            invokevirtual org.apache.cassandra.utils.concurrent.OpOrder$Group.close:()V
        end local 3 // org.apache.cassandra.utils.concurrent.OpOrder$Group opGroup
      StackMap locals:
      StackMap stack:
        18: aload 1
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        19: astore 2
            aload 1
            ifnonnull 20
            aload 2
            astore 1
            goto 21
      StackMap locals:
      StackMap stack:
        20: aload 1
            aload 2
            if_acmpeq 21
            aload 1
            aload 2
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        21: aload 1
            athrow
        22: .line 1155
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   23     0     this  Lorg/apache/cassandra/index/SecondaryIndexManager$CleanupGCTransaction;
            4   18     3  opGroup  Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;
            6   15     4    index  Lorg/apache/cassandra/index/Index;
            7   15     6  indexer  Lorg/apache/cassandra/index/Index$Indexer;
      Exception table:
        from    to  target  type
           4    16      17  any
           3    19      19  any
}
SourceFile: "SecondaryIndexManager.java"
NestHost: org.apache.cassandra.index.SecondaryIndexManager
InnerClasses:
  public abstract Indexer = org.apache.cassandra.index.Index$Indexer of org.apache.cassandra.index.Index
  private final CleanupGCTransaction = org.apache.cassandra.index.SecondaryIndexManager$CleanupGCTransaction of org.apache.cassandra.index.SecondaryIndexManager
  public final Type = org.apache.cassandra.index.transactions.IndexTransaction$Type of org.apache.cassandra.index.transactions.IndexTransaction
  public final Group = org.apache.cassandra.utils.concurrent.OpOrder$Group of org.apache.cassandra.utils.concurrent.OpOrder