public class org.apache.cassandra.db.ColumnIndex
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.cassandra.db.ColumnIndex
super_class: java.lang.Object
{
private org.apache.cassandra.io.util.DataOutputBuffer buffer;
descriptor: Lorg/apache/cassandra/io/util/DataOutputBuffer;
flags: (0x0002) ACC_PRIVATE
private int indexSamplesSerializedSize;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private final java.util.List<org.apache.cassandra.io.sstable.IndexInfo> indexSamples;
descriptor: Ljava/util/List;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/List<Lorg/apache/cassandra/io/sstable/IndexInfo;>;
private org.apache.cassandra.io.util.DataOutputBuffer reusableBuffer;
descriptor: Lorg/apache/cassandra/io/util/DataOutputBuffer;
flags: (0x0002) ACC_PRIVATE
public int columnIndexCount;
descriptor: I
flags: (0x0001) ACC_PUBLIC
private int[] indexOffsets;
descriptor: [I
flags: (0x0002) ACC_PRIVATE
private final org.apache.cassandra.db.SerializationHeader header;
descriptor: Lorg/apache/cassandra/db/SerializationHeader;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final int version;
descriptor: I
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.apache.cassandra.io.util.SequentialWriter writer;
descriptor: Lorg/apache/cassandra/io/util/SequentialWriter;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private long initialPosition;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private final org.apache.cassandra.io.ISerializer<org.apache.cassandra.io.sstable.IndexInfo> idxSerializer;
descriptor: Lorg/apache/cassandra/io/ISerializer;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lorg/apache/cassandra/io/ISerializer<Lorg/apache/cassandra/io/sstable/IndexInfo;>;
public long headerLength;
descriptor: J
flags: (0x0001) ACC_PUBLIC
private long startPosition;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private int written;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private long previousRowStart;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private org.apache.cassandra.db.ClusteringPrefix firstClustering;
descriptor: Lorg/apache/cassandra/db/ClusteringPrefix;
flags: (0x0002) ACC_PRIVATE
private org.apache.cassandra.db.ClusteringPrefix lastClustering;
descriptor: Lorg/apache/cassandra/db/ClusteringPrefix;
flags: (0x0002) ACC_PRIVATE
private org.apache.cassandra.db.DeletionTime openMarker;
descriptor: Lorg/apache/cassandra/db/DeletionTime;
flags: (0x0002) ACC_PRIVATE
private final java.util.Collection<org.apache.cassandra.io.sstable.format.SSTableFlushObserver> observers;
descriptor: Ljava/util/Collection;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Collection<Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;>;
static final boolean $assertionsDisabled;
descriptor: Z
flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/apache/cassandra/db/ColumnIndex;
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.ColumnIndex.$assertionsDisabled:Z
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(org.apache.cassandra.db.SerializationHeader, org.apache.cassandra.io.util.SequentialWriter, org.apache.cassandra.io.sstable.format.Version, java.util.Collection<org.apache.cassandra.io.sstable.format.SSTableFlushObserver>, org.apache.cassandra.io.ISerializer<org.apache.cassandra.io.sstable.IndexInfo>);
descriptor: (Lorg/apache/cassandra/db/SerializationHeader;Lorg/apache/cassandra/io/util/SequentialWriter;Lorg/apache/cassandra/io/sstable/format/Version;Ljava/util/Collection;Lorg/apache/cassandra/io/ISerializer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
putfield org.apache.cassandra.db.ColumnIndex.indexSamples:Ljava/util/List;
2: aload 0
aload 1
putfield org.apache.cassandra.db.ColumnIndex.header:Lorg/apache/cassandra/db/SerializationHeader;
3: aload 0
aload 2
putfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
4: aload 0
aload 3
invokevirtual org.apache.cassandra.io.sstable.format.Version.correspondingMessagingVersion:()I
putfield org.apache.cassandra.db.ColumnIndex.version:I
5: aload 0
aload 4
putfield org.apache.cassandra.db.ColumnIndex.observers:Ljava/util/Collection;
6: aload 0
aload 5
putfield org.apache.cassandra.db.ColumnIndex.idxSerializer:Lorg/apache/cassandra/io/ISerializer;
7: return
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/apache/cassandra/db/ColumnIndex;
0 8 1 header Lorg/apache/cassandra/db/SerializationHeader;
0 8 2 writer Lorg/apache/cassandra/io/util/SequentialWriter;
0 8 3 version Lorg/apache/cassandra/io/sstable/format/Version;
0 8 4 observers Ljava/util/Collection<Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;>;
0 8 5 indexInfoSerializer Lorg/apache/cassandra/io/ISerializer<Lorg/apache/cassandra/io/sstable/IndexInfo;>;
Signature: (Lorg/apache/cassandra/db/SerializationHeader;Lorg/apache/cassandra/io/util/SequentialWriter;Lorg/apache/cassandra/io/sstable/format/Version;Ljava/util/Collection<Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;>;Lorg/apache/cassandra/io/ISerializer<Lorg/apache/cassandra/io/sstable/IndexInfo;>;)V
MethodParameters:
Name Flags
header
writer
version
observers
indexInfoSerializer
public void reset();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
aload 0
getfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
invokevirtual org.apache.cassandra.io.util.SequentialWriter.position:()J
putfield org.apache.cassandra.db.ColumnIndex.initialPosition:J
1: aload 0
ldc -1
putfield org.apache.cassandra.db.ColumnIndex.headerLength:J
2: aload 0
ldc -1
putfield org.apache.cassandra.db.ColumnIndex.startPosition:J
3: aload 0
lconst_0
putfield org.apache.cassandra.db.ColumnIndex.previousRowStart:J
4: aload 0
iconst_0
putfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
5: aload 0
iconst_0
putfield org.apache.cassandra.db.ColumnIndex.written:I
6: aload 0
iconst_0
putfield org.apache.cassandra.db.ColumnIndex.indexSamplesSerializedSize:I
7: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexSamples:Ljava/util/List;
invokeinterface java.util.List.clear:()V
8: aload 0
aconst_null
putfield org.apache.cassandra.db.ColumnIndex.firstClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
9: aload 0
aconst_null
putfield org.apache.cassandra.db.ColumnIndex.lastClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
10: aload 0
aconst_null
putfield org.apache.cassandra.db.ColumnIndex.openMarker:Lorg/apache/cassandra/db/DeletionTime;
11: aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
ifnull 13
12: aload 0
aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
putfield org.apache.cassandra.db.ColumnIndex.reusableBuffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
13: StackMap locals:
StackMap stack:
aload 0
aconst_null
putfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
14: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/apache/cassandra/db/ColumnIndex;
public void buildRowIndex(org.apache.cassandra.db.rows.UnfilteredRowIterator);
descriptor: (Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual org.apache.cassandra.db.ColumnIndex.writePartitionHeader:(Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;)V
1: aload 0
aload 0
getfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
invokevirtual org.apache.cassandra.io.util.SequentialWriter.position:()J
aload 0
getfield org.apache.cassandra.db.ColumnIndex.initialPosition:J
lsub
putfield org.apache.cassandra.db.ColumnIndex.headerLength:J
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
aload 1
invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.next:()Ljava/lang/Object;
checkcast org.apache.cassandra.db.rows.Unfiltered
invokevirtual org.apache.cassandra.db.ColumnIndex.add:(Lorg/apache/cassandra/db/rows/Unfiltered;)V
4: StackMap locals:
StackMap stack:
aload 1
invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.hasNext:()Z
ifne 3
5: aload 0
invokevirtual org.apache.cassandra.db.ColumnIndex.finish:()V
6: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/apache/cassandra/db/ColumnIndex;
0 7 1 iterator Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
iterator
private void writePartitionHeader(org.apache.cassandra.db.rows.UnfilteredRowIterator);
descriptor: (Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=3, args_size=2
start local 0 start local 1 0: aload 1
invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.partitionKey:()Lorg/apache/cassandra/db/DecoratedKey;
invokevirtual org.apache.cassandra.db.DecoratedKey.getKey:()Ljava/nio/ByteBuffer;
aload 0
getfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
invokestatic org.apache.cassandra.utils.ByteBufferUtil.writeWithShortLength:(Ljava/nio/ByteBuffer;Lorg/apache/cassandra/io/util/DataOutputPlus;)V
1: getstatic org.apache.cassandra.db.DeletionTime.serializer:Lorg/apache/cassandra/db/DeletionTime$Serializer;
aload 1
invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.partitionLevelDeletion:()Lorg/apache/cassandra/db/DeletionTime;
aload 0
getfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
invokevirtual org.apache.cassandra.db.DeletionTime$Serializer.serialize:(Lorg/apache/cassandra/db/DeletionTime;Lorg/apache/cassandra/io/util/DataOutputPlus;)V
2: aload 0
getfield org.apache.cassandra.db.ColumnIndex.header:Lorg/apache/cassandra/db/SerializationHeader;
invokevirtual org.apache.cassandra.db.SerializationHeader.hasStatic:()Z
ifeq 7
3: aload 1
invokeinterface org.apache.cassandra.db.rows.UnfilteredRowIterator.staticRow:()Lorg/apache/cassandra/db/rows/Row;
astore 2
start local 2 4: getstatic org.apache.cassandra.db.rows.UnfilteredSerializer.serializer:Lorg/apache/cassandra/db/rows/UnfilteredSerializer;
aload 2
aload 0
getfield org.apache.cassandra.db.ColumnIndex.header:Lorg/apache/cassandra/db/SerializationHeader;
aload 0
getfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
aload 0
getfield org.apache.cassandra.db.ColumnIndex.version:I
invokevirtual org.apache.cassandra.db.rows.UnfilteredSerializer.serializeStaticRow:(Lorg/apache/cassandra/db/rows/Row;Lorg/apache/cassandra/db/SerializationHeader;Lorg/apache/cassandra/io/util/DataOutputPlus;I)V
5: aload 0
getfield org.apache.cassandra.db.ColumnIndex.observers:Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 7
6: aload 0
getfield org.apache.cassandra.db.ColumnIndex.observers:Ljava/util/Collection;
aload 2
invokedynamic accept(Lorg/apache/cassandra/db/rows/Row;)Ljava/util/function/Consumer;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
(Ljava/lang/Object;)V
org/apache/cassandra/db/ColumnIndex.lambda$0(Lorg/apache/cassandra/db/rows/Row;Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;)V (6)
(Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;)V
invokeinterface java.util.Collection.forEach:(Ljava/util/function/Consumer;)V
end local 2 7: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/apache/cassandra/db/ColumnIndex;
0 8 1 iterator Lorg/apache/cassandra/db/rows/UnfilteredRowIterator;
4 7 2 staticRow Lorg/apache/cassandra/db/rows/Row;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
iterator
private long currentPosition();
descriptor: ()J
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
invokevirtual org.apache.cassandra.io.util.SequentialWriter.position:()J
aload 0
getfield org.apache.cassandra.db.ColumnIndex.initialPosition:J
lsub
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/db/ColumnIndex;
public java.nio.ByteBuffer buffer();
descriptor: ()Ljava/nio/ByteBuffer;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
ifnull 1
aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
invokevirtual org.apache.cassandra.io.util.DataOutputBuffer.buffer:()Ljava/nio/ByteBuffer;
goto 2
StackMap locals:
StackMap stack:
1: aconst_null
StackMap locals:
StackMap stack: java.nio.ByteBuffer
2: areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/cassandra/db/ColumnIndex;
public java.util.List<org.apache.cassandra.io.sstable.IndexInfo> indexSamples();
descriptor: ()Ljava/util/List;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexSamplesSerializedSize:I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
iconst_0
invokestatic org.apache.cassandra.db.TypeSizes.sizeof:(I)I
imul
iadd
invokestatic org.apache.cassandra.config.DatabaseDescriptor.getColumnIndexCacheSize:()I
if_icmpgt 2
1: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexSamples:Ljava/util/List;
areturn
2: StackMap locals:
StackMap stack:
aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/cassandra/db/ColumnIndex;
Signature: ()Ljava/util/List<Lorg/apache/cassandra/io/sstable/IndexInfo;>;
public int[] offsets();
descriptor: ()[I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
ifnull 2
1: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
invokestatic java.util.Arrays.copyOf:([II)[I
goto 3
2: StackMap locals:
StackMap stack:
aconst_null
3: StackMap locals:
StackMap stack: int[]
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/cassandra/db/ColumnIndex;
private void addIndexBlock();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=10, locals=4, args_size=1
start local 0 0: new org.apache.cassandra.io.sstable.IndexInfo
dup
aload 0
getfield org.apache.cassandra.db.ColumnIndex.firstClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
1: aload 0
getfield org.apache.cassandra.db.ColumnIndex.lastClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
2: aload 0
getfield org.apache.cassandra.db.ColumnIndex.startPosition:J
3: aload 0
invokevirtual org.apache.cassandra.db.ColumnIndex.currentPosition:()J
aload 0
getfield org.apache.cassandra.db.ColumnIndex.startPosition:J
lsub
4: aload 0
getfield org.apache.cassandra.db.ColumnIndex.openMarker:Lorg/apache/cassandra/db/DeletionTime;
5: invokespecial org.apache.cassandra.io.sstable.IndexInfo.<init>:(Lorg/apache/cassandra/db/ClusteringPrefix;Lorg/apache/cassandra/db/ClusteringPrefix;JJLorg/apache/cassandra/db/DeletionTime;)V
astore 1
start local 1 6: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
ifnonnull 8
7: aload 0
bipush 10
newarray 10
putfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
goto 18
8: StackMap locals: org.apache.cassandra.io.sstable.IndexInfo
StackMap stack:
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
arraylength
if_icmplt 10
9: aload 0
aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
arraylength
bipush 10
iadd
invokestatic java.util.Arrays.copyOf:([II)[I
putfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
10: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
ifne 13
11: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
iconst_0
iastore
12: goto 18
13: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
14: aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
ifnull 16
15: aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
invokevirtual org.apache.cassandra.io.util.DataOutputBuffer.position:()J
invokestatic com.google.common.primitives.Ints.checkedCast:(J)I
goto 17
16: StackMap locals: org.apache.cassandra.db.ColumnIndex org.apache.cassandra.io.sstable.IndexInfo
StackMap stack: int[] int
aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexSamplesSerializedSize:I
17: StackMap locals: org.apache.cassandra.db.ColumnIndex org.apache.cassandra.io.sstable.IndexInfo
StackMap stack: int[] int int
iastore
18: StackMap locals:
StackMap stack:
aload 0
dup
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
iconst_1
iadd
putfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
19: aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
ifnonnull 29
20: aload 0
dup
getfield org.apache.cassandra.db.ColumnIndex.indexSamplesSerializedSize:I
i2l
aload 0
getfield org.apache.cassandra.db.ColumnIndex.idxSerializer:Lorg/apache/cassandra/io/ISerializer;
aload 1
invokeinterface org.apache.cassandra.io.ISerializer.serializedSize:(Ljava/lang/Object;)J
ladd
l2i
putfield org.apache.cassandra.db.ColumnIndex.indexSamplesSerializedSize:I
21: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexSamplesSerializedSize:I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
iconst_0
invokestatic org.apache.cassandra.db.TypeSizes.sizeof:(I)I
imul
iadd
invokestatic org.apache.cassandra.config.DatabaseDescriptor.getColumnIndexCacheSize:()I
if_icmple 28
22: aload 0
aload 0
invokevirtual org.apache.cassandra.db.ColumnIndex.reuseOrAllocateBuffer:()Lorg/apache/cassandra/io/util/DataOutputBuffer;
putfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
23: aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexSamples:Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 3
goto 26
StackMap locals: org.apache.cassandra.db.ColumnIndex org.apache.cassandra.io.sstable.IndexInfo top java.util.Iterator
StackMap stack:
24: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.apache.cassandra.io.sstable.IndexInfo
astore 2
start local 2 25: aload 0
getfield org.apache.cassandra.db.ColumnIndex.idxSerializer:Lorg/apache/cassandra/io/ISerializer;
aload 2
aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
invokeinterface org.apache.cassandra.io.ISerializer.serialize:(Ljava/lang/Object;Lorg/apache/cassandra/io/util/DataOutputPlus;)V
end local 2 26: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 24
27: goto 29
28: StackMap locals: org.apache.cassandra.db.ColumnIndex org.apache.cassandra.io.sstable.IndexInfo
StackMap stack:
aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexSamples:Ljava/util/List;
aload 1
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
29: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
ifnull 31
30: aload 0
getfield org.apache.cassandra.db.ColumnIndex.idxSerializer:Lorg/apache/cassandra/io/ISerializer;
aload 1
aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
invokeinterface org.apache.cassandra.io.ISerializer.serialize:(Ljava/lang/Object;Lorg/apache/cassandra/io/util/DataOutputPlus;)V
31: StackMap locals:
StackMap stack:
aload 0
aconst_null
putfield org.apache.cassandra.db.ColumnIndex.firstClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
32: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 33 0 this Lorg/apache/cassandra/db/ColumnIndex;
6 33 1 cIndexInfo Lorg/apache/cassandra/io/sstable/IndexInfo;
25 26 2 indexSample Lorg/apache/cassandra/io/sstable/IndexInfo;
Exceptions:
throws java.io.IOException
private org.apache.cassandra.io.util.DataOutputBuffer reuseOrAllocateBuffer();
descriptor: ()Lorg/apache/cassandra/io/util/DataOutputBuffer;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=2, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.db.ColumnIndex.reusableBuffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
ifnull 4
1: aload 0
getfield org.apache.cassandra.db.ColumnIndex.reusableBuffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
astore 1
start local 1 2: aload 1
invokevirtual org.apache.cassandra.io.util.DataOutputBuffer.clear:()V
3: aload 1
areturn
end local 1 4: StackMap locals:
StackMap stack:
new org.apache.cassandra.io.util.DataOutputBuffer
dup
invokestatic org.apache.cassandra.config.DatabaseDescriptor.getColumnIndexCacheSize:()I
iconst_2
imul
invokespecial org.apache.cassandra.io.util.DataOutputBuffer.<init>:(I)V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/apache/cassandra/db/ColumnIndex;
2 4 1 buffer Lorg/apache/cassandra/io/util/DataOutputBuffer;
private void add(org.apache.cassandra.db.rows.Unfiltered);
descriptor: (Lorg/apache/cassandra/db/rows/Unfiltered;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=8, locals=5, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.apache.cassandra.db.ColumnIndex.currentPosition:()J
lstore 2
start local 2 1: aload 0
getfield org.apache.cassandra.db.ColumnIndex.firstClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
ifnonnull 4
2: aload 0
aload 1
invokeinterface org.apache.cassandra.db.rows.Unfiltered.clustering:()Lorg/apache/cassandra/db/ClusteringPrefix;
putfield org.apache.cassandra.db.ColumnIndex.firstClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
3: aload 0
lload 2
putfield org.apache.cassandra.db.ColumnIndex.startPosition:J
4: StackMap locals: long
StackMap stack:
getstatic org.apache.cassandra.db.rows.UnfilteredSerializer.serializer:Lorg/apache/cassandra/db/rows/UnfilteredSerializer;
aload 1
aload 0
getfield org.apache.cassandra.db.ColumnIndex.header:Lorg/apache/cassandra/db/SerializationHeader;
aload 0
getfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
lload 2
aload 0
getfield org.apache.cassandra.db.ColumnIndex.previousRowStart:J
lsub
aload 0
getfield org.apache.cassandra.db.ColumnIndex.version:I
invokevirtual org.apache.cassandra.db.rows.UnfilteredSerializer.serialize:(Lorg/apache/cassandra/db/rows/Unfiltered;Lorg/apache/cassandra/db/SerializationHeader;Lorg/apache/cassandra/io/util/DataOutputPlus;JI)V
5: aload 0
getfield org.apache.cassandra.db.ColumnIndex.observers:Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 7
6: aload 0
getfield org.apache.cassandra.db.ColumnIndex.observers:Ljava/util/Collection;
aload 1
invokedynamic accept(Lorg/apache/cassandra/db/rows/Unfiltered;)Ljava/util/function/Consumer;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
(Ljava/lang/Object;)V
org/apache/cassandra/db/ColumnIndex.lambda$1(Lorg/apache/cassandra/db/rows/Unfiltered;Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;)V (6)
(Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;)V
invokeinterface java.util.Collection.forEach:(Ljava/util/function/Consumer;)V
7: StackMap locals:
StackMap stack:
aload 0
aload 1
invokeinterface org.apache.cassandra.db.rows.Unfiltered.clustering:()Lorg/apache/cassandra/db/ClusteringPrefix;
putfield org.apache.cassandra.db.ColumnIndex.lastClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
8: aload 0
lload 2
putfield org.apache.cassandra.db.ColumnIndex.previousRowStart:J
9: aload 0
dup
getfield org.apache.cassandra.db.ColumnIndex.written:I
iconst_1
iadd
putfield org.apache.cassandra.db.ColumnIndex.written:I
10: aload 1
invokeinterface org.apache.cassandra.db.rows.Unfiltered.kind:()Lorg/apache/cassandra/db/rows/Unfiltered$Kind;
getstatic org.apache.cassandra.db.rows.Unfiltered$Kind.RANGE_TOMBSTONE_MARKER:Lorg/apache/cassandra/db/rows/Unfiltered$Kind;
if_acmpne 15
11: aload 1
checkcast org.apache.cassandra.db.rows.RangeTombstoneMarker
astore 4
start local 4 12: aload 0
aload 4
iconst_0
invokeinterface org.apache.cassandra.db.rows.RangeTombstoneMarker.isOpen:(Z)Z
ifeq 13
aload 4
iconst_0
invokeinterface org.apache.cassandra.db.rows.RangeTombstoneMarker.openDeletionTime:(Z)Lorg/apache/cassandra/db/DeletionTime;
goto 14
StackMap locals: org.apache.cassandra.db.ColumnIndex org.apache.cassandra.db.rows.Unfiltered long org.apache.cassandra.db.rows.RangeTombstoneMarker
StackMap stack: org.apache.cassandra.db.ColumnIndex
13: aconst_null
StackMap locals: org.apache.cassandra.db.ColumnIndex org.apache.cassandra.db.rows.Unfiltered long org.apache.cassandra.db.rows.RangeTombstoneMarker
StackMap stack: org.apache.cassandra.db.ColumnIndex org.apache.cassandra.db.DeletionTime
14: putfield org.apache.cassandra.db.ColumnIndex.openMarker:Lorg/apache/cassandra/db/DeletionTime;
end local 4 15: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.apache.cassandra.db.ColumnIndex.currentPosition:()J
aload 0
getfield org.apache.cassandra.db.ColumnIndex.startPosition:J
lsub
invokestatic org.apache.cassandra.config.DatabaseDescriptor.getColumnIndexSize:()I
i2l
lcmp
iflt 17
16: aload 0
invokevirtual org.apache.cassandra.db.ColumnIndex.addIndexBlock:()V
17: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Lorg/apache/cassandra/db/ColumnIndex;
0 18 1 unfiltered Lorg/apache/cassandra/db/rows/Unfiltered;
1 18 2 pos J
12 15 4 marker Lorg/apache/cassandra/db/rows/RangeTombstoneMarker;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
unfiltered
private void finish();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=1, args_size=1
start local 0 0: getstatic org.apache.cassandra.db.rows.UnfilteredSerializer.serializer:Lorg/apache/cassandra/db/rows/UnfilteredSerializer;
aload 0
getfield org.apache.cassandra.db.ColumnIndex.writer:Lorg/apache/cassandra/io/util/SequentialWriter;
invokevirtual org.apache.cassandra.db.rows.UnfilteredSerializer.writeEndOfPartition:(Lorg/apache/cassandra/io/util/DataOutputPlus;)V
1: aload 0
getfield org.apache.cassandra.db.ColumnIndex.written:I
ifne 3
2: return
3: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.db.ColumnIndex.firstClustering:Lorg/apache/cassandra/db/ClusteringPrefix;
ifnull 5
4: aload 0
invokevirtual org.apache.cassandra.db.ColumnIndex.addIndexBlock:()V
5: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
ifnull 7
6: aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexOffsets:[I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
invokestatic org.apache.cassandra.db.RowIndexEntry$Serializer.serializeOffsets:(Lorg/apache/cassandra/io/util/DataOutputBuffer;[II)V
7: StackMap locals:
StackMap stack:
getstatic org.apache.cassandra.db.ColumnIndex.$assertionsDisabled:Z
ifne 9
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
ifle 8
aload 0
getfield org.apache.cassandra.db.ColumnIndex.headerLength:J
lconst_0
lcmp
ifge 9
StackMap locals:
StackMap stack:
8: new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
9: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/apache/cassandra/db/ColumnIndex;
Exceptions:
throws java.io.IOException
public int indexInfoSerializedSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
ifnull 2
1: aload 0
getfield org.apache.cassandra.db.ColumnIndex.buffer:Lorg/apache/cassandra/io/util/DataOutputBuffer;
invokevirtual org.apache.cassandra.io.util.DataOutputBuffer.buffer:()Ljava/nio/ByteBuffer;
invokevirtual java.nio.ByteBuffer.limit:()I
goto 3
2: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.db.ColumnIndex.indexSamplesSerializedSize:I
aload 0
getfield org.apache.cassandra.db.ColumnIndex.columnIndexCount:I
iconst_0
invokestatic org.apache.cassandra.db.TypeSizes.sizeof:(I)I
imul
iadd
3: StackMap locals:
StackMap stack: int
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/cassandra/db/ColumnIndex;
private static void lambda$0(org.apache.cassandra.db.rows.Row, org.apache.cassandra.io.sstable.format.SSTableFlushObserver);
descriptor: (Lorg/apache/cassandra/db/rows/Row;Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;)V
flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
Code:
stack=2, locals=2, args_size=2
start local 1 0: aload 1
aload 0
invokeinterface org.apache.cassandra.io.sstable.format.SSTableFlushObserver.nextUnfilteredCluster:(Lorg/apache/cassandra/db/rows/Unfiltered;)V
return
end local 1 LocalVariableTable:
Start End Slot Name Signature
0 1 1 o Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;
private static void lambda$1(org.apache.cassandra.db.rows.Unfiltered, org.apache.cassandra.io.sstable.format.SSTableFlushObserver);
descriptor: (Lorg/apache/cassandra/db/rows/Unfiltered;Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;)V
flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
Code:
stack=2, locals=2, args_size=2
start local 1 0: aload 1
aload 0
invokeinterface org.apache.cassandra.io.sstable.format.SSTableFlushObserver.nextUnfilteredCluster:(Lorg/apache/cassandra/db/rows/Unfiltered;)V
return
end local 1 LocalVariableTable:
Start End Slot Name Signature
0 1 1 o Lorg/apache/cassandra/io/sstable/format/SSTableFlushObserver;
}
SourceFile: "ColumnIndex.java"
InnerClasses:
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
public Serializer = org.apache.cassandra.db.DeletionTime$Serializer of org.apache.cassandra.db.DeletionTime
public final Serializer = org.apache.cassandra.db.RowIndexEntry$Serializer of org.apache.cassandra.db.RowIndexEntry
public final Kind = org.apache.cassandra.db.rows.Unfiltered$Kind of org.apache.cassandra.db.rows.Unfiltered