public abstract class org.apache.cassandra.db.partitions.PurgeFunction extends org.apache.cassandra.db.transform.Transformation<org.apache.cassandra.db.rows.UnfilteredRowIterator>
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: org.apache.cassandra.db.partitions.PurgeFunction
  super_class: org.apache.cassandra.db.transform.Transformation
{
  private final boolean isForThrift;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

  private final boolean enforceStrictLiveness;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private boolean isReverseOrder;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  public void <init>(boolean, int, int, int, boolean, boolean);
    descriptor: (ZIIIZZ)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=7, args_size=7
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 1 // boolean isForThrift
        start local 2 // int nowInSec
        start local 3 // int gcBefore
        start local 4 // int oldestUnrepairedTombstone
        start local 5 // boolean onlyPurgeRepairedTombstones
        start local 6 // boolean enforceStrictLiveness
         0: .line 35
            aload 0 /* this */
            invokespecial org.apache.cassandra.db.transform.Transformation.<init>:()V
         1: .line 42
            aload 0 /* this */
            iload 1 /* isForThrift */
            putfield org.apache.cassandra.db.partitions.PurgeFunction.isForThrift:Z
         2: .line 43
            aload 0 /* this */
            iload 2 /* nowInSec */
            putfield org.apache.cassandra.db.partitions.PurgeFunction.nowInSec:I
         3: .line 44
            aload 0 /* this */
            aload 0 /* this */
            iload 5 /* onlyPurgeRepairedTombstones */
            iload 4 /* oldestUnrepairedTombstone */
            iload 3 /* gcBefore */
            invokedynamic shouldPurge(Lorg/apache/cassandra/db/partitions/PurgeFunction;ZII)Lorg/apache/cassandra/db/DeletionPurger;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (JI)Z
                  org/apache/cassandra/db/partitions/PurgeFunction.lambda$0(ZIIJI)Z (7)
                  (JI)Z
            putfield org.apache.cassandra.db.partitions.PurgeFunction.purger:Lorg/apache/cassandra/db/DeletionPurger;
         4: .line 48
            aload 0 /* this */
            iload 6 /* enforceStrictLiveness */
            putfield org.apache.cassandra.db.partitions.PurgeFunction.enforceStrictLiveness:Z
         5: .line 49
            return
        end local 6 // boolean enforceStrictLiveness
        end local 5 // boolean onlyPurgeRepairedTombstones
        end local 4 // int oldestUnrepairedTombstone
        end local 3 // int gcBefore
        end local 2 // int nowInSec
        end local 1 // boolean isForThrift
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot                         Name  Signature
            0    6     0                         this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0    6     1                  isForThrift  Z
            0    6     2                     nowInSec  I
            0    6     3                     gcBefore  I
            0    6     4    oldestUnrepairedTombstone  I
            0    6     5  onlyPurgeRepairedTombstones  Z
            0    6     6        enforceStrictLiveness  Z
    MethodParameters:
                             Name  Flags
      isForThrift                  
      nowInSec                     
      gcBefore                     
      oldestUnrepairedTombstone    
      onlyPurgeRepairedTombstones  
      enforceStrictLiveness        

  protected abstract java.util.function.Predicate<java.lang.Long> getPurgeEvaluator();
    descriptor: ()Ljava/util/function/Predicate;
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Signature: ()Ljava/util/function/Predicate<Ljava/lang/Long;>;

  protected void onNewPartition(org.apache.cassandra.db.DecoratedKey);
    descriptor: (Lorg/apache/cassandra/db/DecoratedKey;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=0, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 1 // org.apache.cassandra.db.DecoratedKey partitionKey
         0: .line 56
            return
        end local 1 // org.apache.cassandra.db.DecoratedKey partitionKey
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0          this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0    1     1  partitionKey  Lorg/apache/cassandra/db/DecoratedKey;
    MethodParameters:
              Name  Flags
      partitionKey  

  protected void onEmptyPartitionPostPurge(org.apache.cassandra.db.DecoratedKey);
    descriptor: (Lorg/apache/cassandra/db/DecoratedKey;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=0, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 1 // org.apache.cassandra.db.DecoratedKey partitionKey
         0: .line 61
            return
        end local 1 // org.apache.cassandra.db.DecoratedKey partitionKey
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0          this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0    1     1  partitionKey  Lorg/apache/cassandra/db/DecoratedKey;
    MethodParameters:
              Name  Flags
      partitionKey  

  protected void updateProgress();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=0, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
         0: .line 66
            return
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/partitions/PurgeFunction;

  protected org.apache.cassandra.db.rows.UnfilteredRowIterator applyToPartition(org.apache.cassandra.db.rows.UnfilteredRowIterator);
    descriptor: (Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;)Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 1 // org.apache.cassandra.db.rows.UnfilteredRowIterator partition
         0: .line 71
            aload 0 /* this */
            aload 1 /* partition */
            invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.partitionKey:()Lorg/apache/cassandra/db/DecoratedKey;
            invokevirtual org.apache.cassandra.db.partitions.PurgeFunction.onNewPartition:(Lorg/apache/cassandra/db/DecoratedKey;)V
         1: .line 73
            aload 0 /* this */
            aload 1 /* partition */
            invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.isReverseOrder:()Z
            putfield org.apache.cassandra.db.partitions.PurgeFunction.isReverseOrder:Z
         2: .line 74
            aload 1 /* partition */
            aload 0 /* this */
            invokestatic org.apache.cassandra.db.transform.Transformation.apply:(Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;Lorg/apache/cassandra/db/transform/Transformation;)Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
            astore 2 /* purged */
        start local 2 // org.apache.cassandra.db.rows.UnfilteredRowIterator purged
         3: .line 75
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.isForThrift:Z
            ifne 7
            aload 2 /* purged */
            invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.isEmpty:()Z
            ifeq 7
         4: .line 77
            aload 0 /* this */
            aload 2 /* purged */
            invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.partitionKey:()Lorg/apache/cassandra/db/DecoratedKey;
            invokevirtual org.apache.cassandra.db.partitions.PurgeFunction.onEmptyPartitionPostPurge:(Lorg/apache/cassandra/db/DecoratedKey;)V
         5: .line 78
            aload 2 /* purged */
            invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.close:()V
         6: .line 79
            aconst_null
            areturn
         7: .line 82
      StackMap locals: org.apache.cassandra.db.rows.UnfilteredRowIterator
      StackMap stack:
            aload 2 /* purged */
            areturn
        end local 2 // org.apache.cassandra.db.rows.UnfilteredRowIterator purged
        end local 1 // org.apache.cassandra.db.rows.UnfilteredRowIterator partition
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    8     0       this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0    8     1  partition  Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
            3    8     2     purged  Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
    MethodParameters:
           Name  Flags
      partition  

  protected org.apache.cassandra.db.DeletionTime applyToDeletion(org.apache.cassandra.db.DeletionTime);
    descriptor: (Lorg/apache/cassandra/db/DeletionTime;)Lorg/apache/cassandra/db/DeletionTime;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 1 // org.apache.cassandra.db.DeletionTime deletionTime
         0: .line 88
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.purger:Lorg/apache/cassandra/db/DeletionPurger;
            aload 1 /* deletionTime */
            invokeinterface org.apache.cassandra.db.DeletionPurger.shouldPurge:(Lorg/apache/cassandra/db/DeletionTime;)Z
            ifeq 1
            getstatic org.apache.cassandra.db.DeletionTime.LIVE:Lorg/apache/cassandra/db/DeletionTime;
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 1 /* deletionTime */
      StackMap locals:
      StackMap stack: org.apache.cassandra.db.DeletionTime
         2: areturn
        end local 1 // org.apache.cassandra.db.DeletionTime deletionTime
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    3     0          this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0    3     1  deletionTime  Lorg/apache/cassandra/db/DeletionTime;
    MethodParameters:
              Name  Flags
      deletionTime  

  protected org.apache.cassandra.db.rows.Row applyToStatic(org.apache.cassandra.db.rows.Row);
    descriptor: (Lorg/apache/cassandra/db/rows/Row;)Lorg/apache/cassandra/db/rows/Row;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 1 // org.apache.cassandra.db.rows.Row row
         0: .line 94
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.partitions.PurgeFunction.updateProgress:()V
         1: .line 95
            aload 1 /* row */
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.purger:Lorg/apache/cassandra/db/DeletionPurger;
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.nowInSec:I
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.enforceStrictLiveness:Z
            invokeinterface org.apache.cassandra.db.rows.Row.purge:(Lorg/apache/cassandra/db/DeletionPurger;IZ)Lorg/apache/cassandra/db/rows/Row;
            areturn
        end local 1 // org.apache.cassandra.db.rows.Row row
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0    2     1   row  Lorg/apache/cassandra/db/rows/Row;
    MethodParameters:
      Name  Flags
      row   

  protected org.apache.cassandra.db.rows.Row applyToRow(org.apache.cassandra.db.rows.Row);
    descriptor: (Lorg/apache/cassandra/db/rows/Row;)Lorg/apache/cassandra/db/rows/Row;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 1 // org.apache.cassandra.db.rows.Row row
         0: .line 101
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.partitions.PurgeFunction.updateProgress:()V
         1: .line 102
            aload 1 /* row */
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.purger:Lorg/apache/cassandra/db/DeletionPurger;
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.nowInSec:I
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.enforceStrictLiveness:Z
            invokeinterface org.apache.cassandra.db.rows.Row.purge:(Lorg/apache/cassandra/db/DeletionPurger;IZ)Lorg/apache/cassandra/db/rows/Row;
            areturn
        end local 1 // org.apache.cassandra.db.rows.Row row
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0    2     1   row  Lorg/apache/cassandra/db/rows/Row;
    MethodParameters:
      Name  Flags
      row   

  protected org.apache.cassandra.db.rows.RangeTombstoneMarker applyToMarker(org.apache.cassandra.db.rows.RangeTombstoneMarker);
    descriptor: (Lorg/apache/cassandra/db/rows/RangeTombstoneMarker;)Lorg/apache/cassandra/db/rows/RangeTombstoneMarker;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=6, args_size=2
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 1 // org.apache.cassandra.db.rows.RangeTombstoneMarker marker
         0: .line 108
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.partitions.PurgeFunction.updateProgress:()V
         1: .line 109
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.isReverseOrder:Z
            istore 2 /* reversed */
        start local 2 // boolean reversed
         2: .line 110
            aload 1 /* marker */
            invokeinterface org.apache.cassandra.db.rows.RangeTombstoneMarker.isBoundary:()Z
            ifeq 14
         3: .line 114
            aload 1 /* marker */
            checkcast org.apache.cassandra.db.rows.RangeTombstoneBoundaryMarker
            astore 3 /* boundary */
        start local 3 // org.apache.cassandra.db.rows.RangeTombstoneBoundaryMarker boundary
         4: .line 115
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.purger:Lorg/apache/cassandra/db/DeletionPurger;
            aload 3 /* boundary */
            iload 2 /* reversed */
            invokevirtual org.apache.cassandra.db.rows.RangeTombstoneBoundaryMarker.closeDeletionTime:(Z)Lorg/apache/cassandra/db/DeletionTime;
            invokeinterface org.apache.cassandra.db.DeletionPurger.shouldPurge:(Lorg/apache/cassandra/db/DeletionTime;)Z
            istore 4 /* shouldPurgeClose */
        start local 4 // boolean shouldPurgeClose
         5: .line 116
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.purger:Lorg/apache/cassandra/db/DeletionPurger;
            aload 3 /* boundary */
            iload 2 /* reversed */
            invokevirtual org.apache.cassandra.db.rows.RangeTombstoneBoundaryMarker.openDeletionTime:(Z)Lorg/apache/cassandra/db/DeletionTime;
            invokeinterface org.apache.cassandra.db.DeletionPurger.shouldPurge:(Lorg/apache/cassandra/db/DeletionTime;)Z
            istore 5 /* shouldPurgeOpen */
        start local 5 // boolean shouldPurgeOpen
         6: .line 118
            iload 4 /* shouldPurgeClose */
            ifeq 10
         7: .line 120
            iload 5 /* shouldPurgeOpen */
            ifeq 9
         8: .line 121
            aconst_null
            areturn
         9: .line 123
      StackMap locals: org.apache.cassandra.db.partitions.PurgeFunction org.apache.cassandra.db.rows.RangeTombstoneMarker int org.apache.cassandra.db.rows.RangeTombstoneBoundaryMarker int int
      StackMap stack:
            aload 3 /* boundary */
            iload 2 /* reversed */
            invokevirtual org.apache.cassandra.db.rows.RangeTombstoneBoundaryMarker.createCorrespondingOpenMarker:(Z)Lorg/apache/cassandra/db/rows/RangeTombstoneBoundMarker;
            areturn
        10: .line 126
      StackMap locals:
      StackMap stack:
            iload 5 /* shouldPurgeOpen */
            ifeq 12
        11: .line 127
            aload 3 /* boundary */
            iload 2 /* reversed */
            invokevirtual org.apache.cassandra.db.rows.RangeTombstoneBoundaryMarker.createCorrespondingCloseMarker:(Z)Lorg/apache/cassandra/db/rows/RangeTombstoneBoundMarker;
            goto 13
        12: .line 128
      StackMap locals:
      StackMap stack:
            aload 1 /* marker */
        13: .line 126
      StackMap locals:
      StackMap stack: org.apache.cassandra.db.rows.RangeTombstoneMarker
            areturn
        end local 5 // boolean shouldPurgeOpen
        end local 4 // boolean shouldPurgeClose
        end local 3 // org.apache.cassandra.db.rows.RangeTombstoneBoundaryMarker boundary
        14: .line 132
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.partitions.PurgeFunction.purger:Lorg/apache/cassandra/db/DeletionPurger;
            aload 1 /* marker */
            checkcast org.apache.cassandra.db.rows.RangeTombstoneBoundMarker
            invokevirtual org.apache.cassandra.db.rows.RangeTombstoneBoundMarker.deletionTime:()Lorg/apache/cassandra/db/DeletionTime;
            invokeinterface org.apache.cassandra.db.DeletionPurger.shouldPurge:(Lorg/apache/cassandra/db/DeletionTime;)Z
            ifeq 15
            aconst_null
            goto 16
      StackMap locals:
      StackMap stack:
        15: aload 1 /* marker */
      StackMap locals:
      StackMap stack: org.apache.cassandra.db.rows.RangeTombstoneMarker
        16: areturn
        end local 2 // boolean reversed
        end local 1 // org.apache.cassandra.db.rows.RangeTombstoneMarker marker
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   17     0              this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0   17     1            marker  Lorg/apache/cassandra/db/rows/RangeTombstoneMarker;
            2   17     2          reversed  Z
            4   14     3          boundary  Lorg/apache/cassandra/db/rows/RangeTombstoneBoundaryMarker;
            5   14     4  shouldPurgeClose  Z
            6   14     5   shouldPurgeOpen  Z
    MethodParameters:
        Name  Flags
      marker  

  protected org.apache.cassandra.db.rows.BaseRowIterator applyToPartition(org.apache.cassandra.db.rows.BaseRowIterator);
    descriptor: (Lorg/apache/cassandra/db/rows/BaseRowIterator;)Lorg/apache/cassandra/db/rows/BaseRowIterator;
    flags: (0x1044) ACC_PROTECTED, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            checkcast org.apache.cassandra.db.rows.UnfilteredRowIterator
            invokevirtual org.apache.cassandra.db.partitions.PurgeFunction.applyToPartition:(Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;)Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private boolean lambda$0(boolean, int, int, long, int);
    descriptor: (ZIIJI)Z
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=3, locals=7, args_size=6
        start local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
        start local 4 // long timestamp
        start local 6 // int localDeletionTime
         0: .line 45
            iload 1
            ifeq 1
            iload 6 /* localDeletionTime */
            iload 2
            if_icmpge 3
         1: .line 46
      StackMap locals:
      StackMap stack:
            iload 6 /* localDeletionTime */
            iload 3
            if_icmpge 3
         2: .line 47
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.partitions.PurgeFunction.getPurgeEvaluator:()Ljava/util/function/Predicate;
            lload 4 /* timestamp */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.function.Predicate.test:(Ljava/lang/Object;)Z
            ifeq 3
            iconst_1
            goto 4
      StackMap locals:
      StackMap stack:
         3: iconst_0
      StackMap locals:
      StackMap stack: int
         4: ireturn
        end local 6 // int localDeletionTime
        end local 4 // long timestamp
        end local 0 // org.apache.cassandra.db.partitions.PurgeFunction this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    5     0               this  Lorg/apache/cassandra/db/partitions/PurgeFunction;
            0    5     4          timestamp  J
            0    5     6  localDeletionTime  I
}
Signature: Lorg/apache/cassandra/db/transform/Transformation<Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;>;
SourceFile: "PurgeFunction.java"
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles