public class org.apache.cassandra.index.internal.composites.ClusteringColumnIndex extends org.apache.cassandra.index.internal.CassandraIndex
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.index.internal.composites.ClusteringColumnIndex
  super_class: org.apache.cassandra.index.internal.CassandraIndex
{
  private final boolean enforceStrictLiveness;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>(org.apache.cassandra.db.ColumnFamilyStore, org.apache.cassandra.schema.IndexMetadata);
    descriptor: (Lorg/apache/cassandra/db/ColumnFamilyStore;Lorg/apache/cassandra/schema/IndexMetadata;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
        start local 1 // org.apache.cassandra.db.ColumnFamilyStore baseCfs
        start local 2 // org.apache.cassandra.schema.IndexMetadata indexDef
         0: .line 54
            aload 0 /* this */
            aload 1 /* baseCfs */
            aload 2 /* indexDef */
            invokespecial org.apache.cassandra.index.internal.CassandraIndex.<init>:(Lorg/apache/cassandra/db/ColumnFamilyStore;Lorg/apache/cassandra/schema/IndexMetadata;)V
         1: .line 55
            aload 0 /* this */
            aload 1 /* baseCfs */
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
            invokevirtual org.apache.cassandra.config.CFMetaData.enforceStrictLiveness:()Z
            putfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.enforceStrictLiveness:Z
         2: .line 56
            return
        end local 2 // org.apache.cassandra.schema.IndexMetadata indexDef
        end local 1 // org.apache.cassandra.db.ColumnFamilyStore baseCfs
        end local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lorg/apache/cassandra/index/internal/composites/ClusteringColumnIndex;
            0    3     1   baseCfs  Lorg/apache/cassandra/db/ColumnFamilyStore;
            0    3     2  indexDef  Lorg/apache/cassandra/schema/IndexMetadata;
    MethodParameters:
          Name  Flags
      baseCfs   
      indexDef  

  public java.nio.ByteBuffer getIndexedValue(java.nio.ByteBuffer, org.apache.cassandra.db.Clustering, org.apache.cassandra.db.rows.CellPath, java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;Lorg/apache/cassandra/db/Clustering;Lorg/apache/cassandra/db/rows/CellPath;Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=5
        start local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
        start local 1 // java.nio.ByteBuffer partitionKey
        start local 2 // org.apache.cassandra.db.Clustering clustering
        start local 3 // org.apache.cassandra.db.rows.CellPath path
        start local 4 // java.nio.ByteBuffer cellValue
         0: .line 63
            aload 2 /* clustering */
            aload 0 /* this */
            getfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.indexedColumn:Lorg/apache/cassandra/config/ColumnDefinition;
            invokevirtual org.apache.cassandra.config.ColumnDefinition.position:()I
            invokeinterface org.apache.cassandra.db.Clustering.get:(I)Ljava/nio/ByteBuffer;
            areturn
        end local 4 // java.nio.ByteBuffer cellValue
        end local 3 // org.apache.cassandra.db.rows.CellPath path
        end local 2 // org.apache.cassandra.db.Clustering clustering
        end local 1 // java.nio.ByteBuffer partitionKey
        end local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0          this  Lorg/apache/cassandra/index/internal/composites/ClusteringColumnIndex;
            0    1     1  partitionKey  Ljava/nio/ByteBuffer;
            0    1     2    clustering  Lorg/apache/cassandra/db/Clustering;
            0    1     3          path  Lorg/apache/cassandra/db/rows/CellPath;
            0    1     4     cellValue  Ljava/nio/ByteBuffer;
    MethodParameters:
              Name  Flags
      partitionKey  
      clustering    
      path          
      cellValue     

  public org.apache.cassandra.db.CBuilder buildIndexClusteringPrefix(java.nio.ByteBuffer, org.apache.cassandra.db.ClusteringPrefix, org.apache.cassandra.db.rows.CellPath);
    descriptor: (Ljava/nio/ByteBuffer;Lorg/apache/cassandra/db/ClusteringPrefix;Lorg/apache/cassandra/db/rows/CellPath;)Lorg/apache/cassandra/db/CBuilder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=4
        start local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
        start local 1 // java.nio.ByteBuffer partitionKey
        start local 2 // org.apache.cassandra.db.ClusteringPrefix prefix
        start local 3 // org.apache.cassandra.db.rows.CellPath path
         0: .line 70
            aload 0 /* this */
            invokevirtual org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.getIndexComparator:()Lorg/apache/cassandra/db/ClusteringComparator;
            invokestatic org.apache.cassandra.db.CBuilder.create:(Lorg/apache/cassandra/db/ClusteringComparator;)Lorg/apache/cassandra/db/CBuilder;
            astore 4 /* builder */
        start local 4 // org.apache.cassandra.db.CBuilder builder
         1: .line 71
            aload 4 /* builder */
            aload 1 /* partitionKey */
            invokevirtual org.apache.cassandra.db.CBuilder.add:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/CBuilder;
            pop
         2: .line 72
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         3: goto 6
         4: .line 73
      StackMap locals: org.apache.cassandra.db.CBuilder int
      StackMap stack:
            aload 4 /* builder */
            aload 2 /* prefix */
            iload 5 /* i */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.get:(I)Ljava/nio/ByteBuffer;
            invokevirtual org.apache.cassandra.db.CBuilder.add:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/CBuilder;
            pop
         5: .line 72
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 5 /* i */
            aload 0 /* this */
            getfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.indexedColumn:Lorg/apache/cassandra/config/ColumnDefinition;
            invokevirtual org.apache.cassandra.config.ColumnDefinition.position:()I
            aload 2 /* prefix */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.size:()I
            invokestatic java.lang.Math.min:(II)I
            if_icmplt 4
        end local 5 // int i
         7: .line 74
            aload 0 /* this */
            getfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.indexedColumn:Lorg/apache/cassandra/config/ColumnDefinition;
            invokevirtual org.apache.cassandra.config.ColumnDefinition.position:()I
            iconst_1
            iadd
            istore 5 /* i */
        start local 5 // int i
         8: goto 11
         9: .line 75
      StackMap locals:
      StackMap stack:
            aload 4 /* builder */
            aload 2 /* prefix */
            iload 5 /* i */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.get:(I)Ljava/nio/ByteBuffer;
            invokevirtual org.apache.cassandra.db.CBuilder.add:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/CBuilder;
            pop
        10: .line 74
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
        11: iload 5 /* i */
            aload 2 /* prefix */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.size:()I
            if_icmplt 9
        end local 5 // int i
        12: .line 76
            aload 4 /* builder */
            areturn
        end local 4 // org.apache.cassandra.db.CBuilder builder
        end local 3 // org.apache.cassandra.db.rows.CellPath path
        end local 2 // org.apache.cassandra.db.ClusteringPrefix prefix
        end local 1 // java.nio.ByteBuffer partitionKey
        end local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   13     0          this  Lorg/apache/cassandra/index/internal/composites/ClusteringColumnIndex;
            0   13     1  partitionKey  Ljava/nio/ByteBuffer;
            0   13     2        prefix  Lorg/apache/cassandra/db/ClusteringPrefix;
            0   13     3          path  Lorg/apache/cassandra/db/rows/CellPath;
            1   13     4       builder  Lorg/apache/cassandra/db/CBuilder;
            3    7     5             i  I
            8   12     5             i  I
    MethodParameters:
              Name  Flags
      partitionKey  
      prefix        
      path          

  public org.apache.cassandra.index.internal.IndexEntry decodeEntry(org.apache.cassandra.db.DecoratedKey, org.apache.cassandra.db.rows.Row);
    descriptor: (Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/rows/Row;)Lorg/apache/cassandra/index/internal/IndexEntry;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=7, args_size=3
        start local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
        start local 1 // org.apache.cassandra.db.DecoratedKey indexedValue
        start local 2 // org.apache.cassandra.db.rows.Row indexEntry
         0: .line 82
            aload 0 /* this */
            getfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.baseCfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            getfield org.apache.cassandra.db.ColumnFamilyStore.metadata:Lorg/apache/cassandra/config/CFMetaData;
            invokevirtual org.apache.cassandra.config.CFMetaData.clusteringColumns:()Ljava/util/List;
            invokeinterface java.util.List.size:()I
            istore 3 /* ckCount */
        start local 3 // int ckCount
         1: .line 84
            aload 2 /* indexEntry */
            invokeinterface org.apache.cassandra.db.rows.Row.clustering:()Lorg/apache/cassandra/db/Clustering;
            astore 4 /* clustering */
        start local 4 // org.apache.cassandra.db.Clustering clustering
         2: .line 85
            aload 0 /* this */
            getfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.baseCfs:Lorg/apache/cassandra/db/ColumnFamilyStore;
            invokevirtual org.apache.cassandra.db.ColumnFamilyStore.getComparator:()Lorg/apache/cassandra/db/ClusteringComparator;
            invokestatic org.apache.cassandra.db.CBuilder.create:(Lorg/apache/cassandra/db/ClusteringComparator;)Lorg/apache/cassandra/db/CBuilder;
            astore 5 /* builder */
        start local 5 // org.apache.cassandra.db.CBuilder builder
         3: .line 86
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         4: goto 7
         5: .line 87
      StackMap locals: org.apache.cassandra.index.internal.composites.ClusteringColumnIndex org.apache.cassandra.db.DecoratedKey org.apache.cassandra.db.rows.Row int org.apache.cassandra.db.Clustering org.apache.cassandra.db.CBuilder int
      StackMap stack:
            aload 5 /* builder */
            aload 4 /* clustering */
            iload 6 /* i */
            iconst_1
            iadd
            invokeinterface org.apache.cassandra.db.Clustering.get:(I)Ljava/nio/ByteBuffer;
            invokevirtual org.apache.cassandra.db.CBuilder.add:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/CBuilder;
            pop
         6: .line 86
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
         7: iload 6 /* i */
            aload 0 /* this */
            getfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.indexedColumn:Lorg/apache/cassandra/config/ColumnDefinition;
            invokevirtual org.apache.cassandra.config.ColumnDefinition.position:()I
            if_icmplt 5
        end local 6 // int i
         8: .line 89
            aload 5 /* builder */
            aload 1 /* indexedValue */
            invokevirtual org.apache.cassandra.db.DecoratedKey.getKey:()Ljava/nio/ByteBuffer;
            invokevirtual org.apache.cassandra.db.CBuilder.add:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/CBuilder;
            pop
         9: .line 91
            aload 0 /* this */
            getfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.indexedColumn:Lorg/apache/cassandra/config/ColumnDefinition;
            invokevirtual org.apache.cassandra.config.ColumnDefinition.position:()I
            iconst_1
            iadd
            istore 6 /* i */
        start local 6 // int i
        10: goto 13
        11: .line 92
      StackMap locals:
      StackMap stack:
            aload 5 /* builder */
            aload 4 /* clustering */
            iload 6 /* i */
            invokeinterface org.apache.cassandra.db.Clustering.get:(I)Ljava/nio/ByteBuffer;
            invokevirtual org.apache.cassandra.db.CBuilder.add:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/CBuilder;
            pop
        12: .line 91
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 6 /* i */
            iload 3 /* ckCount */
            if_icmplt 11
        end local 6 // int i
        14: .line 94
            new org.apache.cassandra.index.internal.IndexEntry
            dup
            aload 1 /* indexedValue */
        15: .line 95
            aload 4 /* clustering */
        16: .line 96
            aload 2 /* indexEntry */
            invokeinterface org.apache.cassandra.db.rows.Row.primaryKeyLivenessInfo:()Lorg/apache/cassandra/db/LivenessInfo;
            invokevirtual org.apache.cassandra.db.LivenessInfo.timestamp:()J
        17: .line 97
            aload 4 /* clustering */
            iconst_0
            invokeinterface org.apache.cassandra.db.Clustering.get:(I)Ljava/nio/ByteBuffer;
        18: .line 98
            aload 5 /* builder */
            invokevirtual org.apache.cassandra.db.CBuilder.build:()Lorg/apache/cassandra/db/Clustering;
        19: .line 94
            invokespecial org.apache.cassandra.index.internal.IndexEntry.<init>:(Lorg/apache/cassandra/db/DecoratedKey;Lorg/apache/cassandra/db/Clustering;JLjava/nio/ByteBuffer;Lorg/apache/cassandra/db/Clustering;)V
            areturn
        end local 5 // org.apache.cassandra.db.CBuilder builder
        end local 4 // org.apache.cassandra.db.Clustering clustering
        end local 3 // int ckCount
        end local 2 // org.apache.cassandra.db.rows.Row indexEntry
        end local 1 // org.apache.cassandra.db.DecoratedKey indexedValue
        end local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   20     0          this  Lorg/apache/cassandra/index/internal/composites/ClusteringColumnIndex;
            0   20     1  indexedValue  Lorg/apache/cassandra/db/DecoratedKey;
            0   20     2    indexEntry  Lorg/apache/cassandra/db/rows/Row;
            1   20     3       ckCount  I
            2   20     4    clustering  Lorg/apache/cassandra/db/Clustering;
            3   20     5       builder  Lorg/apache/cassandra/db/CBuilder;
            4    8     6             i  I
           10   14     6             i  I
    MethodParameters:
              Name  Flags
      indexedValue  
      indexEntry    

  public boolean isStale(org.apache.cassandra.db.rows.Row, java.nio.ByteBuffer, int);
    descriptor: (Lorg/apache/cassandra/db/rows/Row;Ljava/nio/ByteBuffer;I)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
        start local 1 // org.apache.cassandra.db.rows.Row data
        start local 2 // java.nio.ByteBuffer indexValue
        start local 3 // int nowInSec
         0: .line 103
            aload 1 /* data */
            iload 3 /* nowInSec */
            aload 0 /* this */
            getfield org.apache.cassandra.index.internal.composites.ClusteringColumnIndex.enforceStrictLiveness:Z
            invokeinterface org.apache.cassandra.db.rows.Row.hasLiveData:(IZ)Z
            ifeq 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_1
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 3 // int nowInSec
        end local 2 // java.nio.ByteBuffer indexValue
        end local 1 // org.apache.cassandra.db.rows.Row data
        end local 0 // org.apache.cassandra.index.internal.composites.ClusteringColumnIndex this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Lorg/apache/cassandra/index/internal/composites/ClusteringColumnIndex;
            0    3     1        data  Lorg/apache/cassandra/db/rows/Row;
            0    3     2  indexValue  Ljava/nio/ByteBuffer;
            0    3     3    nowInSec  I
    MethodParameters:
            Name  Flags
      data        
      indexValue  
      nowInSec    
}
SourceFile: "ClusteringColumnIndex.java"