public class org.apache.cassandra.db.compaction.CompactionIterator extends org.apache.cassandra.db.compaction.CompactionInfo$Holder implements org.apache.cassandra.db.partitions.UnfilteredPartitionIterator
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.db.compaction.CompactionIterator
  super_class: org.apache.cassandra.db.compaction.CompactionInfo$Holder
{
  private static final long UNFILTERED_TO_UPDATE_PROGRESS;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 100

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

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

  private final java.util.List<org.apache.cassandra.io.sstable.ISSTableScanner> scanners;
    descriptor: Ljava/util/List;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/List<Lorg/apache/cassandra/io/sstable/ISSTableScanner;>;

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

  private final java.util.UUID compactionId;
    descriptor: Ljava/util/UUID;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final long totalBytes;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private long bytesRead;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private long totalSourceCQLRows;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private final long[] mergeCounters;
    descriptor: [J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  private final org.apache.cassandra.metrics.CompactionMetrics metrics;
    descriptor: Lorg/apache/cassandra/metrics/CompactionMetrics;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 54
            ldc Lorg/apache/cassandra/db/compaction/CompactionIterator;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.apache.cassandra.db.compaction.CompactionIterator.$assertionsDisabled:Z
         3: .line 56
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(org.apache.cassandra.db.compaction.OperationType, java.util.List<org.apache.cassandra.io.sstable.ISSTableScanner>, org.apache.cassandra.db.compaction.CompactionController, int, java.util.UUID);
    descriptor: (Lorg/apache/cassandra/db/compaction/OperationType;Ljava/util/List;Lorg/apache/cassandra/db/compaction/CompactionController;ILjava/util/UUID;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=6
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
        start local 1 // org.apache.cassandra.db.compaction.OperationType type
        start local 2 // java.util.List scanners
        start local 3 // org.apache.cassandra.db.compaction.CompactionController controller
        start local 4 // int nowInSec
        start local 5 // java.util.UUID compactionId
         0: .line 80
            aload 0 /* this */
            aload 1 /* type */
            aload 2 /* scanners */
            aload 3 /* controller */
            iload 4 /* nowInSec */
            aload 5 /* compactionId */
            aconst_null
            invokespecial org.apache.cassandra.db.compaction.CompactionIterator.<init>:(Lorg/apache/cassandra/db/compaction/OperationType;Ljava/util/List;Lorg/apache/cassandra/db/compaction/CompactionController;ILjava/util/UUID;Lorg/apache/cassandra/metrics/CompactionMetrics;)V
         1: .line 81
            return
        end local 5 // java.util.UUID compactionId
        end local 4 // int nowInSec
        end local 3 // org.apache.cassandra.db.compaction.CompactionController controller
        end local 2 // java.util.List scanners
        end local 1 // org.apache.cassandra.db.compaction.OperationType type
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    2     0          this  Lorg/apache/cassandra/db/compaction/CompactionIterator;
            0    2     1          type  Lorg/apache/cassandra/db/compaction/OperationType;
            0    2     2      scanners  Ljava/util/List<Lorg/apache/cassandra/io/sstable/ISSTableScanner;>;
            0    2     3    controller  Lorg/apache/cassandra/db/compaction/CompactionController;
            0    2     4      nowInSec  I
            0    2     5  compactionId  Ljava/util/UUID;
    Signature: (Lorg/apache/cassandra/db/compaction/OperationType;Ljava/util/List<Lorg/apache/cassandra/io/sstable/ISSTableScanner;>;Lorg/apache/cassandra/db/compaction/CompactionController;ILjava/util/UUID;)V
    MethodParameters:
              Name  Flags
      type          
      scanners      
      controller    
      nowInSec      
      compactionId  

  public void <init>(org.apache.cassandra.db.compaction.OperationType, java.util.List<org.apache.cassandra.io.sstable.ISSTableScanner>, org.apache.cassandra.db.compaction.CompactionController, int, java.util.UUID, org.apache.cassandra.metrics.CompactionMetrics);
    descriptor: (Lorg/apache/cassandra/db/compaction/OperationType;Ljava/util/List;Lorg/apache/cassandra/db/compaction/CompactionController;ILjava/util/UUID;Lorg/apache/cassandra/metrics/CompactionMetrics;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=11, args_size=7
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
        start local 1 // org.apache.cassandra.db.compaction.OperationType type
        start local 2 // java.util.List scanners
        start local 3 // org.apache.cassandra.db.compaction.CompactionController controller
        start local 4 // int nowInSec
        start local 5 // java.util.UUID compactionId
        start local 6 // org.apache.cassandra.metrics.CompactionMetrics metrics
         0: .line 84
            aload 0 /* this */
            invokespecial org.apache.cassandra.db.compaction.CompactionInfo$Holder.<init>:()V
         1: .line 86
            aload 0 /* this */
            aload 3 /* controller */
            putfield org.apache.cassandra.db.compaction.CompactionIterator.controller:Lorg/apache/cassandra/db/compaction/CompactionController;
         2: .line 87
            aload 0 /* this */
            aload 1 /* type */
            putfield org.apache.cassandra.db.compaction.CompactionIterator.type:Lorg/apache/cassandra/db/compaction/OperationType;
         3: .line 88
            aload 0 /* this */
            aload 2 /* scanners */
            putfield org.apache.cassandra.db.compaction.CompactionIterator.scanners:Ljava/util/List;
         4: .line 89
            aload 0 /* this */
            iload 4 /* nowInSec */
            putfield org.apache.cassandra.db.compaction.CompactionIterator.nowInSec:I
         5: .line 90
            aload 0 /* this */
            aload 5 /* compactionId */
            putfield org.apache.cassandra.db.compaction.CompactionIterator.compactionId:Ljava/util/UUID;
         6: .line 91
            aload 0 /* this */
            lconst_0
            putfield org.apache.cassandra.db.compaction.CompactionIterator.bytesRead:J
         7: .line 93
            lconst_0
            lstore 7 /* bytes */
        start local 7 // long bytes
         8: .line 94
            aload 2 /* scanners */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 10
            goto 11
      StackMap locals: org.apache.cassandra.db.compaction.CompactionIterator org.apache.cassandra.db.compaction.OperationType java.util.List org.apache.cassandra.db.compaction.CompactionController int java.util.UUID org.apache.cassandra.metrics.CompactionMetrics long top java.util.Iterator
      StackMap stack:
         9: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.io.sstable.ISSTableScanner
            astore 9 /* scanner */
        start local 9 // org.apache.cassandra.io.sstable.ISSTableScanner scanner
        10: .line 95
            lload 7 /* bytes */
            aload 9 /* scanner */
            invokeinterface org.apache.cassandra.io.sstable.ISSTableScanner.getLengthInBytes:()J
            ladd
            lstore 7 /* bytes */
        end local 9 // org.apache.cassandra.io.sstable.ISSTableScanner scanner
        11: .line 94
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        12: .line 96
            aload 0 /* this */
            lload 7 /* bytes */
            putfield org.apache.cassandra.db.compaction.CompactionIterator.totalBytes:J
        13: .line 97
            aload 0 /* this */
            aload 2 /* scanners */
            invokeinterface java.util.List.size:()I
            newarray 11
            putfield org.apache.cassandra.db.compaction.CompactionIterator.mergeCounters:[J
        14: .line 98
            aload 0 /* this */
            aload 6 /* metrics */
            putfield org.apache.cassandra.db.compaction.CompactionIterator.metrics:Lorg/apache/cassandra/metrics/CompactionMetrics;
        15: .line 100
            aload 6 /* metrics */
            ifnull 17
        16: .line 101
            aload 6 /* metrics */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.metrics.CompactionMetrics.beginCompaction:(Lorg/apache/cassandra/db/compaction/CompactionInfo$Holder;)V
        17: .line 103
      StackMap locals: org.apache.cassandra.db.compaction.CompactionIterator org.apache.cassandra.db.compaction.OperationType java.util.List org.apache.cassandra.db.compaction.CompactionController int java.util.UUID org.apache.cassandra.metrics.CompactionMetrics long
      StackMap stack:
            aload 2 /* scanners */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 19
        18: .line 104
            aload 3 /* controller */
            getfield org.apache.cassandra.db.compaction.CompactionController.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
            iconst_0
            invokestatic org.apache.cassandra.db.EmptyIterators.unfilteredPartition:(Lorg/apache/cassandra/config/CFMetaData;Z)Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
            goto 20
        19: .line 105
      StackMap locals:
      StackMap stack:
            aload 2 /* scanners */
            iload 4 /* nowInSec */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.compaction.CompactionIterator.listener:()Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterators$MergeListener;
            invokestatic org.apache.cassandra.db.partitions.UnfilteredPartitionIterators.merge:(Ljava/util/List;ILorg/apache/cassandra/db/partitions/UnfilteredPartitionIterators$MergeListener;)Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
        20: .line 103
      StackMap locals:
      StackMap stack: org.apache.cassandra.db.partitions.UnfilteredPartitionIterator
            astore 9 /* merged */
        start local 9 // org.apache.cassandra.db.partitions.UnfilteredPartitionIterator merged
        21: .line 106
            aload 9 /* merged */
            invokeinterface org.apache.cassandra.db.partitions.UnfilteredPartitionIterator.isForThrift:()Z
            istore 10 /* isForThrift */
        start local 10 // boolean isForThrift
        22: .line 107
            aload 9 /* merged */
            new org.apache.cassandra.db.compaction.CompactionIterator$GarbageSkipper
            dup
            aload 3 /* controller */
            iload 4 /* nowInSec */
            invokespecial org.apache.cassandra.db.compaction.CompactionIterator$GarbageSkipper.<init>:(Lorg/apache/cassandra/db/compaction/CompactionController;I)V
            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;
            astore 9 /* merged */
        23: .line 108
            aload 0 /* this */
            aload 9 /* merged */
            new org.apache.cassandra.db.compaction.CompactionIterator$Purger
            dup
            aload 0 /* this */
            iload 10 /* isForThrift */
            aload 3 /* controller */
            iload 4 /* nowInSec */
            invokespecial org.apache.cassandra.db.compaction.CompactionIterator$Purger.<init>:(Lorg/apache/cassandra/db/compaction/CompactionIterator;ZLorg/apache/cassandra/db/compaction/CompactionController;I)V
            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;
            putfield org.apache.cassandra.db.compaction.CompactionIterator.compacted:Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
        24: .line 109
            return
        end local 10 // boolean isForThrift
        end local 9 // org.apache.cassandra.db.partitions.UnfilteredPartitionIterator merged
        end local 7 // long bytes
        end local 6 // org.apache.cassandra.metrics.CompactionMetrics metrics
        end local 5 // java.util.UUID compactionId
        end local 4 // int nowInSec
        end local 3 // org.apache.cassandra.db.compaction.CompactionController controller
        end local 2 // java.util.List scanners
        end local 1 // org.apache.cassandra.db.compaction.OperationType type
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   25     0          this  Lorg/apache/cassandra/db/compaction/CompactionIterator;
            0   25     1          type  Lorg/apache/cassandra/db/compaction/OperationType;
            0   25     2      scanners  Ljava/util/List<Lorg/apache/cassandra/io/sstable/ISSTableScanner;>;
            0   25     3    controller  Lorg/apache/cassandra/db/compaction/CompactionController;
            0   25     4      nowInSec  I
            0   25     5  compactionId  Ljava/util/UUID;
            0   25     6       metrics  Lorg/apache/cassandra/metrics/CompactionMetrics;
            8   25     7         bytes  J
           10   11     9       scanner  Lorg/apache/cassandra/io/sstable/ISSTableScanner;
           21   25     9        merged  Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
           22   25    10   isForThrift  Z
    Signature: (Lorg/apache/cassandra/db/compaction/OperationType;Ljava/util/List<Lorg/apache/cassandra/io/sstable/ISSTableScanner;>;Lorg/apache/cassandra/db/compaction/CompactionController;ILjava/util/UUID;Lorg/apache/cassandra/metrics/CompactionMetrics;)V
    MethodParameters:
              Name  Flags
      type          
      scanners      
      controller    
      nowInSec      
      compactionId  
      metrics       

  public boolean isForThrift();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 113
            iconst_0
            ireturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  public org.apache.cassandra.config.CFMetaData metadata();
    descriptor: ()Lorg/apache/cassandra/config/CFMetaData;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 118
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.controller:Lorg/apache/cassandra/db/compaction/CompactionController;
            getfield org.apache.cassandra.db.compaction.CompactionController.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
            areturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  public org.apache.cassandra.db.compaction.CompactionInfo getCompactionInfo();
    descriptor: ()Lorg/apache/cassandra/db/compaction/CompactionInfo;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 123
            new org.apache.cassandra.db.compaction.CompactionInfo
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.controller:Lorg/apache/cassandra/db/compaction/CompactionController;
            getfield org.apache.cassandra.db.compaction.CompactionController.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
         1: .line 124
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.type:Lorg/apache/cassandra/db/compaction/OperationType;
         2: .line 125
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.bytesRead:J
         3: .line 126
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.totalBytes:J
         4: .line 127
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.compactionId:Ljava/util/UUID;
         5: .line 123
            invokespecial org.apache.cassandra.db.compaction.CompactionInfo.<init>:(Lorg/apache/cassandra/config/CFMetaData;Lorg/apache/cassandra/db/compaction/OperationType;JJLjava/util/UUID;)V
            areturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  private void updateCounterFor(int);
    descriptor: (I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
        start local 1 // int rows
         0: .line 132
            getstatic org.apache.cassandra.db.compaction.CompactionIterator.$assertionsDisabled:Z
            ifne 2
            iload 1 /* rows */
            ifle 1
            iload 1 /* rows */
            iconst_1
            isub
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.mergeCounters:[J
            arraylength
            if_icmplt 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.mergeCounters:[J
            iload 1 /* rows */
            iconst_1
            isub
            dup2
            laload
            lconst_1
            ladd
            lastore
         3: .line 134
            return
        end local 1 // int rows
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;
            0    4     1  rows  I
    MethodParameters:
      Name  Flags
      rows  

  public long[] getMergedRowCounts();
    descriptor: ()[J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 138
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.mergeCounters:[J
            areturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  public long getTotalSourceCQLRows();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 143
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.totalSourceCQLRows:J
            lreturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  private org.apache.cassandra.db.partitions.UnfilteredPartitionIterators$MergeListener listener();
    descriptor: ()Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterators$MergeListener;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 148
            new org.apache.cassandra.db.compaction.CompactionIterator$1
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.db.compaction.CompactionIterator$1.<init>:(Lorg/apache/cassandra/db/compaction/CompactionIterator;)V
            areturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  private void updateBytesRead();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 225
            lconst_0
            lstore 1 /* n */
        start local 1 // long n
         1: .line 226
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.scanners:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: org.apache.cassandra.db.compaction.CompactionIterator long top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.io.sstable.ISSTableScanner
            astore 3 /* scanner */
        start local 3 // org.apache.cassandra.io.sstable.ISSTableScanner scanner
         3: .line 227
            lload 1 /* n */
            aload 3 /* scanner */
            invokeinterface org.apache.cassandra.io.sstable.ISSTableScanner.getCurrentPosition:()J
            ladd
            lstore 1 /* n */
        end local 3 // org.apache.cassandra.io.sstable.ISSTableScanner scanner
         4: .line 226
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 228
            aload 0 /* this */
            lload 1 /* n */
            putfield org.apache.cassandra.db.compaction.CompactionIterator.bytesRead:J
         6: .line 229
            return
        end local 1 // long n
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lorg/apache/cassandra/db/compaction/CompactionIterator;
            1    7     1        n  J
            3    4     3  scanner  Lorg/apache/cassandra/io/sstable/ISSTableScanner;

  public boolean hasNext();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 233
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.compacted:Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
            invokeinterface org.apache.cassandra.db.partitions.UnfilteredPartitionIterator.hasNext:()Z
            ireturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  public org.apache.cassandra.db.rows.UnfilteredRowIterator next();
    descriptor: ()Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 238
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.compacted:Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
            invokeinterface org.apache.cassandra.db.partitions.UnfilteredPartitionIterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.rows.UnfilteredRowIterator
            areturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  public void remove();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 243
            new java.lang.UnsupportedOperationException
            dup
            invokespecial java.lang.UnsupportedOperationException.<init>:()V
            athrow
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 250
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.compacted:Lorg/apache/cassandra/db/partitions/UnfilteredPartitionIterator;
            invokeinterface org.apache.cassandra.db.partitions.UnfilteredPartitionIterator.close:()V
         1: .line 251
            goto 6
         2: .line 253
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1
         3: .line 254
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.metrics:Lorg/apache/cassandra/metrics/CompactionMetrics;
            ifnull 5
         4: .line 255
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.metrics:Lorg/apache/cassandra/metrics/CompactionMetrics;
            aload 0 /* this */
            invokevirtual org.apache.cassandra.metrics.CompactionMetrics.finishCompaction:(Lorg/apache/cassandra/db/compaction/CompactionInfo$Holder;)V
         5: .line 256
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 1
            athrow
         6: .line 254
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.metrics:Lorg/apache/cassandra/metrics/CompactionMetrics;
            ifnull 8
         7: .line 255
            aload 0 /* this */
            getfield org.apache.cassandra.db.compaction.CompactionIterator.metrics:Lorg/apache/cassandra/metrics/CompactionMetrics;
            aload 0 /* this */
            invokevirtual org.apache.cassandra.metrics.CompactionMetrics.finishCompaction:(Lorg/apache/cassandra/db/compaction/CompactionInfo$Holder;)V
         8: .line 257
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;
      Exception table:
        from    to  target  type
           0     2       2  any

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
         0: .line 261
            aload 0 /* this */
            invokevirtual org.apache.cassandra.db.compaction.CompactionIterator.getCompactionInfo:()Lorg/apache/cassandra/db/compaction/CompactionInfo;
            invokevirtual org.apache.cassandra.db.compaction.CompactionInfo.toString:()Ljava/lang/String;
            areturn
        end local 0 // org.apache.cassandra.db.compaction.CompactionIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/compaction/CompactionIterator;

  public java.lang.Object next();
    descriptor: ()Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.apache.cassandra.db.compaction.CompactionIterator.next:()Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "CompactionIterator.java"
NestMembers:
  org.apache.cassandra.db.compaction.CompactionIterator$1  org.apache.cassandra.db.compaction.CompactionIterator$1$1  org.apache.cassandra.db.compaction.CompactionIterator$GarbageSkipper  org.apache.cassandra.db.compaction.CompactionIterator$GarbageSkippingUnfilteredRowIterator  org.apache.cassandra.db.compaction.CompactionIterator$Purger
InnerClasses:
  public abstract Holder = org.apache.cassandra.db.compaction.CompactionInfo$Holder of org.apache.cassandra.db.compaction.CompactionInfo
  org.apache.cassandra.db.compaction.CompactionIterator$1
  private GarbageSkipper = org.apache.cassandra.db.compaction.CompactionIterator$GarbageSkipper of org.apache.cassandra.db.compaction.CompactionIterator
  private GarbageSkippingUnfilteredRowIterator = org.apache.cassandra.db.compaction.CompactionIterator$GarbageSkippingUnfilteredRowIterator of org.apache.cassandra.db.compaction.CompactionIterator
  private Purger = org.apache.cassandra.db.compaction.CompactionIterator$Purger of org.apache.cassandra.db.compaction.CompactionIterator
  public abstract MergeListener = org.apache.cassandra.db.partitions.UnfilteredPartitionIterators$MergeListener of org.apache.cassandra.db.partitions.UnfilteredPartitionIterators