public class org.apache.cassandra.db.Memtable implements java.lang.Comparable<org.apache.cassandra.db.Memtable>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.db.Memtable
  super_class: java.lang.Object
{
  private static final org.slf4j.Logger logger;
    descriptor: Lorg/slf4j/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  public static final org.apache.cassandra.utils.memory.MemtablePool MEMORY_POOL;
    descriptor: Lorg/apache/cassandra/utils/memory/MemtablePool;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  private static final int ROW_OVERHEAD_HEAP_SIZE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final org.apache.cassandra.utils.memory.MemtableAllocator allocator;
    descriptor: Lorg/apache/cassandra/utils/memory/MemtableAllocator;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicLong liveDataSize;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicLong currentOperations;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile org.apache.cassandra.utils.concurrent.OpOrder$Barrier writeBarrier;
    descriptor: Lorg/apache/cassandra/utils/concurrent/OpOrder$Barrier;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile java.util.concurrent.atomic.AtomicReference<org.apache.cassandra.db.commitlog.CommitLogPosition> commitLogUpperBound;
    descriptor: Ljava/util/concurrent/atomic/AtomicReference;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
    Signature: Ljava/util/concurrent/atomic/AtomicReference<Lorg/apache/cassandra/db/commitlog/CommitLogPosition;>;

  private java.util.concurrent.atomic.AtomicReference<org.apache.cassandra.db.commitlog.CommitLogPosition> commitLogLowerBound;
    descriptor: Ljava/util/concurrent/atomic/AtomicReference;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/concurrent/atomic/AtomicReference<Lorg/apache/cassandra/db/commitlog/CommitLogPosition;>;

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

  private final java.util.concurrent.ConcurrentNavigableMap<org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.db.partitions.AtomicBTreePartition> partitions;
    descriptor: Ljava/util/concurrent/ConcurrentNavigableMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentNavigableMap<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;>;

  public final org.apache.cassandra.db.ColumnFamilyStore cfs;
    descriptor: Lorg/apache/cassandra/db/ColumnFamilyStore;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

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

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

  public final org.apache.cassandra.db.ClusteringComparator initialComparator;
    descriptor: Lorg/apache/cassandra/db/ClusteringComparator;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  private final org.apache.cassandra.db.Memtable$ColumnsCollector columnsCollector;
    descriptor: Lorg/apache/cassandra/db/Memtable$ColumnsCollector;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.cassandra.db.Memtable$StatsCollector statsCollector;
    descriptor: Lorg/apache/cassandra/db/Memtable$StatsCollector;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private static volatile int[] $SWITCH_TABLE$org$apache$cassandra$config$Config$MemtableAllocationType;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  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=2, locals=0, args_size=0
         0: .line 63
            ldc Lorg/apache/cassandra/db/Memtable;
            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.Memtable.$assertionsDisabled:Z
         3: .line 65
            ldc Lorg/apache/cassandra/db/Memtable;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic org.apache.cassandra.db.Memtable.logger:Lorg/slf4j/Logger;
         4: .line 67
            invokestatic org.apache.cassandra.db.Memtable.createMemtableAllocatorPool:()Lorg/apache/cassandra/utils/memory/MemtablePool;
            putstatic org.apache.cassandra.db.Memtable.MEMORY_POOL:Lorg/apache/cassandra/utils/memory/MemtablePool;
         5: .line 92
            ldc "cassandra.memtable_row_overhead_computation_step"
            ldc "100000"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            invokestatic org.apache.cassandra.db.Memtable.estimateRowOverhead:(I)I
            putstatic org.apache.cassandra.db.Memtable.ROW_OVERHEAD_HEAP_SIZE:I
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static org.apache.cassandra.utils.memory.MemtablePool createMemtableAllocatorPool();
    descriptor: ()Lorg/apache/cassandra/utils/memory/MemtablePool;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=9, locals=4, args_size=0
         0: .line 71
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMemtableHeapSpaceInMb:()J
            bipush 20
            lshl
            lstore 0 /* heapLimit */
        start local 0 // long heapLimit
         1: .line 72
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMemtableOffheapSpaceInMb:()J
            bipush 20
            lshl
            lstore 2 /* offHeapLimit */
        start local 2 // long offHeapLimit
         2: .line 73
            invokestatic org.apache.cassandra.db.Memtable.$SWITCH_TABLE$org$apache$cassandra$config$Config$MemtableAllocationType:()[I
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMemtableAllocationType:()Lorg/apache/cassandra/config/Config$MemtableAllocationType;
            invokevirtual org.apache.cassandra.config.Config$MemtableAllocationType.ordinal:()I
            iaload
            tableswitch { // 1 - 4
                    1: 3
                    2: 4
                    3: 5
                    4: 8
              default: 9
          }
         3: .line 76
      StackMap locals: long long
      StackMap stack:
            new org.apache.cassandra.utils.memory.HeapPool
            dup
            lload 0 /* heapLimit */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMemtableCleanupThreshold:()Ljava/lang/Float;
            invokevirtual java.lang.Float.floatValue:()F
            new org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily
            dup
            invokespecial org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily.<init>:()V
            invokespecial org.apache.cassandra.utils.memory.HeapPool.<init>:(JFLjava/lang/Runnable;)V
            areturn
         4: .line 78
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.utils.memory.SlabPool
            dup
            lload 0 /* heapLimit */
            lconst_0
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMemtableCleanupThreshold:()Ljava/lang/Float;
            invokevirtual java.lang.Float.floatValue:()F
            new org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily
            dup
            invokespecial org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily.<init>:()V
            invokespecial org.apache.cassandra.utils.memory.SlabPool.<init>:(JJFLjava/lang/Runnable;)V
            areturn
         5: .line 80
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.io.util.FileUtils.isCleanerAvailable:Z
            ifne 7
         6: .line 82
            new java.lang.IllegalStateException
            dup
            ldc "Could not free direct byte buffer: offheap_buffers is not a safe memtable_allocation_type without this ability, please adjust your config. This feature is only guaranteed to work on an Oracle JVM. Refusing to start."
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 84
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.utils.memory.SlabPool
            dup
            lload 0 /* heapLimit */
            lload 2 /* offHeapLimit */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMemtableCleanupThreshold:()Ljava/lang/Float;
            invokevirtual java.lang.Float.floatValue:()F
            new org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily
            dup
            invokespecial org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily.<init>:()V
            invokespecial org.apache.cassandra.utils.memory.SlabPool.<init>:(JJFLjava/lang/Runnable;)V
            areturn
         8: .line 86
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.utils.memory.NativePool
            dup
            lload 0 /* heapLimit */
            lload 2 /* offHeapLimit */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMemtableCleanupThreshold:()Ljava/lang/Float;
            invokevirtual java.lang.Float.floatValue:()F
            new org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily
            dup
            invokespecial org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily.<init>:()V
            invokespecial org.apache.cassandra.utils.memory.NativePool.<init>:(JJFLjava/lang/Runnable;)V
            areturn
         9: .line 88
      StackMap locals:
      StackMap stack:
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        end local 2 // long offHeapLimit
        end local 0 // long heapLimit
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            1   10     0     heapLimit  J
            2   10     2  offHeapLimit  J

  public int compareTo(org.apache.cassandra.db.Memtable);
    descriptor: (Lorg/apache/cassandra/db/Memtable;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.db.Memtable that
         0: .line 111
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.approximateCommitLogLowerBound:Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
            aload 1 /* that */
            getfield org.apache.cassandra.db.Memtable.approximateCommitLogLowerBound:Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
            invokevirtual org.apache.cassandra.db.commitlog.CommitLogPosition.compareTo:(Lorg/apache/cassandra/db/commitlog/CommitLogPosition;)I
            ireturn
        end local 1 // org.apache.cassandra.db.Memtable that
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;
            0    1     1  that  Lorg/apache/cassandra/db/Memtable;
    MethodParameters:
      Name  Flags
      that  

  public void <init>(java.util.concurrent.atomic.AtomicReference<org.apache.cassandra.db.commitlog.CommitLogPosition>, org.apache.cassandra.db.ColumnFamilyStore);
    descriptor: (Ljava/util/concurrent/atomic/AtomicReference;Lorg/apache/cassandra/db/ColumnFamilyStore;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // java.util.concurrent.atomic.AtomicReference commitLogLowerBound
        start local 2 // org.apache.cassandra.db.ColumnFamilyStore cfs
         0: .line 141
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 95
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            lconst_0
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:(J)V
            putfield org.apache.cassandra.db.Memtable.liveDataSize:Ljava/util/concurrent/atomic/AtomicLong;
         2: .line 96
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            lconst_0
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:(J)V
            putfield org.apache.cassandra.db.Memtable.currentOperations:Ljava/util/concurrent/atomic/AtomicLong;
         3: .line 107
            aload 0 /* this */
            getstatic org.apache.cassandra.db.commitlog.CommitLog.instance:Lorg/apache/cassandra/db/commitlog/CommitLog;
            invokevirtual org.apache.cassandra.db.commitlog.CommitLog.getCurrentPosition:()Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
            putfield org.apache.cassandra.db.Memtable.approximateCommitLogLowerBound:Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
         4: .line 125
            aload 0 /* this */
            new java.util.concurrent.ConcurrentSkipListMap
            dup
            invokespecial java.util.concurrent.ConcurrentSkipListMap.<init>:()V
            putfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
         5: .line 127
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield org.apache.cassandra.db.Memtable.creationNano:J
         6: .line 130
            aload 0 /* this */
            ldc 9223372036854775807
            putfield org.apache.cassandra.db.Memtable.minTimestamp:J
         7: .line 138
            aload 0 /* this */
            new org.apache.cassandra.db.Memtable$StatsCollector
            dup
            invokespecial org.apache.cassandra.db.Memtable$StatsCollector.<init>:()V
            putfield org.apache.cassandra.db.Memtable.statsCollector:Lorg/apache/cassandra/db/Memtable$StatsCollector;
         8: .line 143
            aload 0 /* this */
            aload 2 /* cfs */
            putfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
         9: .line 144
            aload 0 /* this */
            aload 1 /* commitLogLowerBound */
            putfield org.apache.cassandra.db.Memtable.commitLogLowerBound:Ljava/util/concurrent/atomic/AtomicReference;
        10: .line 145
            aload 0 /* this */
            getstatic org.apache.cassandra.db.Memtable.MEMORY_POOL:Lorg/apache/cassandra/utils/memory/MemtablePool;
            invokevirtual org.apache.cassandra.utils.memory.MemtablePool.newAllocator:()Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            putfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
        11: .line 146
            aload 0 /* this */
            aload 2 /* cfs */
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
            getfield org.apache.cassandra.config.CFMetaData.comparator:Lorg/apache/cassandra/db/ClusteringComparator;
            putfield org.apache.cassandra.db.Memtable.initialComparator:Lorg/apache/cassandra/db/ClusteringComparator;
        12: .line 147
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            invokevirtual org.apache.cassandra.db.ColumnFamilyStore.scheduleFlush:()V
        13: .line 148
            aload 0 /* this */
            new org.apache.cassandra.db.Memtable$ColumnsCollector
            dup
            aload 2 /* cfs */
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
            invokevirtual org.apache.cassandra.config.CFMetaData.partitionColumns:()Lorg/apache/cassandra/db/PartitionColumns;
            invokespecial org.apache.cassandra.db.Memtable$ColumnsCollector.<init>:(Lorg/apache/cassandra/db/PartitionColumns;)V
            putfield org.apache.cassandra.db.Memtable.columnsCollector:Lorg/apache/cassandra/db/Memtable$ColumnsCollector;
        14: .line 149
            return
        end local 2 // org.apache.cassandra.db.ColumnFamilyStore cfs
        end local 1 // java.util.concurrent.atomic.AtomicReference commitLogLowerBound
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   15     0                 this  Lorg/apache/cassandra/db/Memtable;
            0   15     1  commitLogLowerBound  Ljava/util/concurrent/atomic/AtomicReference<Lorg/apache/cassandra/db/commitlog/CommitLogPosition;>;
            0   15     2                  cfs  Lorg/apache/cassandra/db/ColumnFamilyStore;
    Signature: (Ljava/util/concurrent/atomic/AtomicReference<Lorg/apache/cassandra/db/commitlog/CommitLogPosition;>;Lorg/apache/cassandra/db/ColumnFamilyStore;)V
    MethodParameters:
                     Name  Flags
      commitLogLowerBound  
      cfs                  

  public void <init>(org.apache.cassandra.config.CFMetaData);
    descriptor: (Lorg/apache/cassandra/config/CFMetaData;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.config.CFMetaData metadata
         0: .line 153
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 95
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            lconst_0
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:(J)V
            putfield org.apache.cassandra.db.Memtable.liveDataSize:Ljava/util/concurrent/atomic/AtomicLong;
         2: .line 96
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            lconst_0
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:(J)V
            putfield org.apache.cassandra.db.Memtable.currentOperations:Ljava/util/concurrent/atomic/AtomicLong;
         3: .line 107
            aload 0 /* this */
            getstatic org.apache.cassandra.db.commitlog.CommitLog.instance:Lorg/apache/cassandra/db/commitlog/CommitLog;
            invokevirtual org.apache.cassandra.db.commitlog.CommitLog.getCurrentPosition:()Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
            putfield org.apache.cassandra.db.Memtable.approximateCommitLogLowerBound:Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
         4: .line 125
            aload 0 /* this */
            new java.util.concurrent.ConcurrentSkipListMap
            dup
            invokespecial java.util.concurrent.ConcurrentSkipListMap.<init>:()V
            putfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
         5: .line 127
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield org.apache.cassandra.db.Memtable.creationNano:J
         6: .line 130
            aload 0 /* this */
            ldc 9223372036854775807
            putfield org.apache.cassandra.db.Memtable.minTimestamp:J
         7: .line 138
            aload 0 /* this */
            new org.apache.cassandra.db.Memtable$StatsCollector
            dup
            invokespecial org.apache.cassandra.db.Memtable$StatsCollector.<init>:()V
            putfield org.apache.cassandra.db.Memtable.statsCollector:Lorg/apache/cassandra/db/Memtable$StatsCollector;
         8: .line 155
            aload 0 /* this */
            aload 1 /* metadata */
            getfield org.apache.cassandra.config.CFMetaData.comparator:Lorg/apache/cassandra/db/ClusteringComparator;
            putfield org.apache.cassandra.db.Memtable.initialComparator:Lorg/apache/cassandra/db/ClusteringComparator;
         9: .line 156
            aload 0 /* this */
            aconst_null
            putfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
        10: .line 157
            aload 0 /* this */
            aconst_null
            putfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
        11: .line 158
            aload 0 /* this */
            new org.apache.cassandra.db.Memtable$ColumnsCollector
            dup
            aload 1 /* metadata */
            invokevirtual org.apache.cassandra.config.CFMetaData.partitionColumns:()Lorg/apache/cassandra/db/PartitionColumns;
            invokespecial org.apache.cassandra.db.Memtable$ColumnsCollector.<init>:(Lorg/apache/cassandra/db/PartitionColumns;)V
            putfield org.apache.cassandra.db.Memtable.columnsCollector:Lorg/apache/cassandra/db/Memtable$ColumnsCollector;
        12: .line 159
            return
        end local 1 // org.apache.cassandra.config.CFMetaData metadata
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   13     0      this  Lorg/apache/cassandra/db/Memtable;
            0   13     1  metadata  Lorg/apache/cassandra/config/CFMetaData;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.google.common.annotations.VisibleForTesting()
    MethodParameters:
          Name  Flags
      metadata  

  public org.apache.cassandra.utils.memory.MemtableAllocator getAllocator();
    descriptor: ()Lorg/apache/cassandra/utils/memory/MemtableAllocator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 163
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            areturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;

  public long getLiveDataSize();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 168
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.liveDataSize:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            lreturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;

  public long getOperations();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 173
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.currentOperations:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            lreturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;

  public void setDiscarding(org.apache.cassandra.utils.concurrent.OpOrder$Barrier, java.util.concurrent.atomic.AtomicReference<org.apache.cassandra.db.commitlog.CommitLogPosition>);
    descriptor: (Lorg/apache/cassandra/utils/concurrent/OpOrder$Barrier;Ljava/util/concurrent/atomic/AtomicReference;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.utils.concurrent.OpOrder$Barrier writeBarrier
        start local 2 // java.util.concurrent.atomic.AtomicReference commitLogUpperBound
         0: .line 179
            getstatic org.apache.cassandra.db.Memtable.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.writeBarrier:Lorg/apache/cassandra/utils/concurrent/OpOrder$Barrier;
            ifnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 180
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* commitLogUpperBound */
            putfield org.apache.cassandra.db.Memtable.commitLogUpperBound:Ljava/util/concurrent/atomic/AtomicReference;
         2: .line 181
            aload 0 /* this */
            aload 1 /* writeBarrier */
            putfield org.apache.cassandra.db.Memtable.writeBarrier:Lorg/apache/cassandra/utils/concurrent/OpOrder$Barrier;
         3: .line 182
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.setDiscarding:()V
         4: .line 183
            return
        end local 2 // java.util.concurrent.atomic.AtomicReference commitLogUpperBound
        end local 1 // org.apache.cassandra.utils.concurrent.OpOrder$Barrier writeBarrier
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    5     0                 this  Lorg/apache/cassandra/db/Memtable;
            0    5     1         writeBarrier  Lorg/apache/cassandra/utils/concurrent/OpOrder$Barrier;
            0    5     2  commitLogUpperBound  Ljava/util/concurrent/atomic/AtomicReference<Lorg/apache/cassandra/db/commitlog/CommitLogPosition;>;
    Signature: (Lorg/apache/cassandra/utils/concurrent/OpOrder$Barrier;Ljava/util/concurrent/atomic/AtomicReference<Lorg/apache/cassandra/db/commitlog/CommitLogPosition;>;)V
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    MethodParameters:
                     Name  Flags
      writeBarrier         
      commitLogUpperBound  

  void setDiscarded();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 187
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.setDiscarded:()V
         1: .line 188
            return
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/db/Memtable;

  public boolean accepts(org.apache.cassandra.utils.concurrent.OpOrder$Group, org.apache.cassandra.db.commitlog.CommitLogPosition);
    descriptor: (Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;Lorg/apache/cassandra/db/commitlog/CommitLogPosition;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.utils.concurrent.OpOrder$Group opGroup
        start local 2 // org.apache.cassandra.db.commitlog.CommitLogPosition commitLogPosition
         0: .line 194
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.writeBarrier:Lorg/apache/cassandra/utils/concurrent/OpOrder$Barrier;
            astore 3 /* barrier */
        start local 3 // org.apache.cassandra.utils.concurrent.OpOrder$Barrier barrier
         1: .line 195
            aload 3 /* barrier */
            ifnonnull 3
         2: .line 196
            iconst_1
            ireturn
         3: .line 198
      StackMap locals: org.apache.cassandra.utils.concurrent.OpOrder$Barrier
      StackMap stack:
            aload 3 /* barrier */
            aload 1 /* opGroup */
            invokevirtual org.apache.cassandra.utils.concurrent.OpOrder$Barrier.isAfter:(Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;)Z
            ifne 5
         4: .line 199
            iconst_0
            ireturn
         5: .line 201
      StackMap locals:
      StackMap stack:
            aload 2 /* commitLogPosition */
            ifnonnull 7
         6: .line 202
            iconst_1
            ireturn
         7: .line 210
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.commitLogUpperBound:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.commitlog.CommitLogPosition
            astore 4 /* currentLast */
        start local 4 // org.apache.cassandra.db.commitlog.CommitLogPosition currentLast
         8: .line 211
            aload 4 /* currentLast */
            instanceof org.apache.cassandra.db.Memtable$LastCommitLogPosition
            ifeq 11
         9: .line 212
            aload 4 /* currentLast */
            aload 2 /* commitLogPosition */
            invokevirtual org.apache.cassandra.db.commitlog.CommitLogPosition.compareTo:(Lorg/apache/cassandra/db/commitlog/CommitLogPosition;)I
            iflt 10
            iconst_1
            ireturn
      StackMap locals: org.apache.cassandra.db.commitlog.CommitLogPosition
      StackMap stack:
        10: iconst_0
            ireturn
        11: .line 213
      StackMap locals:
      StackMap stack:
            aload 4 /* currentLast */
            ifnull 13
            aload 4 /* currentLast */
            aload 2 /* commitLogPosition */
            invokevirtual org.apache.cassandra.db.commitlog.CommitLogPosition.compareTo:(Lorg/apache/cassandra/db/commitlog/CommitLogPosition;)I
            iflt 13
        12: .line 214
            iconst_1
            ireturn
        13: .line 215
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.commitLogUpperBound:Ljava/util/concurrent/atomic/AtomicReference;
            aload 4 /* currentLast */
            aload 2 /* commitLogPosition */
            invokevirtual java.util.concurrent.atomic.AtomicReference.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 7
        14: .line 216
            iconst_1
            ireturn
        end local 4 // org.apache.cassandra.db.commitlog.CommitLogPosition currentLast
        end local 3 // org.apache.cassandra.utils.concurrent.OpOrder$Barrier barrier
        end local 2 // org.apache.cassandra.db.commitlog.CommitLogPosition commitLogPosition
        end local 1 // org.apache.cassandra.utils.concurrent.OpOrder$Group opGroup
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   15     0               this  Lorg/apache/cassandra/db/Memtable;
            0   15     1            opGroup  Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;
            0   15     2  commitLogPosition  Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
            1   15     3            barrier  Lorg/apache/cassandra/utils/concurrent/OpOrder$Barrier;
            8   15     4        currentLast  Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
    MethodParameters:
                   Name  Flags
      opGroup            
      commitLogPosition  

  public org.apache.cassandra.db.commitlog.CommitLogPosition getCommitLogLowerBound();
    descriptor: ()Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 222
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.commitLogLowerBound:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.commitlog.CommitLogPosition
            areturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;

  public org.apache.cassandra.db.commitlog.CommitLogPosition getCommitLogUpperBound();
    descriptor: ()Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 227
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.commitLogUpperBound:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.commitlog.CommitLogPosition
            areturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;

  public boolean isLive();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 232
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.isLive:()Z
            ireturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;

  public boolean isClean();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 237
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.isEmpty:()Z
            ireturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;

  public boolean mayContainDataBefore(org.apache.cassandra.db.commitlog.CommitLogPosition);
    descriptor: (Lorg/apache/cassandra/db/commitlog/CommitLogPosition;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.db.commitlog.CommitLogPosition position
         0: .line 242
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.approximateCommitLogLowerBound:Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
            aload 1 /* position */
            invokevirtual org.apache.cassandra.db.commitlog.CommitLogPosition.compareTo:(Lorg/apache/cassandra/db/commitlog/CommitLogPosition;)I
            ifge 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // org.apache.cassandra.db.commitlog.CommitLogPosition position
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/cassandra/db/Memtable;
            0    2     1  position  Lorg/apache/cassandra/db/commitlog/CommitLogPosition;
    MethodParameters:
          Name  Flags
      position  

  public boolean isExpired();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 250
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
            getfield org.apache.cassandra.config.CFMetaData.params:Lorg/apache/cassandra/schema/TableParams;
            getfield org.apache.cassandra.schema.TableParams.memtableFlushPeriodInMs:I
            istore 1 /* period */
        start local 1 // int period
         1: .line 251
            iload 1 /* period */
            ifle 2
            invokestatic java.lang.System.nanoTime:()J
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.creationNano:J
            lsub
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            iload 1 /* period */
            i2l
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lcmp
            iflt 2
            iconst_1
            ireturn
      StackMap locals: int
      StackMap stack:
         2: iconst_0
            ireturn
        end local 1 // int period
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/apache/cassandra/db/Memtable;
            1    3     1  period  I

  long put(org.apache.cassandra.db.partitions.PartitionUpdate, org.apache.cassandra.index.transactions.UpdateTransaction, org.apache.cassandra.utils.concurrent.OpOrder$Group);
    descriptor: (Lorg/apache/cassandra/db/partitions/PartitionUpdate;Lorg/apache/cassandra/index/transactions/UpdateTransaction;Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;)J
    flags: (0x0000) 
    Code:
      stack=5, locals=10, args_size=4
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.db.partitions.PartitionUpdate update
        start local 2 // org.apache.cassandra.index.transactions.UpdateTransaction indexer
        start local 3 // org.apache.cassandra.utils.concurrent.OpOrder$Group opGroup
         0: .line 262
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            aload 1 /* update */
            invokevirtual org.apache.cassandra.db.partitions.PartitionUpdate.partitionKey:()Lorg/apache/cassandra/db/DecoratedKey;
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.partitions.AtomicBTreePartition
            astore 4 /* previous */
        start local 4 // org.apache.cassandra.db.partitions.AtomicBTreePartition previous
         1: .line 264
            lconst_0
            lstore 5 /* initialSize */
        start local 5 // long initialSize
         2: .line 265
            aload 4 /* previous */
            ifnonnull 11
         3: .line 267
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            aload 1 /* update */
            invokevirtual org.apache.cassandra.db.partitions.PartitionUpdate.partitionKey:()Lorg/apache/cassandra/db/DecoratedKey;
            aload 3 /* opGroup */
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.clone:(Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;)Lorg/apache/cassandra/db/DecoratedKey;
            astore 7 /* cloneKey */
        start local 7 // org.apache.cassandra.db.DecoratedKey cloneKey
         4: .line 268
            new org.apache.cassandra.db.partitions.AtomicBTreePartition
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
            aload 7 /* cloneKey */
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            invokespecial org.apache.cassandra.db.partitions.AtomicBTreePartition.<init>:(Lorg/apache/cassandra/config/CFMetaData;Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/utils/memory/MemtableAllocator;)V
            astore 8 /* empty */
        start local 8 // org.apache.cassandra.db.partitions.AtomicBTreePartition empty
         5: .line 270
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            aload 7 /* cloneKey */
            aload 8 /* empty */
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.partitions.AtomicBTreePartition
            astore 4 /* previous */
         6: .line 271
            aload 4 /* previous */
            ifnonnull 11
         7: .line 273
            aload 8 /* empty */
            astore 4 /* previous */
         8: .line 276
            aload 7 /* cloneKey */
            invokevirtual org.apache.cassandra.db.DecoratedKey.getToken:()Lorg/apache/cassandra/dht/Token;
            invokevirtual org.apache.cassandra.dht.Token.getHeapSize:()J
            getstatic org.apache.cassandra.db.Memtable.ROW_OVERHEAD_HEAP_SIZE:I
            i2l
            ladd
            l2i
            istore 9 /* overhead */
        start local 9 // int overhead
         9: .line 277
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.onHeap:()Lorg/apache/cassandra/utils/memory/MemtableAllocator$SubAllocator;
            iload 9 /* overhead */
            i2l
            aload 3 /* opGroup */
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator$SubAllocator.allocate:(JLorg/apache/cassandra/utils/concurrent/OpOrder$Group;)V
        10: .line 278
            ldc 8
            lstore 5 /* initialSize */
        end local 9 // int overhead
        end local 8 // org.apache.cassandra.db.partitions.AtomicBTreePartition empty
        end local 7 // org.apache.cassandra.db.DecoratedKey cloneKey
        11: .line 282
      StackMap locals: org.apache.cassandra.db.partitions.AtomicBTreePartition long
      StackMap stack:
            aload 4 /* previous */
            aload 1 /* update */
            aload 3 /* opGroup */
            aload 2 /* indexer */
            invokevirtual org.apache.cassandra.db.partitions.AtomicBTreePartition.addAllWithSizeDelta:(Lorg/apache/cassandra/db/partitions/PartitionUpdate;Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;Lorg/apache/cassandra/index/transactions/UpdateTransaction;)[J
            astore 7 /* pair */
        start local 7 // long[] pair
        12: .line 283
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.minTimestamp:J
            aload 4 /* previous */
            invokevirtual org.apache.cassandra.db.partitions.AtomicBTreePartition.stats:()Lorg/apache/cassandra/db/rows/EncodingStats;
            getfield org.apache.cassandra.db.rows.EncodingStats.minTimestamp:J
            invokestatic java.lang.Math.min:(JJ)J
            putfield org.apache.cassandra.db.Memtable.minTimestamp:J
        13: .line 284
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.liveDataSize:Ljava/util/concurrent/atomic/AtomicLong;
            lload 5 /* initialSize */
            aload 7 /* pair */
            iconst_0
            laload
            ladd
            invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
            pop2
        14: .line 285
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.columnsCollector:Lorg/apache/cassandra/db/Memtable$ColumnsCollector;
            aload 1 /* update */
            invokevirtual org.apache.cassandra.db.partitions.PartitionUpdate.columns:()Lorg/apache/cassandra/db/PartitionColumns;
            invokevirtual org.apache.cassandra.db.Memtable$ColumnsCollector.update:(Lorg/apache/cassandra/db/PartitionColumns;)V
        15: .line 286
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.statsCollector:Lorg/apache/cassandra/db/Memtable$StatsCollector;
            aload 1 /* update */
            invokevirtual org.apache.cassandra.db.partitions.PartitionUpdate.stats:()Lorg/apache/cassandra/db/rows/EncodingStats;
            invokevirtual org.apache.cassandra.db.Memtable$StatsCollector.update:(Lorg/apache/cassandra/db/rows/EncodingStats;)V
        16: .line 287
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.currentOperations:Ljava/util/concurrent/atomic/AtomicLong;
            aload 1 /* update */
            invokevirtual org.apache.cassandra.db.partitions.PartitionUpdate.operationCount:()I
            i2l
            invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
            pop2
        17: .line 288
            aload 7 /* pair */
            iconst_1
            laload
            lreturn
        end local 7 // long[] pair
        end local 5 // long initialSize
        end local 4 // org.apache.cassandra.db.partitions.AtomicBTreePartition previous
        end local 3 // org.apache.cassandra.utils.concurrent.OpOrder$Group opGroup
        end local 2 // org.apache.cassandra.index.transactions.UpdateTransaction indexer
        end local 1 // org.apache.cassandra.db.partitions.PartitionUpdate update
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   18     0         this  Lorg/apache/cassandra/db/Memtable;
            0   18     1       update  Lorg/apache/cassandra/db/partitions/PartitionUpdate;
            0   18     2      indexer  Lorg/apache/cassandra/index/transactions/UpdateTransaction;
            0   18     3      opGroup  Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;
            1   18     4     previous  Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;
            2   18     5  initialSize  J
            4   11     7     cloneKey  Lorg/apache/cassandra/db/DecoratedKey;
            5   11     8        empty  Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;
            9   11     9     overhead  I
           12   18     7         pair  [J
    MethodParameters:
         Name  Flags
      update   
      indexer  
      opGroup  

  public int partitionCount();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 293
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.size:()I
            ireturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;

  public java.util.List<org.apache.cassandra.db.Memtable$FlushRunnable> flushRunnables(org.apache.cassandra.db.lifecycle.LifecycleTransaction);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;)Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.db.lifecycle.LifecycleTransaction txn
         0: .line 298
            aload 0 /* this */
            aload 1 /* txn */
            invokevirtual org.apache.cassandra.db.Memtable.createFlushRunnables:(Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;)Ljava/util/List;
            areturn
        end local 1 // org.apache.cassandra.db.lifecycle.LifecycleTransaction txn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;
            0    1     1   txn  Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;
    Signature: (Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;)Ljava/util/List<Lorg/apache/cassandra/db/Memtable$FlushRunnable;>;
    MethodParameters:
      Name  Flags
      txn   

  private java.util.List<org.apache.cassandra.db.Memtable$FlushRunnable> createFlushRunnables(org.apache.cassandra.db.lifecycle.LifecycleTransaction);
    descriptor: (Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;)Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=9, args_size=2
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.db.lifecycle.LifecycleTransaction txn
         0: .line 303
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            invokevirtual org.apache.cassandra.db.ColumnFamilyStore.getDiskBoundaries:()Lorg/apache/cassandra/db/DiskBoundaries;
            astore 2 /* diskBoundaries */
        start local 2 // org.apache.cassandra.db.DiskBoundaries diskBoundaries
         1: .line 304
            aload 2 /* diskBoundaries */
            getfield org.apache.cassandra.db.DiskBoundaries.positions:Lcom/google/common/collect/ImmutableList;
            astore 3 /* boundaries */
        start local 3 // java.util.List boundaries
         2: .line 305
            aload 2 /* diskBoundaries */
            getfield org.apache.cassandra.db.DiskBoundaries.directories:Ljava/util/List;
            astore 4 /* locations */
        start local 4 // java.util.List locations
         3: .line 306
            aload 3 /* boundaries */
            ifnonnull 5
         4: .line 307
            new org.apache.cassandra.db.Memtable$FlushRunnable
            dup
            aload 0 /* this */
            aload 1 /* txn */
            invokespecial org.apache.cassandra.db.Memtable$FlushRunnable.<init>:(Lorg/apache/cassandra/db/Memtable;Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;)V
            invokestatic java.util.Collections.singletonList:(Ljava/lang/Object;)Ljava/util/List;
            areturn
         5: .line 309
      StackMap locals: org.apache.cassandra.db.DiskBoundaries java.util.List java.util.List
      StackMap stack:
            new java.util.ArrayList
            dup
            aload 3 /* boundaries */
            invokeinterface java.util.List.size:()I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 5 /* runnables */
        start local 5 // java.util.List runnables
         6: .line 310
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            invokevirtual org.apache.cassandra.db.ColumnFamilyStore.getPartitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            invokeinterface org.apache.cassandra.dht.IPartitioner.getMinimumToken:()Lorg/apache/cassandra/dht/Token;
            invokevirtual org.apache.cassandra.dht.Token.minKeyBound:()Lorg/apache/cassandra/dht/Token$KeyBound;
            astore 6 /* rangeStart */
        start local 6 // org.apache.cassandra.db.PartitionPosition rangeStart
         7: .line 313
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         8: goto 13
         9: .line 315
      StackMap locals: java.util.List org.apache.cassandra.db.PartitionPosition int
      StackMap stack:
            aload 3 /* boundaries */
            iload 7 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.PartitionPosition
            astore 8 /* t */
        start local 8 // org.apache.cassandra.db.PartitionPosition t
        10: .line 316
            aload 5 /* runnables */
            new org.apache.cassandra.db.Memtable$FlushRunnable
            dup
            aload 0 /* this */
            aload 6 /* rangeStart */
            aload 8 /* t */
            aload 4 /* locations */
            iload 7 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.Directories$DataDirectory
            aload 1 /* txn */
            invokespecial org.apache.cassandra.db.Memtable$FlushRunnable.<init>:(Lorg/apache/cassandra/db/Memtable;Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/Directories$DataDirectory;Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;)V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        11: .line 317
            aload 8 /* t */
            astore 6 /* rangeStart */
        end local 8 // org.apache.cassandra.db.PartitionPosition t
        12: .line 313
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 7 /* i */
            aload 3 /* boundaries */
            invokeinterface java.util.List.size:()I
            if_icmplt 9
        end local 7 // int i
        14: .line 319
            aload 5 /* runnables */
        15: areturn
        16: .line 321
      StackMap locals: org.apache.cassandra.db.Memtable org.apache.cassandra.db.lifecycle.LifecycleTransaction org.apache.cassandra.db.DiskBoundaries java.util.List java.util.List java.util.List org.apache.cassandra.db.PartitionPosition
      StackMap stack: java.lang.Throwable
            astore 7 /* e */
        start local 7 // java.lang.Throwable e
        17: .line 323
            aload 0 /* this */
            aload 5 /* runnables */
            aload 7 /* e */
            invokevirtual org.apache.cassandra.db.Memtable.abortRunnables:(Ljava/util/List;Ljava/lang/Throwable;)Ljava/lang/Throwable;
            invokestatic com.google.common.base.Throwables.propagate:(Ljava/lang/Throwable;)Ljava/lang/RuntimeException;
            athrow
        end local 7 // java.lang.Throwable e
        end local 6 // org.apache.cassandra.db.PartitionPosition rangeStart
        end local 5 // java.util.List runnables
        end local 4 // java.util.List locations
        end local 3 // java.util.List boundaries
        end local 2 // org.apache.cassandra.db.DiskBoundaries diskBoundaries
        end local 1 // org.apache.cassandra.db.lifecycle.LifecycleTransaction txn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   18     0            this  Lorg/apache/cassandra/db/Memtable;
            0   18     1             txn  Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;
            1   18     2  diskBoundaries  Lorg/apache/cassandra/db/DiskBoundaries;
            2   18     3      boundaries  Ljava/util/List<Lorg/apache/cassandra/db/PartitionPosition;>;
            3   18     4       locations  Ljava/util/List<Lorg/apache/cassandra/db/Directories$DataDirectory;>;
            6   18     5       runnables  Ljava/util/List<Lorg/apache/cassandra/db/Memtable$FlushRunnable;>;
            7   18     6      rangeStart  Lorg/apache/cassandra/db/PartitionPosition;
            8   14     7               i  I
           10   12     8               t  Lorg/apache/cassandra/db/PartitionPosition;
           17   18     7               e  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           7    15      16  Class java.lang.Throwable
    Signature: (Lorg/apache/cassandra/db/lifecycle/LifecycleTransaction;)Ljava/util/List<Lorg/apache/cassandra/db/Memtable$FlushRunnable;>;
    MethodParameters:
      Name  Flags
      txn   

  public java.lang.Throwable abortRunnables(java.util.List<org.apache.cassandra.db.Memtable$FlushRunnable>, java.lang.Throwable);
    descriptor: (Ljava/util/List;Ljava/lang/Throwable;)Ljava/lang/Throwable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=3
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // java.util.List runnables
        start local 2 // java.lang.Throwable t
         0: .line 329
            aload 1 /* runnables */
            ifnull 5
         1: .line 330
            aload 1 /* runnables */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: org.apache.cassandra.db.Memtable java.util.List java.lang.Throwable top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.Memtable$FlushRunnable
            astore 3 /* runnable */
        start local 3 // org.apache.cassandra.db.Memtable$FlushRunnable runnable
         3: .line 331
            aload 3 /* runnable */
            getfield org.apache.cassandra.db.Memtable$FlushRunnable.writer:Lorg/apache/cassandra/io/sstable/SSTableMultiWriter;
            aload 2 /* t */
            invokeinterface org.apache.cassandra.io.sstable.SSTableMultiWriter.abort:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            astore 2 /* t */
        end local 3 // org.apache.cassandra.db.Memtable$FlushRunnable runnable
         4: .line 330
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 332
      StackMap locals: org.apache.cassandra.db.Memtable java.util.List java.lang.Throwable
      StackMap stack:
            aload 2 /* t */
            areturn
        end local 2 // java.lang.Throwable t
        end local 1 // java.util.List runnables
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lorg/apache/cassandra/db/Memtable;
            0    6     1  runnables  Ljava/util/List<Lorg/apache/cassandra/db/Memtable$FlushRunnable;>;
            0    6     2          t  Ljava/lang/Throwable;
            3    4     3   runnable  Lorg/apache/cassandra/db/Memtable$FlushRunnable;
    Signature: (Ljava/util/List<Lorg/apache/cassandra/db/Memtable$FlushRunnable;>;Ljava/lang/Throwable;)Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      runnables  
      t          

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 337
            ldc "Memtable-%s@%s(%s serialized bytes, %s ops, %.0f%%/%.0f%% of on/off-heap limit)"
            bipush 6
            anewarray java.lang.Object
            dup
            iconst_0
         1: .line 338
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            getfield org.apache.cassandra.db.ColumnFamilyStore.name:Ljava/lang/String;
            aastore
            dup
            iconst_1
            aload 0 /* this */
            invokevirtual java.lang.Object.hashCode:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_2
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.liveDataSize:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            invokestatic org.apache.cassandra.utils.FBUtilities.prettyPrintMemory:(J)Ljava/lang/String;
            aastore
            dup
            iconst_3
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.currentOperations:Ljava/util/concurrent/atomic/AtomicLong;
            aastore
            dup
            iconst_4
         2: .line 339
            ldc 100.0
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.onHeap:()Lorg/apache/cassandra/utils/memory/MemtableAllocator$SubAllocator;
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator$SubAllocator.ownershipRatio:()F
            fmul
            invokestatic java.lang.Float.valueOf:(F)Ljava/lang/Float;
            aastore
            dup
            iconst_5
            ldc 100.0
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.allocator:Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.offHeap:()Lorg/apache/cassandra/utils/memory/MemtableAllocator$SubAllocator;
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator$SubAllocator.ownershipRatio:()F
            fmul
            invokestatic java.lang.Float.valueOf:(F)Ljava/lang/Float;
            aastore
         3: .line 337
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/db/Memtable;

  public org.apache.cassandra.db.Memtable$MemtableUnfilteredPartitionIterator makePartitionIterator(org.apache.cassandra.db.filter.ColumnFilter, org.apache.cassandra.db.DataRange, boolean);
    descriptor: (Lorg/apache/cassandra/db/filter/ColumnFilter;Lorg/apache/cassandra/db/DataRange;Z)Lorg/apache/cassandra/db/Memtable$MemtableUnfilteredPartitionIterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=13, args_size=4
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.db.filter.ColumnFilter columnFilter
        start local 2 // org.apache.cassandra.db.DataRange dataRange
        start local 3 // boolean isForThrift
         0: .line 344
            aload 2 /* dataRange */
            invokevirtual org.apache.cassandra.db.DataRange.keyRange:()Lorg/apache/cassandra/dht/AbstractBounds;
            astore 4 /* keyRange */
        start local 4 // org.apache.cassandra.dht.AbstractBounds keyRange
         1: .line 346
            aload 4 /* keyRange */
            getfield org.apache.cassandra.dht.AbstractBounds.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            invokeinterface org.apache.cassandra.db.PartitionPosition.isMinimum:()Z
            istore 5 /* startIsMin */
        start local 5 // boolean startIsMin
         2: .line 347
            aload 4 /* keyRange */
            getfield org.apache.cassandra.dht.AbstractBounds.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            invokeinterface org.apache.cassandra.db.PartitionPosition.isMinimum:()Z
            istore 6 /* stopIsMin */
        start local 6 // boolean stopIsMin
         3: .line 349
            aload 4 /* keyRange */
            instanceof org.apache.cassandra.dht.Bounds
            istore 7 /* isBound */
        start local 7 // boolean isBound
         4: .line 350
            iload 7 /* isBound */
            ifne 5
            aload 4 /* keyRange */
            instanceof org.apache.cassandra.dht.IncludingExcludingBounds
            ifne 5
            iconst_0
            goto 6
      StackMap locals: org.apache.cassandra.db.Memtable org.apache.cassandra.db.filter.ColumnFilter org.apache.cassandra.db.DataRange int org.apache.cassandra.dht.AbstractBounds int int int
      StackMap stack:
         5: iconst_1
      StackMap locals:
      StackMap stack: int
         6: istore 8 /* includeStart */
        start local 8 // boolean includeStart
         7: .line 351
            iload 7 /* isBound */
            ifne 8
            aload 4 /* keyRange */
            instanceof org.apache.cassandra.dht.Range
            ifne 8
            iconst_0
            goto 9
      StackMap locals: int
      StackMap stack:
         8: iconst_1
      StackMap locals:
      StackMap stack: int
         9: istore 9 /* includeStop */
        start local 9 // boolean includeStop
        10: .line 353
            iload 5 /* startIsMin */
            ifeq 15
        11: .line 354
            iload 6 /* stopIsMin */
            ifeq 12
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            goto 13
      StackMap locals: int
      StackMap stack:
        12: aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            aload 4 /* keyRange */
            getfield org.apache.cassandra.dht.AbstractBounds.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            iload 9 /* includeStop */
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.headMap:(Ljava/lang/Object;Z)Ljava/util/concurrent/ConcurrentNavigableMap;
      StackMap locals:
      StackMap stack: java.util.concurrent.ConcurrentNavigableMap
        13: astore 10 /* subMap */
        start local 10 // java.util.Map subMap
        14: goto 19
        end local 10 // java.util.Map subMap
        15: .line 356
      StackMap locals:
      StackMap stack:
            iload 6 /* stopIsMin */
            ifeq 17
        16: .line 357
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            aload 4 /* keyRange */
            getfield org.apache.cassandra.dht.AbstractBounds.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            iload 8 /* includeStart */
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.tailMap:(Ljava/lang/Object;Z)Ljava/util/concurrent/ConcurrentNavigableMap;
            goto 18
        17: .line 358
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            aload 4 /* keyRange */
            getfield org.apache.cassandra.dht.AbstractBounds.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            iload 8 /* includeStart */
            aload 4 /* keyRange */
            getfield org.apache.cassandra.dht.AbstractBounds.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            iload 9 /* includeStop */
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.subMap:(Ljava/lang/Object;ZLjava/lang/Object;Z)Ljava/util/concurrent/ConcurrentNavigableMap;
        18: .line 356
      StackMap locals:
      StackMap stack: java.util.concurrent.ConcurrentNavigableMap
            astore 10 /* subMap */
        start local 10 // java.util.Map subMap
        19: .line 360
      StackMap locals: java.util.Map
      StackMap stack:
            ldc 2147483647
            istore 11 /* minLocalDeletionTime */
        start local 11 // int minLocalDeletionTime
        20: .line 363
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            invokevirtual org.apache.cassandra.db.ColumnFamilyStore.getCompactionStrategyManager:()Lorg/apache/cassandra/db/compaction/CompactionStrategyManager;
            invokevirtual org.apache.cassandra.db.compaction.CompactionStrategyManager.onlyPurgeRepairedTombstones:()Z
            ifeq 22
        21: .line 364
            aload 0 /* this */
            aload 10 /* subMap */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            invokevirtual org.apache.cassandra.db.Memtable.findMinLocalDeletionTime:(Ljava/util/Iterator;)I
            istore 11 /* minLocalDeletionTime */
        22: .line 366
      StackMap locals: int
      StackMap stack:
            aload 10 /* subMap */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 12 /* iter */
        start local 12 // java.util.Iterator iter
        23: .line 368
            new org.apache.cassandra.db.Memtable$MemtableUnfilteredPartitionIterator
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.cfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            aload 12 /* iter */
            iload 3 /* isForThrift */
            iload 11 /* minLocalDeletionTime */
            aload 1 /* columnFilter */
            aload 2 /* dataRange */
            invokespecial org.apache.cassandra.db.Memtable$MemtableUnfilteredPartitionIterator.<init>:(Lorg/apache/cassandra/db/ColumnFamilyStore;Ljava/util/Iterator;ZILorg/apache/cassandra/db/filter/ColumnFilter;Lorg/apache/cassandra/db/DataRange;)V
            areturn
        end local 12 // java.util.Iterator iter
        end local 11 // int minLocalDeletionTime
        end local 10 // java.util.Map subMap
        end local 9 // boolean includeStop
        end local 8 // boolean includeStart
        end local 7 // boolean isBound
        end local 6 // boolean stopIsMin
        end local 5 // boolean startIsMin
        end local 4 // org.apache.cassandra.dht.AbstractBounds keyRange
        end local 3 // boolean isForThrift
        end local 2 // org.apache.cassandra.db.DataRange dataRange
        end local 1 // org.apache.cassandra.db.filter.ColumnFilter columnFilter
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   24     0                  this  Lorg/apache/cassandra/db/Memtable;
            0   24     1          columnFilter  Lorg/apache/cassandra/db/filter/ColumnFilter;
            0   24     2             dataRange  Lorg/apache/cassandra/db/DataRange;
            0   24     3           isForThrift  Z
            1   24     4              keyRange  Lorg/apache/cassandra/dht/AbstractBounds<Lorg/apache/cassandra/db/PartitionPosition;>;
            2   24     5            startIsMin  Z
            3   24     6             stopIsMin  Z
            4   24     7               isBound  Z
            7   24     8          includeStart  Z
           10   24     9           includeStop  Z
           14   15    10                subMap  Ljava/util/Map<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;>;
           19   24    10                subMap  Ljava/util/Map<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;>;
           20   24    11  minLocalDeletionTime  I
           23   24    12                  iter  Ljava/util/Iterator<Ljava/util/Map$Entry<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;>;>;
    MethodParameters:
              Name  Flags
      columnFilter  final
      dataRange     final
      isForThrift   final

  private int findMinLocalDeletionTime(java.util.Iterator<java.util.Map$Entry<org.apache.cassandra.db.PartitionPosition, org.apache.cassandra.db.partitions.AtomicBTreePartition>>);
    descriptor: (Ljava/util/Iterator;)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // java.util.Iterator iterator
         0: .line 373
            ldc 2147483647
            istore 2 /* minLocalDeletionTime */
        start local 2 // int minLocalDeletionTime
         1: .line 374
            goto 4
         2: .line 376
      StackMap locals: int
      StackMap stack:
            aload 1 /* iterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 3 /* entry */
        start local 3 // java.util.Map$Entry entry
         3: .line 377
            iload 2 /* minLocalDeletionTime */
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.partitions.AtomicBTreePartition
            invokevirtual org.apache.cassandra.db.partitions.AtomicBTreePartition.stats:()Lorg/apache/cassandra/db/rows/EncodingStats;
            getfield org.apache.cassandra.db.rows.EncodingStats.minLocalDeletionTime:I
            invokestatic java.lang.Math.min:(II)I
            istore 2 /* minLocalDeletionTime */
        end local 3 // java.util.Map$Entry entry
         4: .line 374
      StackMap locals:
      StackMap stack:
            aload 1 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 379
            iload 2 /* minLocalDeletionTime */
            ireturn
        end local 2 // int minLocalDeletionTime
        end local 1 // java.util.Iterator iterator
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0    6     0                  this  Lorg/apache/cassandra/db/Memtable;
            0    6     1              iterator  Ljava/util/Iterator<Ljava/util/Map$Entry<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;>;>;
            1    6     2  minLocalDeletionTime  I
            3    4     3                 entry  Ljava/util/Map$Entry<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;>;
    Signature: (Ljava/util/Iterator<Ljava/util/Map$Entry<Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/partitions/AtomicBTreePartition;>;>;)I
    MethodParameters:
          Name  Flags
      iterator  

  public org.apache.cassandra.db.partitions.Partition getPartition(org.apache.cassandra.db.DecoratedKey);
    descriptor: (Lorg/apache/cassandra/db/DecoratedKey;)Lorg/apache/cassandra/db/partitions/Partition;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.db.Memtable this
        start local 1 // org.apache.cassandra.db.DecoratedKey key
         0: .line 384
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.partitions:Ljava/util/concurrent/ConcurrentNavigableMap;
            aload 1 /* key */
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.partitions.Partition
            areturn
        end local 1 // org.apache.cassandra.db.DecoratedKey key
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/Memtable;
            0    1     1   key  Lorg/apache/cassandra/db/DecoratedKey;
    MethodParameters:
      Name  Flags
      key   

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

  public void makeUnflushable();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.Memtable this
         0: .line 398
            aload 0 /* this */
            getfield org.apache.cassandra.db.Memtable.liveDataSize:Ljava/util/concurrent/atomic/AtomicLong;
            ldc 1125899906842624
            invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
            pop2
         1: .line 399
            return
        end local 0 // org.apache.cassandra.db.Memtable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/db/Memtable;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()

  private static int estimateRowOverhead(int);
    descriptor: (I)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=10, args_size=1
        start local 0 // int count
         0: .line 522
            aconst_null
            astore 1
            aconst_null
            astore 2
         1: new org.apache.cassandra.utils.concurrent.OpOrder
            dup
            invokespecial org.apache.cassandra.utils.concurrent.OpOrder.<init>:()V
            invokevirtual org.apache.cassandra.utils.concurrent.OpOrder.start:()Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;
            astore 3 /* group */
        start local 3 // org.apache.cassandra.utils.concurrent.OpOrder$Group group
         2: .line 525
            getstatic org.apache.cassandra.db.Memtable.MEMORY_POOL:Lorg/apache/cassandra/utils/memory/MemtablePool;
            invokevirtual org.apache.cassandra.utils.memory.MemtablePool.newAllocator:()Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            astore 5 /* allocator */
        start local 5 // org.apache.cassandra.utils.memory.MemtableAllocator allocator
         3: .line 526
            new java.util.concurrent.ConcurrentSkipListMap
            dup
            invokespecial java.util.concurrent.ConcurrentSkipListMap.<init>:()V
            astore 6 /* partitions */
        start local 6 // java.util.concurrent.ConcurrentNavigableMap partitions
         4: .line 527
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            astore 7 /* val */
        start local 7 // java.lang.Object val
         5: .line 528
            iconst_0
            istore 8 /* i */
        start local 8 // int i
         6: goto 9
         7: .line 529
      StackMap locals: int java.lang.Throwable java.lang.Throwable org.apache.cassandra.utils.concurrent.OpOrder$Group top org.apache.cassandra.utils.memory.MemtableAllocator java.util.concurrent.ConcurrentNavigableMap java.lang.Object int
      StackMap stack:
            aload 6 /* partitions */
            aload 5 /* allocator */
            new org.apache.cassandra.db.BufferDecoratedKey
            dup
            new org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            dup
            iload 8 /* i */
            i2l
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$LongToken.<init>:(J)V
            getstatic org.apache.cassandra.utils.ByteBufferUtil.EMPTY_BYTE_BUFFER:Ljava/nio/ByteBuffer;
            invokespecial org.apache.cassandra.db.BufferDecoratedKey.<init>:(Lorg/apache/cassandra/dht/Token;Ljava/nio/ByteBuffer;)V
            aload 3 /* group */
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.clone:(Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;)Lorg/apache/cassandra/db/DecoratedKey;
            aload 7 /* val */
            invokeinterface java.util.concurrent.ConcurrentNavigableMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 528
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: iload 8 /* i */
            iload 0 /* count */
            if_icmplt 7
        end local 8 // int i
        10: .line 530
            aload 6 /* partitions */
            invokestatic org.apache.cassandra.utils.ObjectSizes.measureDeep:(Ljava/lang/Object;)J
            l2d
            iload 0 /* count */
            i2d
            ddiv
            dstore 8 /* avgSize */
        start local 8 // double avgSize
        11: .line 531
            dload 8 /* avgSize */
            dload 8 /* avgSize */
            invokestatic java.lang.Math.floor:(D)D
            dsub
            ldc 0.05
            dcmpg
            ifge 12
            dload 8 /* avgSize */
            invokestatic java.lang.Math.floor:(D)D
            goto 13
      StackMap locals: int java.lang.Throwable java.lang.Throwable org.apache.cassandra.utils.concurrent.OpOrder$Group top org.apache.cassandra.utils.memory.MemtableAllocator java.util.concurrent.ConcurrentNavigableMap java.lang.Object double
      StackMap stack:
        12: dload 8 /* avgSize */
            invokestatic java.lang.Math.ceil:(D)D
      StackMap locals:
      StackMap stack: double
        13: d2i
            istore 4 /* rowOverhead */
        start local 4 // int rowOverhead
        14: .line 532
            iload 4 /* rowOverhead */
            i2l
            new org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            dup
            lconst_0
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$LongToken.<init>:(J)V
            invokestatic org.apache.cassandra.utils.ObjectSizes.measureDeep:(Ljava/lang/Object;)J
            lsub
            l2i
            istore 4 /* rowOverhead */
        15: .line 533
            iload 4 /* rowOverhead */
            i2l
            getstatic org.apache.cassandra.db.partitions.AtomicBTreePartition.EMPTY_SIZE:J
            ladd
            l2i
            istore 4 /* rowOverhead */
        16: .line 534
            aload 5 /* allocator */
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.setDiscarding:()V
        17: .line 535
            aload 5 /* allocator */
            invokevirtual org.apache.cassandra.utils.memory.MemtableAllocator.setDiscarded:()V
        18: .line 536
            iload 4 /* rowOverhead */
        19: .line 537
            aload 3 /* group */
            ifnull 20
            aload 3 /* group */
            invokevirtual org.apache.cassandra.utils.concurrent.OpOrder$Group.close:()V
        20: .line 536
      StackMap locals: int java.lang.Throwable java.lang.Throwable org.apache.cassandra.utils.concurrent.OpOrder$Group int org.apache.cassandra.utils.memory.MemtableAllocator java.util.concurrent.ConcurrentNavigableMap java.lang.Object double
      StackMap stack: int
            ireturn
        end local 8 // double avgSize
        end local 7 // java.lang.Object val
        end local 6 // java.util.concurrent.ConcurrentNavigableMap partitions
        end local 5 // org.apache.cassandra.utils.memory.MemtableAllocator allocator
        end local 4 // int rowOverhead
      StackMap locals: int java.lang.Throwable java.lang.Throwable org.apache.cassandra.utils.concurrent.OpOrder$Group
      StackMap stack: java.lang.Throwable
        21: astore 1
        22: .line 537
            aload 3 /* group */
            ifnull 23
            aload 3 /* group */
            invokevirtual org.apache.cassandra.utils.concurrent.OpOrder$Group.close:()V
        end local 3 // org.apache.cassandra.utils.concurrent.OpOrder$Group group
      StackMap locals:
      StackMap stack:
        23: aload 1
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        24: astore 2
            aload 1
            ifnonnull 25
            aload 2
            astore 1
            goto 26
      StackMap locals:
      StackMap stack:
        25: aload 1
            aload 2
            if_acmpeq 26
            aload 1
            aload 2
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        26: aload 1
            athrow
        end local 0 // int count
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   27     0        count  I
            2   23     3        group  Lorg/apache/cassandra/utils/concurrent/OpOrder$Group;
           14   21     4  rowOverhead  I
            3   21     5    allocator  Lorg/apache/cassandra/utils/memory/MemtableAllocator;
            4   21     6   partitions  Ljava/util/concurrent/ConcurrentNavigableMap<Lorg/apache/cassandra/db/PartitionPosition;Ljava/lang/Object;>;
            5   21     7          val  Ljava/lang/Object;
            6   10     8            i  I
           11   21     8      avgSize  D
      Exception table:
        from    to  target  type
           2    19      21  any
           1    20      24  any
          21    24      24  any
    MethodParameters:
       Name  Flags
      count  final

  public int compareTo(java.lang.Object);
    descriptor: (Ljava/lang/Object;)I
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            checkcast org.apache.cassandra.db.Memtable
            invokevirtual org.apache.cassandra.db.Memtable.compareTo:(Lorg/apache/cassandra/db/Memtable;)I
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static int[] $SWITCH_TABLE$org$apache$cassandra$config$Config$MemtableAllocationType();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 63
            getstatic org.apache.cassandra.db.Memtable.$SWITCH_TABLE$org$apache$cassandra$config$Config$MemtableAllocationType:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic org.apache.cassandra.config.Config$MemtableAllocationType.values:()[Lorg/apache/cassandra/config/Config$MemtableAllocationType;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic org.apache.cassandra.config.Config$MemtableAllocationType.heap_buffers:Lorg/apache/cassandra/config/Config$MemtableAllocationType;
            invokevirtual org.apache.cassandra.config.Config$MemtableAllocationType.ordinal:()I
            iconst_2
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic org.apache.cassandra.config.Config$MemtableAllocationType.offheap_buffers:Lorg/apache/cassandra/config/Config$MemtableAllocationType;
            invokevirtual org.apache.cassandra.config.Config$MemtableAllocationType.ordinal:()I
            iconst_3
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic org.apache.cassandra.config.Config$MemtableAllocationType.offheap_objects:Lorg/apache/cassandra/config/Config$MemtableAllocationType;
            invokevirtual org.apache.cassandra.config.Config$MemtableAllocationType.ordinal:()I
            iconst_4
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            getstatic org.apache.cassandra.config.Config$MemtableAllocationType.unslabbed_heap_buffers:Lorg/apache/cassandra/config/Config$MemtableAllocationType;
            invokevirtual org.apache.cassandra.config.Config$MemtableAllocationType.ordinal:()I
            iconst_1
            iastore
        12: goto 14
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        13: pop
      StackMap locals:
      StackMap stack:
        14: aload 0
            dup
            putstatic org.apache.cassandra.db.Memtable.$SWITCH_TABLE$org$apache$cassandra$config$Config$MemtableAllocationType:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError
          11    12      13  Class java.lang.NoSuchFieldError
}
Signature: Ljava/lang/Object;Ljava/lang/Comparable<Lorg/apache/cassandra/db/Memtable;>;
SourceFile: "Memtable.java"
NestMembers:
  org.apache.cassandra.db.Memtable$ColumnsCollector  org.apache.cassandra.db.Memtable$FlushRunnable  org.apache.cassandra.db.Memtable$LastCommitLogPosition  org.apache.cassandra.db.Memtable$MemtableUnfilteredPartitionIterator  org.apache.cassandra.db.Memtable$StatsCollector
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map
  public final MemtableAllocationType = org.apache.cassandra.config.Config$MemtableAllocationType of org.apache.cassandra.config.Config
  public FlushLargestColumnFamily = org.apache.cassandra.db.ColumnFamilyStore$FlushLargestColumnFamily of org.apache.cassandra.db.ColumnFamilyStore
  public DataDirectory = org.apache.cassandra.db.Directories$DataDirectory of org.apache.cassandra.db.Directories
  private ColumnsCollector = org.apache.cassandra.db.Memtable$ColumnsCollector of org.apache.cassandra.db.Memtable
  FlushRunnable = org.apache.cassandra.db.Memtable$FlushRunnable of org.apache.cassandra.db.Memtable
  public final LastCommitLogPosition = org.apache.cassandra.db.Memtable$LastCommitLogPosition of org.apache.cassandra.db.Memtable
  public MemtableUnfilteredPartitionIterator = org.apache.cassandra.db.Memtable$MemtableUnfilteredPartitionIterator of org.apache.cassandra.db.Memtable
  private StatsCollector = org.apache.cassandra.db.Memtable$StatsCollector of org.apache.cassandra.db.Memtable
  public LongToken = org.apache.cassandra.dht.Murmur3Partitioner$LongToken of org.apache.cassandra.dht.Murmur3Partitioner
  public KeyBound = org.apache.cassandra.dht.Token$KeyBound of org.apache.cassandra.dht.Token
  public final Barrier = org.apache.cassandra.utils.concurrent.OpOrder$Barrier of org.apache.cassandra.utils.concurrent.OpOrder
  public final Group = org.apache.cassandra.utils.concurrent.OpOrder$Group of org.apache.cassandra.utils.concurrent.OpOrder
  public final SubAllocator = org.apache.cassandra.utils.memory.MemtableAllocator$SubAllocator of org.apache.cassandra.utils.memory.MemtableAllocator