public abstract class org.apache.cassandra.db.filter.DataLimits$Counter extends org.apache.cassandra.db.transform.StoppingTransformation<org.apache.cassandra.db.rows.BaseRowIterator<?>>
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: org.apache.cassandra.db.filter.DataLimits$Counter
  super_class: org.apache.cassandra.db.transform.StoppingTransformation
{
  protected final int nowInSec;
    descriptor: I
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final boolean assumeLiveData;
    descriptor: Z
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

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

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

  protected void <init>(int, boolean, boolean);
    descriptor: (IZZ)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // int nowInSec
        start local 2 // boolean assumeLiveData
        start local 3 // boolean enforceStrictLiveness
         0: .line 262
            aload 0 /* this */
            invokespecial org.apache.cassandra.db.transform.StoppingTransformation.<init>:()V
         1: .line 260
            aload 0 /* this */
            iconst_1
            putfield org.apache.cassandra.db.filter.DataLimits$Counter.enforceLimits:Z
         2: .line 264
            aload 0 /* this */
            iload 1 /* nowInSec */
            putfield org.apache.cassandra.db.filter.DataLimits$Counter.nowInSec:I
         3: .line 265
            aload 0 /* this */
            iload 2 /* assumeLiveData */
            putfield org.apache.cassandra.db.filter.DataLimits$Counter.assumeLiveData:Z
         4: .line 266
            aload 0 /* this */
            iload 3 /* enforceStrictLiveness */
            putfield org.apache.cassandra.db.filter.DataLimits$Counter.enforceStrictLiveness:Z
         5: .line 267
            return
        end local 3 // boolean enforceStrictLiveness
        end local 2 // boolean assumeLiveData
        end local 1 // int nowInSec
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0    6     0                   this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    6     1               nowInSec  I
            0    6     2         assumeLiveData  Z
            0    6     3  enforceStrictLiveness  Z
    MethodParameters:
                       Name  Flags
      nowInSec               
      assumeLiveData         
      enforceStrictLiveness  

  public org.apache.cassandra.db.filter.DataLimits$Counter onlyCount();
    descriptor: ()Lorg/apache/cassandra/db/filter/DataLimits$Counter;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
         0: .line 271
            aload 0 /* this */
            iconst_0
            putfield org.apache.cassandra.db.filter.DataLimits$Counter.enforceLimits:Z
         1: .line 272
            aload 0 /* this */
            areturn
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;

  public org.apache.cassandra.db.partitions.PartitionIterator applyTo(org.apache.cassandra.db.partitions.PartitionIterator);
    descriptor: (Lorg/apache/cassandra/db/partitions/PartitionIterator;)Lorg/apache/cassandra/db/partitions/PartitionIterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // org.apache.cassandra.db.partitions.PartitionIterator partitions
         0: .line 277
            aload 1 /* partitions */
            aload 0 /* this */
            invokestatic org.apache.cassandra.db.transform.Transformation.apply:(Lorg/apache/cassandra/db/partitions/PartitionIterator;Lorg/apache/cassandra/db/transform/Transformation;)Lorg/apache/cassandra/db/partitions/PartitionIterator;
            areturn
        end local 1 // org.apache.cassandra.db.partitions.PartitionIterator partitions
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    1     1  partitions  Lorg/apache/cassandra/db/partitions/PartitionIterator;
    MethodParameters:
            Name  Flags
      partitions  

  public org.apache.cassandra.db.partitions.UnfilteredPartitionIterator applyTo(org.apache.cassandra.db.partitions.UnfilteredPartitionIterator);
    descriptor: (Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;)Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // org.apache.cassandra.db.partitions.UnfilteredPartitionIterator partitions
         0: .line 282
            aload 1 /* partitions */
            aload 0 /* this */
            invokestatic org.apache.cassandra.db.transform.Transformation.apply:(Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;Lorg/apache/cassandra/db/transform/Transformation;)Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
            areturn
        end local 1 // org.apache.cassandra.db.partitions.UnfilteredPartitionIterator partitions
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    1     1  partitions  Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
    MethodParameters:
            Name  Flags
      partitions  

  public org.apache.cassandra.db.rows.UnfilteredRowIterator applyTo(org.apache.cassandra.db.rows.UnfilteredRowIterator);
    descriptor: (Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;)Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // org.apache.cassandra.db.rows.UnfilteredRowIterator partition
         0: .line 287
            aload 0 /* this */
            aload 1 /* partition */
            invokevirtual org.apache.cassandra.db.filter.DataLimits$Counter.applyToPartition:(Lorg/apache/cassandra/db/rows/BaseRowIterator;)Lorg/apache/cassandra/db/rows/BaseRowIterator;
            checkcast org.apache.cassandra.db.rows.UnfilteredRowIterator
            areturn
        end local 1 // org.apache.cassandra.db.rows.UnfilteredRowIterator partition
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    1     1  partition  Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
    MethodParameters:
           Name  Flags
      partition  

  public org.apache.cassandra.db.rows.RowIterator applyTo(org.apache.cassandra.db.rows.RowIterator);
    descriptor: (Lorg/apache/cassandra/db/rows/RowIterator;)Lorg/apache/cassandra/db/rows/RowIterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // org.apache.cassandra.db.rows.RowIterator partition
         0: .line 292
            aload 0 /* this */
            aload 1 /* partition */
            invokevirtual org.apache.cassandra.db.filter.DataLimits$Counter.applyToPartition:(Lorg/apache/cassandra/db/rows/BaseRowIterator;)Lorg/apache/cassandra/db/rows/BaseRowIterator;
            checkcast org.apache.cassandra.db.rows.RowIterator
            areturn
        end local 1 // org.apache.cassandra.db.rows.RowIterator partition
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    1     1  partition  Lorg/apache/cassandra/db/rows/RowIterator;
    MethodParameters:
           Name  Flags
      partition  

  public abstract int counted();
    descriptor: ()I
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract int countedInCurrentPartition();
    descriptor: ()I
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract int rowCounted();
    descriptor: ()I
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract int rowCountedInCurrentPartition();
    descriptor: ()I
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract boolean isDone();
    descriptor: ()Z
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract boolean isDoneForPartition();
    descriptor: ()Z
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  protected boolean isLive(org.apache.cassandra.db.rows.Row);
    descriptor: (Lorg/apache/cassandra/db/rows/Row;)Z
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // org.apache.cassandra.db.rows.Row row
         0: .line 325
            aload 0 /* this */
            getfield org.apache.cassandra.db.filter.DataLimits$Counter.assumeLiveData:Z
            ifne 1
            aload 1 /* row */
            aload 0 /* this */
            getfield org.apache.cassandra.db.filter.DataLimits$Counter.nowInSec:I
            aload 0 /* this */
            getfield org.apache.cassandra.db.filter.DataLimits$Counter.enforceStrictLiveness:Z
            invokeinterface org.apache.cassandra.db.rows.Row.hasLiveData:(IZ)Z
            ifne 1
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_1
            ireturn
        end local 1 // org.apache.cassandra.db.rows.Row row
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    2     1   row  Lorg/apache/cassandra/db/rows/Row;
    MethodParameters:
      Name  Flags
      row   

  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: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // org.apache.cassandra.db.rows.BaseRowIterator partition
         0: .line 331
            aload 1 /* partition */
            instanceof org.apache.cassandra.db.rows.UnfilteredRowIterator
            ifeq 1
            aload 1 /* partition */
            checkcast org.apache.cassandra.db.rows.UnfilteredRowIterator
            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;
            goto 2
         1: .line 332
      StackMap locals:
      StackMap stack:
            aload 1 /* partition */
            checkcast org.apache.cassandra.db.rows.RowIterator
            aload 0 /* this */
            invokestatic org.apache.cassandra.db.transform.Transformation.apply:(Lorg/apache/cassandra/db/rows/RowIterator;Lorg/apache/cassandra/db/transform/Transformation;)Lorg/apache/cassandra/db/rows/RowIterator;
         2: .line 331
      StackMap locals:
      StackMap stack: org.apache.cassandra.db.rows.BaseRowIterator
            areturn
        end local 1 // org.apache.cassandra.db.rows.BaseRowIterator partition
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    3     1  partition  Lorg/apache/cassandra/db/rows/BaseRowIterator<*>;
    Signature: (Lorg/apache/cassandra/db/rows/BaseRowIterator<*>;)Lorg/apache/cassandra/db/rows/BaseRowIterator<*>;
    MethodParameters:
           Name  Flags
      partition  

  protected abstract void applyToPartition(org.apache.cassandra.db.DecoratedKey, org.apache.cassandra.db.rows.Row);
    descriptor: (Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/rows/Row;)V
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    MethodParameters:
              Name  Flags
      partitionKey  
      staticRow     

  protected void attachTo(org.apache.cassandra.db.transform.BasePartitions);
    descriptor: (Lorg/apache/cassandra/db/transform/BasePartitions;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // org.apache.cassandra.db.transform.BasePartitions partitions
         0: .line 341
            aload 0 /* this */
            getfield org.apache.cassandra.db.filter.DataLimits$Counter.enforceLimits:Z
            ifeq 2
         1: .line 342
            aload 0 /* this */
            aload 1 /* partitions */
            invokespecial org.apache.cassandra.db.transform.StoppingTransformation.attachTo:(Lorg/apache/cassandra/db/transform/BasePartitions;)V
         2: .line 343
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.filter.DataLimits$Counter.isDone:()Z
            ifeq 4
         3: .line 344
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.filter.DataLimits$Counter.stop:()V
         4: .line 345
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.cassandra.db.transform.BasePartitions partitions
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    5     1  partitions  Lorg/apache/cassandra/db/transform/BasePartitions;
    MethodParameters:
            Name  Flags
      partitions  

  protected void attachTo(org.apache.cassandra.db.transform.BaseRows);
    descriptor: (Lorg/apache/cassandra/db/transform/BaseRows;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
        start local 1 // org.apache.cassandra.db.transform.BaseRows rows
         0: .line 350
            aload 0 /* this */
            getfield org.apache.cassandra.db.filter.DataLimits$Counter.enforceLimits:Z
            ifeq 2
         1: .line 351
            aload 0 /* this */
            aload 1 /* rows */
            invokespecial org.apache.cassandra.db.transform.StoppingTransformation.attachTo:(Lorg/apache/cassandra/db/transform/BaseRows;)V
         2: .line 352
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* rows */
            invokevirtual org.apache.cassandra.db.transform.BaseRows.partitionKey:()Lorg/apache/cassandra/db/DecoratedKey;
            aload 1 /* rows */
            invokevirtual org.apache.cassandra.db.transform.BaseRows.staticRow:()Lorg/apache/cassandra/db/rows/Row;
            invokevirtual org.apache.cassandra.db.filter.DataLimits$Counter.applyToPartition:(Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/rows/Row;)V
         3: .line 353
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.filter.DataLimits$Counter.isDoneForPartition:()Z
            ifeq 5
         4: .line 354
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.filter.DataLimits$Counter.stopInPartition:()V
         5: .line 355
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.cassandra.db.transform.BaseRows rows
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
            0    6     1  rows  Lorg/apache/cassandra/db/transform/BaseRows;
    MethodParameters:
      Name  Flags
      rows  

  public void onClose();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
         0: .line 360
            aload 0 /* this */
            invokespecial org.apache.cassandra.db.transform.StoppingTransformation.onClose:()V
         1: .line 361
            return
        end local 0 // org.apache.cassandra.db.filter.DataLimits$Counter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/db/filter/DataLimits$Counter;
}
Signature: Lorg/apache/cassandra/db/transform/StoppingTransformation<Lorg/apache/cassandra/db/rows/BaseRowIterator<*>;>;
SourceFile: "DataLimits.java"
NestHost: org.apache.cassandra.db.filter.DataLimits
InnerClasses:
  public abstract Counter = org.apache.cassandra.db.filter.DataLimits$Counter of org.apache.cassandra.db.filter.DataLimits