public class org.apache.cassandra.db.ClusteringPrefix$Serializer
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.db.ClusteringPrefix$Serializer
  super_class: java.lang.Object
{
  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 251
            ldc Lorg/apache/cassandra/db/ClusteringPrefix;
            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.ClusteringPrefix$Serializer.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
         0: .line 251
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;

  public void serialize(org.apache.cassandra.db.ClusteringPrefix, org.apache.cassandra.io.util.DataOutputPlus, int, java.util.List<org.apache.cassandra.db.marshal.AbstractType<?>>);
    descriptor: (Lorg/apache/cassandra/db/ClusteringPrefix;Lorg/apache/cassandra/io/util/DataOutputPlus;ILjava/util/List;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=5
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
        start local 1 // org.apache.cassandra.db.ClusteringPrefix clustering
        start local 2 // org.apache.cassandra.io.util.DataOutputPlus out
        start local 3 // int version
        start local 4 // java.util.List types
         0: .line 256
            getstatic org.apache.cassandra.db.ClusteringPrefix$Serializer.$assertionsDisabled:Z
            ifne 1
            aload 1 /* clustering */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.kind:()Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            getstatic org.apache.cassandra.db.ClusteringPrefix$Kind.STATIC_CLUSTERING:Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            if_acmpne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 257
      StackMap locals:
      StackMap stack:
            aload 1 /* clustering */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.kind:()Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            getstatic org.apache.cassandra.db.ClusteringPrefix$Kind.CLUSTERING:Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            if_acmpne 5
         2: .line 259
            aload 2 /* out */
            aload 1 /* clustering */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.kind:()Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            invokevirtual org.apache.cassandra.db.ClusteringPrefix$Kind.ordinal:()I
            invokeinterface org.apache.cassandra.io.util.DataOutputPlus.writeByte:(I)V
         3: .line 260
            getstatic org.apache.cassandra.db.Clustering.serializer:Lorg/apache/cassandra/db/Clustering$Serializer;
            aload 1 /* clustering */
            checkcast org.apache.cassandra.db.Clustering
            aload 2 /* out */
            iload 3 /* version */
            aload 4 /* types */
            invokevirtual org.apache.cassandra.db.Clustering$Serializer.serialize:(Lorg/apache/cassandra/db/Clustering;Lorg/apache/cassandra/io/util/DataOutputPlus;ILjava/util/List;)V
         4: .line 261
            goto 6
         5: .line 264
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.db.ClusteringBoundOrBoundary.serializer:Lorg/apache/cassandra/db/ClusteringBoundOrBoundary$Serializer;
            aload 1 /* clustering */
            checkcast org.apache.cassandra.db.ClusteringBoundOrBoundary
            aload 2 /* out */
            iload 3 /* version */
            aload 4 /* types */
            invokevirtual org.apache.cassandra.db.ClusteringBoundOrBoundary$Serializer.serialize:(Lorg/apache/cassandra/db/ClusteringBoundOrBoundary;Lorg/apache/cassandra/io/util/DataOutputPlus;ILjava/util/List;)V
         6: .line 266
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.util.List types
        end local 3 // int version
        end local 2 // org.apache.cassandra.io.util.DataOutputPlus out
        end local 1 // org.apache.cassandra.db.ClusteringPrefix clustering
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    7     0        this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;
            0    7     1  clustering  Lorg/apache/cassandra/db/ClusteringPrefix;
            0    7     2         out  Lorg/apache/cassandra/io/util/DataOutputPlus;
            0    7     3     version  I
            0    7     4       types  Ljava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/apache/cassandra/db/ClusteringPrefix;Lorg/apache/cassandra/io/util/DataOutputPlus;ILjava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;)V
    MethodParameters:
            Name  Flags
      clustering  
      out         
      version     
      types       

  public void skip(org.apache.cassandra.io.util.DataInputPlus, int, java.util.List<org.apache.cassandra.db.marshal.AbstractType<?>>);
    descriptor: (Lorg/apache/cassandra/io/util/DataInputPlus;ILjava/util/List;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
        start local 1 // org.apache.cassandra.io.util.DataInputPlus in
        start local 2 // int version
        start local 3 // java.util.List types
         0: .line 270
            invokestatic org.apache.cassandra.db.ClusteringPrefix$Kind.values:()[Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            aload 1 /* in */
            invokeinterface org.apache.cassandra.io.util.DataInputPlus.readByte:()B
            aaload
            astore 4 /* kind */
        start local 4 // org.apache.cassandra.db.ClusteringPrefix$Kind kind
         1: .line 272
            getstatic org.apache.cassandra.db.ClusteringPrefix$Serializer.$assertionsDisabled:Z
            ifne 2
            aload 4 /* kind */
            getstatic org.apache.cassandra.db.ClusteringPrefix$Kind.STATIC_CLUSTERING:Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            if_acmpne 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 273
      StackMap locals: org.apache.cassandra.db.ClusteringPrefix$Kind
      StackMap stack:
            aload 4 /* kind */
            getstatic org.apache.cassandra.db.ClusteringPrefix$Kind.CLUSTERING:Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            if_acmpne 4
         3: .line 274
            getstatic org.apache.cassandra.db.Clustering.serializer:Lorg/apache/cassandra/db/Clustering$Serializer;
            aload 1 /* in */
            iload 2 /* version */
            aload 3 /* types */
            invokevirtual org.apache.cassandra.db.Clustering$Serializer.skip:(Lorg/apache/cassandra/io/util/DataInputPlus;ILjava/util/List;)V
            goto 5
         4: .line 276
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.db.ClusteringBoundOrBoundary.serializer:Lorg/apache/cassandra/db/ClusteringBoundOrBoundary$Serializer;
            aload 1 /* in */
            aload 4 /* kind */
            iload 2 /* version */
            aload 3 /* types */
            invokevirtual org.apache.cassandra.db.ClusteringBoundOrBoundary$Serializer.skipValues:(Lorg/apache/cassandra/io/util/DataInputPlus;Lorg/apache/cassandra/db/ClusteringPrefix$Kind;ILjava/util/List;)V
         5: .line 277
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.apache.cassandra.db.ClusteringPrefix$Kind kind
        end local 3 // java.util.List types
        end local 2 // int version
        end local 1 // org.apache.cassandra.io.util.DataInputPlus in
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0     this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;
            0    6     1       in  Lorg/apache/cassandra/io/util/DataInputPlus;
            0    6     2  version  I
            0    6     3    types  Ljava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;
            1    6     4     kind  Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/apache/cassandra/io/util/DataInputPlus;ILjava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;)V
    MethodParameters:
         Name  Flags
      in       
      version  
      types    

  public org.apache.cassandra.db.ClusteringPrefix deserialize(org.apache.cassandra.io.util.DataInputPlus, int, java.util.List<org.apache.cassandra.db.marshal.AbstractType<?>>);
    descriptor: (Lorg/apache/cassandra/io/util/DataInputPlus;ILjava/util/List;)Lorg/apache/cassandra/db/ClusteringPrefix;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
        start local 1 // org.apache.cassandra.io.util.DataInputPlus in
        start local 2 // int version
        start local 3 // java.util.List types
         0: .line 281
            invokestatic org.apache.cassandra.db.ClusteringPrefix$Kind.values:()[Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            aload 1 /* in */
            invokeinterface org.apache.cassandra.io.util.DataInputPlus.readByte:()B
            aaload
            astore 4 /* kind */
        start local 4 // org.apache.cassandra.db.ClusteringPrefix$Kind kind
         1: .line 283
            getstatic org.apache.cassandra.db.ClusteringPrefix$Serializer.$assertionsDisabled:Z
            ifne 2
            aload 4 /* kind */
            getstatic org.apache.cassandra.db.ClusteringPrefix$Kind.STATIC_CLUSTERING:Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            if_acmpne 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 284
      StackMap locals: org.apache.cassandra.db.ClusteringPrefix$Kind
      StackMap stack:
            aload 4 /* kind */
            getstatic org.apache.cassandra.db.ClusteringPrefix$Kind.CLUSTERING:Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            if_acmpne 4
         3: .line 285
            getstatic org.apache.cassandra.db.Clustering.serializer:Lorg/apache/cassandra/db/Clustering$Serializer;
            aload 1 /* in */
            iload 2 /* version */
            aload 3 /* types */
            invokevirtual org.apache.cassandra.db.Clustering$Serializer.deserialize:(Lorg/apache/cassandra/io/util/DataInputPlus;ILjava/util/List;)Lorg/apache/cassandra/db/Clustering;
            areturn
         4: .line 287
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.db.ClusteringBoundOrBoundary.serializer:Lorg/apache/cassandra/db/ClusteringBoundOrBoundary$Serializer;
            aload 1 /* in */
            aload 4 /* kind */
            iload 2 /* version */
            aload 3 /* types */
            invokevirtual org.apache.cassandra.db.ClusteringBoundOrBoundary$Serializer.deserializeValues:(Lorg/apache/cassandra/io/util/DataInputPlus;Lorg/apache/cassandra/db/ClusteringPrefix$Kind;ILjava/util/List;)Lorg/apache/cassandra/db/ClusteringBoundOrBoundary;
            areturn
        end local 4 // org.apache.cassandra.db.ClusteringPrefix$Kind kind
        end local 3 // java.util.List types
        end local 2 // int version
        end local 1 // org.apache.cassandra.io.util.DataInputPlus in
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;
            0    5     1       in  Lorg/apache/cassandra/io/util/DataInputPlus;
            0    5     2  version  I
            0    5     3    types  Ljava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;
            1    5     4     kind  Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/apache/cassandra/io/util/DataInputPlus;ILjava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;)Lorg/apache/cassandra/db/ClusteringPrefix;
    MethodParameters:
         Name  Flags
      in       
      version  
      types    

  public long serializedSize(org.apache.cassandra.db.ClusteringPrefix, int, java.util.List<org.apache.cassandra.db.marshal.AbstractType<?>>);
    descriptor: (Lorg/apache/cassandra/db/ClusteringPrefix;ILjava/util/List;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
        start local 1 // org.apache.cassandra.db.ClusteringPrefix clustering
        start local 2 // int version
        start local 3 // java.util.List types
         0: .line 293
            getstatic org.apache.cassandra.db.ClusteringPrefix$Serializer.$assertionsDisabled:Z
            ifne 1
            aload 1 /* clustering */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.kind:()Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            getstatic org.apache.cassandra.db.ClusteringPrefix$Kind.STATIC_CLUSTERING:Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            if_acmpne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 294
      StackMap locals:
      StackMap stack:
            aload 1 /* clustering */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.kind:()Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            getstatic org.apache.cassandra.db.ClusteringPrefix$Kind.CLUSTERING:Lorg/apache/cassandra/db/ClusteringPrefix$Kind;
            if_acmpne 3
         2: .line 295
            lconst_1
            getstatic org.apache.cassandra.db.Clustering.serializer:Lorg/apache/cassandra/db/Clustering$Serializer;
            aload 1 /* clustering */
            checkcast org.apache.cassandra.db.Clustering
            iload 2 /* version */
            aload 3 /* types */
            invokevirtual org.apache.cassandra.db.Clustering$Serializer.serializedSize:(Lorg/apache/cassandra/db/Clustering;ILjava/util/List;)J
            ladd
            lreturn
         3: .line 297
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.db.ClusteringBoundOrBoundary.serializer:Lorg/apache/cassandra/db/ClusteringBoundOrBoundary$Serializer;
            aload 1 /* clustering */
            checkcast org.apache.cassandra.db.ClusteringBoundOrBoundary
            iload 2 /* version */
            aload 3 /* types */
            invokevirtual org.apache.cassandra.db.ClusteringBoundOrBoundary$Serializer.serializedSize:(Lorg/apache/cassandra/db/ClusteringBoundOrBoundary;ILjava/util/List;)J
            lreturn
        end local 3 // java.util.List types
        end local 2 // int version
        end local 1 // org.apache.cassandra.db.ClusteringPrefix clustering
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;
            0    4     1  clustering  Lorg/apache/cassandra/db/ClusteringPrefix;
            0    4     2     version  I
            0    4     3       types  Ljava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;
    Signature: (Lorg/apache/cassandra/db/ClusteringPrefix;ILjava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;)J
    MethodParameters:
            Name  Flags
      clustering  
      version     
      types       

  void serializeValuesWithoutSize(org.apache.cassandra.db.ClusteringPrefix, org.apache.cassandra.io.util.DataOutputPlus, int, java.util.List<org.apache.cassandra.db.marshal.AbstractType<?>>);
    descriptor: (Lorg/apache/cassandra/db/ClusteringPrefix;Lorg/apache/cassandra/io/util/DataOutputPlus;ILjava/util/List;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=9, args_size=5
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
        start local 1 // org.apache.cassandra.db.ClusteringPrefix clustering
        start local 2 // org.apache.cassandra.io.util.DataOutputPlus out
        start local 3 // int version
        start local 4 // java.util.List types
         0: .line 302
            iconst_0
            istore 5 /* offset */
        start local 5 // int offset
         1: .line 303
            aload 1 /* clustering */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.size:()I
            istore 6 /* clusteringSize */
        start local 6 // int clusteringSize
         2: .line 305
            goto 11
         3: .line 311
      StackMap locals: int int
      StackMap stack:
            iload 6 /* clusteringSize */
            iload 5 /* offset */
            bipush 32
            iadd
            invokestatic java.lang.Math.min:(II)I
            istore 7 /* limit */
        start local 7 // int limit
         4: .line 312
            aload 2 /* out */
            aload 1 /* clustering */
            iload 5 /* offset */
            iload 7 /* limit */
            invokestatic org.apache.cassandra.db.ClusteringPrefix$Serializer.makeHeader:(Lorg/apache/cassandra/db/ClusteringPrefix;II)J
            invokeinterface org.apache.cassandra.io.util.DataOutputPlus.writeUnsignedVInt:(J)V
         5: .line 313
            goto 10
         6: .line 315
      StackMap locals: int
      StackMap stack:
            aload 1 /* clustering */
            iload 5 /* offset */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.get:(I)Ljava/nio/ByteBuffer;
            astore 8 /* v */
        start local 8 // java.nio.ByteBuffer v
         7: .line 316
            aload 8 /* v */
            ifnull 9
            aload 8 /* v */
            invokevirtual java.nio.ByteBuffer.hasRemaining:()Z
            ifeq 9
         8: .line 317
            aload 4 /* types */
            iload 5 /* offset */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.marshal.AbstractType
            aload 8 /* v */
            aload 2 /* out */
            invokevirtual org.apache.cassandra.db.marshal.AbstractType.writeValue:(Ljava/nio/ByteBuffer;Lorg/apache/cassandra/io/util/DataOutputPlus;)V
         9: .line 318
      StackMap locals: java.nio.ByteBuffer
      StackMap stack:
            iinc 5 /* offset */ 1
        end local 8 // java.nio.ByteBuffer v
        10: .line 313
      StackMap locals:
      StackMap stack:
            iload 5 /* offset */
            iload 7 /* limit */
            if_icmplt 6
        end local 7 // int limit
        11: .line 305
      StackMap locals:
      StackMap stack:
            iload 5 /* offset */
            iload 6 /* clusteringSize */
            if_icmplt 3
        12: .line 321
            return
        end local 6 // int clusteringSize
        end local 5 // int offset
        end local 4 // java.util.List types
        end local 3 // int version
        end local 2 // org.apache.cassandra.io.util.DataOutputPlus out
        end local 1 // org.apache.cassandra.db.ClusteringPrefix clustering
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   13     0            this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;
            0   13     1      clustering  Lorg/apache/cassandra/db/ClusteringPrefix;
            0   13     2             out  Lorg/apache/cassandra/io/util/DataOutputPlus;
            0   13     3         version  I
            0   13     4           types  Ljava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;
            1   13     5          offset  I
            2   13     6  clusteringSize  I
            4   11     7           limit  I
            7   10     8               v  Ljava/nio/ByteBuffer;
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/apache/cassandra/db/ClusteringPrefix;Lorg/apache/cassandra/io/util/DataOutputPlus;ILjava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;)V
    MethodParameters:
            Name  Flags
      clustering  
      out         
      version     
      types       

  long valuesWithoutSizeSerializedSize(org.apache.cassandra.db.ClusteringPrefix, int, java.util.List<org.apache.cassandra.db.marshal.AbstractType<?>>);
    descriptor: (Lorg/apache/cassandra/db/ClusteringPrefix;ILjava/util/List;)J
    flags: (0x0000) 
    Code:
      stack=5, locals=10, args_size=4
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
        start local 1 // org.apache.cassandra.db.ClusteringPrefix clustering
        start local 2 // int version
        start local 3 // java.util.List types
         0: .line 325
            lconst_0
            lstore 4 /* result */
        start local 4 // long result
         1: .line 326
            iconst_0
            istore 6 /* offset */
        start local 6 // int offset
         2: .line 327
            aload 1 /* clustering */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.size:()I
            istore 7 /* clusteringSize */
        start local 7 // int clusteringSize
         3: .line 328
            goto 7
         4: .line 330
      StackMap locals: long int int
      StackMap stack:
            iload 7 /* clusteringSize */
            iload 6 /* offset */
            bipush 32
            iadd
            invokestatic java.lang.Math.min:(II)I
            istore 8 /* limit */
        start local 8 // int limit
         5: .line 331
            lload 4 /* result */
            aload 1 /* clustering */
            iload 6 /* offset */
            iload 8 /* limit */
            invokestatic org.apache.cassandra.db.ClusteringPrefix$Serializer.makeHeader:(Lorg/apache/cassandra/db/ClusteringPrefix;II)J
            invokestatic org.apache.cassandra.db.TypeSizes.sizeofUnsignedVInt:(J)I
            i2l
            ladd
            lstore 4 /* result */
         6: .line 332
            iload 8 /* limit */
            istore 6 /* offset */
        end local 8 // int limit
         7: .line 328
      StackMap locals:
      StackMap stack:
            iload 6 /* offset */
            iload 7 /* clusteringSize */
            if_icmplt 4
         8: .line 334
            iconst_0
            istore 8 /* i */
        start local 8 // int i
         9: goto 15
        10: .line 336
      StackMap locals: int
      StackMap stack:
            aload 1 /* clustering */
            iload 8 /* i */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.get:(I)Ljava/nio/ByteBuffer;
            astore 9 /* v */
        start local 9 // java.nio.ByteBuffer v
        11: .line 337
            aload 9 /* v */
            ifnull 14
            aload 9 /* v */
            invokevirtual java.nio.ByteBuffer.hasRemaining:()Z
            ifne 13
        12: .line 338
            goto 14
        13: .line 340
      StackMap locals: java.nio.ByteBuffer
      StackMap stack:
            lload 4 /* result */
            aload 3 /* types */
            iload 8 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.marshal.AbstractType
            aload 9 /* v */
            invokevirtual org.apache.cassandra.db.marshal.AbstractType.writtenLength:(Ljava/nio/ByteBuffer;)J
            ladd
            lstore 4 /* result */
        end local 9 // java.nio.ByteBuffer v
        14: .line 334
      StackMap locals:
      StackMap stack:
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        15: iload 8 /* i */
            iload 7 /* clusteringSize */
            if_icmplt 10
        end local 8 // int i
        16: .line 342
            lload 4 /* result */
            lreturn
        end local 7 // int clusteringSize
        end local 6 // int offset
        end local 4 // long result
        end local 3 // java.util.List types
        end local 2 // int version
        end local 1 // org.apache.cassandra.db.ClusteringPrefix clustering
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   17     0            this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;
            0   17     1      clustering  Lorg/apache/cassandra/db/ClusteringPrefix;
            0   17     2         version  I
            0   17     3           types  Ljava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;
            1   17     4          result  J
            2   17     6          offset  I
            3   17     7  clusteringSize  I
            5    7     8           limit  I
            9   16     8               i  I
           11   14     9               v  Ljava/nio/ByteBuffer;
    Signature: (Lorg/apache/cassandra/db/ClusteringPrefix;ILjava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;)J
    MethodParameters:
            Name  Flags
      clustering  
      version     
      types       

  java.nio.ByteBuffer[] deserializeValuesWithoutSize(org.apache.cassandra.io.util.DataInputPlus, int, int, java.util.List<org.apache.cassandra.db.marshal.AbstractType<?>>);
    descriptor: (Lorg/apache/cassandra/io/util/DataInputPlus;IILjava/util/List;)[Ljava/nio/ByteBuffer;
    flags: (0x0000) 
    Code:
      stack=5, locals=10, args_size=5
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
        start local 1 // org.apache.cassandra.io.util.DataInputPlus in
        start local 2 // int size
        start local 3 // int version
        start local 4 // java.util.List types
         0: .line 348
            getstatic org.apache.cassandra.db.ClusteringPrefix$Serializer.$assertionsDisabled:Z
            ifne 1
            iload 2 /* size */
            ifgt 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 349
      StackMap locals:
      StackMap stack:
            iload 2 /* size */
            anewarray java.nio.ByteBuffer
            astore 5 /* values */
        start local 5 // java.nio.ByteBuffer[] values
         2: .line 350
            iconst_0
            istore 6 /* offset */
        start local 6 // int offset
         3: .line 351
            goto 14
         4: .line 353
      StackMap locals: java.nio.ByteBuffer[] int
      StackMap stack:
            aload 1 /* in */
            invokeinterface org.apache.cassandra.io.util.DataInputPlus.readUnsignedVInt:()J
            lstore 7 /* header */
        start local 7 // long header
         5: .line 354
            iload 2 /* size */
            iload 6 /* offset */
            bipush 32
            iadd
            invokestatic java.lang.Math.min:(II)I
            istore 9 /* limit */
        start local 9 // int limit
         6: .line 355
            goto 13
         7: .line 357
      StackMap locals: long int
      StackMap stack:
            aload 5 /* values */
            iload 6 /* offset */
            lload 7 /* header */
            iload 6 /* offset */
            invokestatic org.apache.cassandra.db.ClusteringPrefix$Serializer.isNull:(JI)Z
            ifeq 9
         8: .line 358
            aconst_null
            goto 11
         9: .line 359
      StackMap locals: org.apache.cassandra.db.ClusteringPrefix$Serializer org.apache.cassandra.io.util.DataInputPlus int int java.util.List java.nio.ByteBuffer[] int long int
      StackMap stack: java.nio.ByteBuffer[] int
            lload 7 /* header */
            iload 6 /* offset */
            invokestatic org.apache.cassandra.db.ClusteringPrefix$Serializer.isEmpty:(JI)Z
            ifeq 10
            getstatic org.apache.cassandra.utils.ByteBufferUtil.EMPTY_BYTE_BUFFER:Ljava/nio/ByteBuffer;
            goto 11
      StackMap locals: org.apache.cassandra.db.ClusteringPrefix$Serializer org.apache.cassandra.io.util.DataInputPlus int int java.util.List java.nio.ByteBuffer[] int long int
      StackMap stack: java.nio.ByteBuffer[] int
        10: aload 4 /* types */
            iload 6 /* offset */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.marshal.AbstractType
            aload 1 /* in */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMaxValueSize:()I
            invokevirtual org.apache.cassandra.db.marshal.AbstractType.readValue:(Lorg/apache/cassandra/io/util/DataInputPlus;I)Ljava/nio/ByteBuffer;
        11: .line 357
      StackMap locals: org.apache.cassandra.db.ClusteringPrefix$Serializer org.apache.cassandra.io.util.DataInputPlus int int java.util.List java.nio.ByteBuffer[] int long int
      StackMap stack: java.nio.ByteBuffer[] int java.nio.ByteBuffer
            aastore
        12: .line 360
            iinc 6 /* offset */ 1
        13: .line 355
      StackMap locals:
      StackMap stack:
            iload 6 /* offset */
            iload 9 /* limit */
            if_icmplt 7
        end local 9 // int limit
        end local 7 // long header
        14: .line 351
      StackMap locals:
      StackMap stack:
            iload 6 /* offset */
            iload 2 /* size */
            if_icmplt 4
        15: .line 363
            aload 5 /* values */
            areturn
        end local 6 // int offset
        end local 5 // java.nio.ByteBuffer[] values
        end local 4 // java.util.List types
        end local 3 // int version
        end local 2 // int size
        end local 1 // org.apache.cassandra.io.util.DataInputPlus in
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   16     0     this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;
            0   16     1       in  Lorg/apache/cassandra/io/util/DataInputPlus;
            0   16     2     size  I
            0   16     3  version  I
            0   16     4    types  Ljava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;
            2   16     5   values  [Ljava/nio/ByteBuffer;
            3   16     6   offset  I
            5   14     7   header  J
            6   14     9    limit  I
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/apache/cassandra/io/util/DataInputPlus;IILjava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;)[Ljava/nio/ByteBuffer;
    MethodParameters:
         Name  Flags
      in       
      size     
      version  
      types    

  void skipValuesWithoutSize(org.apache.cassandra.io.util.DataInputPlus, int, int, java.util.List<org.apache.cassandra.db.marshal.AbstractType<?>>);
    descriptor: (Lorg/apache/cassandra/io/util/DataInputPlus;IILjava/util/List;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=9, args_size=5
        start local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
        start local 1 // org.apache.cassandra.io.util.DataInputPlus in
        start local 2 // int size
        start local 3 // int version
        start local 4 // java.util.List types
         0: .line 369
            getstatic org.apache.cassandra.db.ClusteringPrefix$Serializer.$assertionsDisabled:Z
            ifne 1
            iload 2 /* size */
            ifgt 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 370
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 5 /* offset */
        start local 5 // int offset
         2: .line 371
            goto 10
         3: .line 373
      StackMap locals: int
      StackMap stack:
            aload 1 /* in */
            invokeinterface org.apache.cassandra.io.util.DataInputPlus.readUnsignedVInt:()J
            lstore 6 /* header */
        start local 6 // long header
         4: .line 374
            iload 2 /* size */
            iload 5 /* offset */
            bipush 32
            iadd
            invokestatic java.lang.Math.min:(II)I
            istore 8 /* limit */
        start local 8 // int limit
         5: .line 375
            goto 9
         6: .line 377
      StackMap locals: long int
      StackMap stack:
            lload 6 /* header */
            iload 5 /* offset */
            invokestatic org.apache.cassandra.db.ClusteringPrefix$Serializer.isNull:(JI)Z
            ifne 8
            lload 6 /* header */
            iload 5 /* offset */
            invokestatic org.apache.cassandra.db.ClusteringPrefix$Serializer.isEmpty:(JI)Z
            ifne 8
         7: .line 378
            aload 4 /* types */
            iload 5 /* offset */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.db.marshal.AbstractType
            aload 1 /* in */
            invokevirtual org.apache.cassandra.db.marshal.AbstractType.skipValue:(Lorg/apache/cassandra/io/util/DataInputPlus;)V
         8: .line 379
      StackMap locals:
      StackMap stack:
            iinc 5 /* offset */ 1
         9: .line 375
      StackMap locals:
      StackMap stack:
            iload 5 /* offset */
            iload 8 /* limit */
            if_icmplt 6
        end local 8 // int limit
        end local 6 // long header
        10: .line 371
      StackMap locals:
      StackMap stack:
            iload 5 /* offset */
            iload 2 /* size */
            if_icmplt 3
        11: .line 382
            return
        end local 5 // int offset
        end local 4 // java.util.List types
        end local 3 // int version
        end local 2 // int size
        end local 1 // org.apache.cassandra.io.util.DataInputPlus in
        end local 0 // org.apache.cassandra.db.ClusteringPrefix$Serializer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   12     0     this  Lorg/apache/cassandra/db/ClusteringPrefix$Serializer;
            0   12     1       in  Lorg/apache/cassandra/io/util/DataInputPlus;
            0   12     2     size  I
            0   12     3  version  I
            0   12     4    types  Ljava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;
            2   12     5   offset  I
            4   10     6   header  J
            5   10     8    limit  I
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/apache/cassandra/io/util/DataInputPlus;IILjava/util/List<Lorg/apache/cassandra/db/marshal/AbstractType<*>;>;)V
    MethodParameters:
         Name  Flags
      in       
      size     
      version  
      types    

  private static long makeHeader(org.apache.cassandra.db.ClusteringPrefix, int, int);
    descriptor: (Lorg/apache/cassandra/db/ClusteringPrefix;II)J
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=7, args_size=3
        start local 0 // org.apache.cassandra.db.ClusteringPrefix clustering
        start local 1 // int offset
        start local 2 // int limit
         0: .line 392
            lconst_0
            lstore 3 /* header */
        start local 3 // long header
         1: .line 393
            iload 1 /* offset */
            istore 5 /* i */
        start local 5 // int i
         2: goto 9
         3: .line 395
      StackMap locals: long int
      StackMap stack:
            aload 0 /* clustering */
            iload 5 /* i */
            invokeinterface org.apache.cassandra.db.ClusteringPrefix.get:(I)Ljava/nio/ByteBuffer;
            astore 6 /* v */
        start local 6 // java.nio.ByteBuffer v
         4: .line 397
            aload 6 /* v */
            ifnonnull 6
         5: .line 398
            lload 3 /* header */
            lconst_1
            iload 5 /* i */
            iconst_2
            imul
            iconst_1
            iadd
            lshl
            lor
            lstore 3 /* header */
            goto 8
         6: .line 399
      StackMap locals: java.nio.ByteBuffer
      StackMap stack:
            aload 6 /* v */
            invokevirtual java.nio.ByteBuffer.hasRemaining:()Z
            ifne 8
         7: .line 400
            lload 3 /* header */
            lconst_1
            iload 5 /* i */
            iconst_2
            imul
            lshl
            lor
            lstore 3 /* header */
        end local 6 // java.nio.ByteBuffer v
         8: .line 393
      StackMap locals:
      StackMap stack:
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: iload 5 /* i */
            iload 2 /* limit */
            if_icmplt 3
        end local 5 // int i
        10: .line 402
            lload 3 /* header */
            lreturn
        end local 3 // long header
        end local 2 // int limit
        end local 1 // int offset
        end local 0 // org.apache.cassandra.db.ClusteringPrefix clustering
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   11     0  clustering  Lorg/apache/cassandra/db/ClusteringPrefix;
            0   11     1      offset  I
            0   11     2       limit  I
            1   11     3      header  J
            2   10     5           i  I
            4    8     6           v  Ljava/nio/ByteBuffer;
    MethodParameters:
            Name  Flags
      clustering  
      offset      
      limit       

  private static boolean isNull(long, int);
    descriptor: (JI)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // long header
        start local 2 // int i
         0: .line 408
            lconst_1
            iload 2 /* i */
            iconst_2
            imul
            iconst_1
            iadd
            lshl
            lstore 3 /* mask */
        start local 3 // long mask
         1: .line 409
            lload 0 /* header */
            lload 3 /* mask */
            land
            lconst_0
            lcmp
            ifeq 2
            iconst_1
            ireturn
      StackMap locals: long
      StackMap stack:
         2: iconst_0
            ireturn
        end local 3 // long mask
        end local 2 // int i
        end local 0 // long header
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0  header  J
            0    3     2       i  I
            1    3     3    mask  J
    MethodParameters:
        Name  Flags
      header  
      i       

  private static boolean isEmpty(long, int);
    descriptor: (JI)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // long header
        start local 2 // int i
         0: .line 415
            lconst_1
            iload 2 /* i */
            iconst_2
            imul
            lshl
            lstore 3 /* mask */
        start local 3 // long mask
         1: .line 416
            lload 0 /* header */
            lload 3 /* mask */
            land
            lconst_0
            lcmp
            ifeq 2
            iconst_1
            ireturn
      StackMap locals: long
      StackMap stack:
         2: iconst_0
            ireturn
        end local 3 // long mask
        end local 2 // int i
        end local 0 // long header
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0  header  J
            0    3     2       i  I
            1    3     3    mask  J
    MethodParameters:
        Name  Flags
      header  
      i       
}
SourceFile: "ClusteringPrefix.java"
NestHost: org.apache.cassandra.db.ClusteringPrefix
InnerClasses:
  public Serializer = org.apache.cassandra.db.Clustering$Serializer of org.apache.cassandra.db.Clustering
  public Serializer = org.apache.cassandra.db.ClusteringBoundOrBoundary$Serializer of org.apache.cassandra.db.ClusteringBoundOrBoundary
  public final Kind = org.apache.cassandra.db.ClusteringPrefix$Kind of org.apache.cassandra.db.ClusteringPrefix
  public Serializer = org.apache.cassandra.db.ClusteringPrefix$Serializer of org.apache.cassandra.db.ClusteringPrefix