public class org.apache.cassandra.serializers.TupleSerializer extends org.apache.cassandra.serializers.BytesSerializer
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.serializers.TupleSerializer
  super_class: org.apache.cassandra.serializers.BytesSerializer
{
  public final java.util.List<org.apache.cassandra.serializers.TypeSerializer<?>> fields;
    descriptor: Ljava/util/List;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Signature: Ljava/util/List<Lorg/apache/cassandra/serializers/TypeSerializer<*>;>;

  public void <init>(java.util.List<org.apache.cassandra.serializers.TypeSerializer<?>>);
    descriptor: (Ljava/util/List;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.serializers.TupleSerializer this
        start local 1 // java.util.List fields
         0: .line 29
            aload 0 /* this */
            invokespecial org.apache.cassandra.serializers.BytesSerializer.<init>:()V
         1: .line 31
            aload 0 /* this */
            aload 1 /* fields */
            putfield org.apache.cassandra.serializers.TupleSerializer.fields:Ljava/util/List;
         2: .line 32
            return
        end local 1 // java.util.List fields
        end local 0 // org.apache.cassandra.serializers.TupleSerializer this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/apache/cassandra/serializers/TupleSerializer;
            0    3     1  fields  Ljava/util/List<Lorg/apache/cassandra/serializers/TypeSerializer<*>;>;
    Signature: (Ljava/util/List<Lorg/apache/cassandra/serializers/TypeSerializer<*>;>;)V
    MethodParameters:
        Name  Flags
      fields  

  public void validate(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=2
        start local 0 // org.apache.cassandra.serializers.TupleSerializer this
        start local 1 // java.nio.ByteBuffer bytes
         0: .line 37
            aload 1 /* bytes */
            invokevirtual java.nio.ByteBuffer.duplicate:()Ljava/nio/ByteBuffer;
            astore 2 /* input */
        start local 2 // java.nio.ByteBuffer input
         1: .line 38
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         2: goto 15
         3: .line 41
      StackMap locals: java.nio.ByteBuffer int
      StackMap stack:
            aload 2 /* input */
            invokevirtual java.nio.ByteBuffer.hasRemaining:()Z
            ifne 5
         4: .line 42
            return
         5: .line 44
      StackMap locals:
      StackMap stack:
            aload 2 /* input */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_4
            if_icmpge 7
         6: .line 45
            new org.apache.cassandra.serializers.MarshalException
            dup
            ldc "Not enough bytes to read size of %dth component"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            iload 3 /* i */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial org.apache.cassandra.serializers.MarshalException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 47
      StackMap locals:
      StackMap stack:
            aload 2 /* input */
            invokevirtual java.nio.ByteBuffer.getInt:()I
            istore 4 /* size */
        start local 4 // int size
         8: .line 50
            iload 4 /* size */
            ifge 10
         9: .line 51
            goto 14
        10: .line 53
      StackMap locals: int
      StackMap stack:
            aload 2 /* input */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iload 4 /* size */
            if_icmpge 12
        11: .line 54
            new org.apache.cassandra.serializers.MarshalException
            dup
            ldc "Not enough bytes to read %dth component"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            iload 3 /* i */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial org.apache.cassandra.serializers.MarshalException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 56
      StackMap locals:
      StackMap stack:
            aload 2 /* input */
            iload 4 /* size */
            invokestatic org.apache.cassandra.utils.ByteBufferUtil.readBytes:(Ljava/nio/ByteBuffer;I)Ljava/nio/ByteBuffer;
            astore 5 /* field */
        start local 5 // java.nio.ByteBuffer field
        13: .line 57
            aload 0 /* this */
            getfield org.apache.cassandra.serializers.TupleSerializer.fields:Ljava/util/List;
            iload 3 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.cassandra.serializers.TypeSerializer
            aload 5 /* field */
            invokeinterface org.apache.cassandra.serializers.TypeSerializer.validate:(Ljava/nio/ByteBuffer;)V
        end local 5 // java.nio.ByteBuffer field
        end local 4 // int size
        14: .line 38
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        15: iload 3 /* i */
            aload 0 /* this */
            getfield org.apache.cassandra.serializers.TupleSerializer.fields:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            if_icmplt 3
        end local 3 // int i
        16: .line 61
            aload 2 /* input */
            invokevirtual java.nio.ByteBuffer.hasRemaining:()Z
            ifeq 18
        17: .line 62
            new org.apache.cassandra.serializers.MarshalException
            dup
            ldc "Invalid remaining data after end of tuple value"
            invokespecial org.apache.cassandra.serializers.MarshalException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 63
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.nio.ByteBuffer input
        end local 1 // java.nio.ByteBuffer bytes
        end local 0 // org.apache.cassandra.serializers.TupleSerializer this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   19     0   this  Lorg/apache/cassandra/serializers/TupleSerializer;
            0   19     1  bytes  Ljava/nio/ByteBuffer;
            1   19     2  input  Ljava/nio/ByteBuffer;
            2   16     3      i  I
            8   14     4   size  I
           13   14     5  field  Ljava/nio/ByteBuffer;
    Exceptions:
      throws org.apache.cassandra.serializers.MarshalException
    MethodParameters:
       Name  Flags
      bytes  
}
SourceFile: "TupleSerializer.java"