public class org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer implements org.apache.cassandra.io.IVersionedSerializer<org.apache.cassandra.utils.MerkleTrees>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer
  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 388
            ldc Lorg/apache/cassandra/utils/MerkleTrees;
            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.utils.MerkleTrees$MerkleTreesSerializer.$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.utils.MerkleTrees$MerkleTreesSerializer this
         0: .line 388
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/utils/MerkleTrees$MerkleTreesSerializer;

  public void serialize(org.apache.cassandra.utils.MerkleTrees, org.apache.cassandra.io.util.DataOutputPlus, int);
    descriptor: (Lorg/apache/cassandra/utils/MerkleTrees;Lorg/apache/cassandra/io/util/DataOutputPlus;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer this
        start local 1 // org.apache.cassandra.utils.MerkleTrees trees
        start local 2 // org.apache.cassandra.io.util.DataOutputPlus out
        start local 3 // int version
         0: .line 392
            aload 2 /* out */
            aload 1 /* trees */
            getfield org.apache.cassandra.utils.MerkleTrees.merkleTrees:Ljava/util/Map;
            invokeinterface java.util.Map.size:()I
            invokeinterface org.apache.cassandra.io.util.DataOutputPlus.writeInt:(I)V
         1: .line 393
            aload 1 /* trees */
            getfield org.apache.cassandra.utils.MerkleTrees.merkleTrees:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 4
      StackMap locals: org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer org.apache.cassandra.utils.MerkleTrees org.apache.cassandra.io.util.DataOutputPlus int top java.util.Iterator
      StackMap stack:
         2: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.MerkleTree
            astore 4 /* tree */
        start local 4 // org.apache.cassandra.utils.MerkleTree tree
         3: .line 395
            getstatic org.apache.cassandra.utils.MerkleTree.serializer:Lorg/apache/cassandra/utils/MerkleTree$MerkleTreeSerializer;
            aload 4 /* tree */
            aload 2 /* out */
            iload 3 /* version */
            invokevirtual org.apache.cassandra.utils.MerkleTree$MerkleTreeSerializer.serialize:(Lorg/apache/cassandra/utils/MerkleTree;Lorg/apache/cassandra/io/util/DataOutputPlus;I)V
        end local 4 // org.apache.cassandra.utils.MerkleTree tree
         4: .line 393
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 397
            return
        end local 3 // int version
        end local 2 // org.apache.cassandra.io.util.DataOutputPlus out
        end local 1 // org.apache.cassandra.utils.MerkleTrees trees
        end local 0 // org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0     this  Lorg/apache/cassandra/utils/MerkleTrees$MerkleTreesSerializer;
            0    6     1    trees  Lorg/apache/cassandra/utils/MerkleTrees;
            0    6     2      out  Lorg/apache/cassandra/io/util/DataOutputPlus;
            0    6     3  version  I
            3    4     4     tree  Lorg/apache/cassandra/utils/MerkleTree;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      trees    
      out      
      version  

  public org.apache.cassandra.utils.MerkleTrees deserialize(org.apache.cassandra.io.util.DataInputPlus, int);
    descriptor: (Lorg/apache/cassandra/io/util/DataInputPlus;I)Lorg/apache/cassandra/utils/MerkleTrees;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=8, args_size=3
        start local 0 // org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer this
        start local 1 // org.apache.cassandra.io.util.DataInputPlus in
        start local 2 // int version
         0: .line 401
            aconst_null
            astore 3 /* partitioner */
        start local 3 // org.apache.cassandra.dht.IPartitioner partitioner
         1: .line 402
            aload 1 /* in */
            invokeinterface org.apache.cassandra.io.util.DataInputPlus.readInt:()I
            istore 4 /* nTrees */
        start local 4 // int nTrees
         2: .line 403
            new java.util.ArrayList
            dup
            iload 4 /* nTrees */
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 5 /* trees */
        start local 5 // java.util.Collection trees
         3: .line 404
            iload 4 /* nTrees */
            ifle 13
         4: .line 406
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         5: goto 12
         6: .line 408
      StackMap locals: org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer org.apache.cassandra.io.util.DataInputPlus int org.apache.cassandra.dht.IPartitioner int java.util.Collection int
      StackMap stack:
            getstatic org.apache.cassandra.utils.MerkleTree.serializer:Lorg/apache/cassandra/utils/MerkleTree$MerkleTreeSerializer;
            aload 1 /* in */
            iload 2 /* version */
            invokevirtual org.apache.cassandra.utils.MerkleTree$MerkleTreeSerializer.deserialize:(Lorg/apache/cassandra/io/util/DataInputPlus;I)Lorg/apache/cassandra/utils/MerkleTree;
            astore 7 /* tree */
        start local 7 // org.apache.cassandra.utils.MerkleTree tree
         7: .line 409
            aload 5 /* trees */
            aload 7 /* tree */
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
         8: .line 411
            aload 3 /* partitioner */
            ifnonnull 10
         9: .line 412
            aload 7 /* tree */
            invokevirtual org.apache.cassandra.utils.MerkleTree.partitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            astore 3 /* partitioner */
            goto 11
        10: .line 414
      StackMap locals: org.apache.cassandra.utils.MerkleTree
      StackMap stack:
            getstatic org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer.$assertionsDisabled:Z
            ifne 11
            aload 7 /* tree */
            invokevirtual org.apache.cassandra.utils.MerkleTree.partitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            aload 3 /* partitioner */
            if_acmpeq 11
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        end local 7 // org.apache.cassandra.utils.MerkleTree tree
        11: .line 406
      StackMap locals:
      StackMap stack:
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        12: iload 6 /* i */
            iload 4 /* nTrees */
            if_icmplt 6
        end local 6 // int i
        13: .line 418
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.utils.MerkleTrees
            dup
            aload 3 /* partitioner */
            aload 5 /* trees */
            invokespecial org.apache.cassandra.utils.MerkleTrees.<init>:(Lorg/apache/cassandra/dht/IPartitioner;Ljava/util/Collection;)V
            areturn
        end local 5 // java.util.Collection trees
        end local 4 // int nTrees
        end local 3 // org.apache.cassandra.dht.IPartitioner partitioner
        end local 2 // int version
        end local 1 // org.apache.cassandra.io.util.DataInputPlus in
        end local 0 // org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   14     0         this  Lorg/apache/cassandra/utils/MerkleTrees$MerkleTreesSerializer;
            0   14     1           in  Lorg/apache/cassandra/io/util/DataInputPlus;
            0   14     2      version  I
            1   14     3  partitioner  Lorg/apache/cassandra/dht/IPartitioner;
            2   14     4       nTrees  I
            3   14     5        trees  Ljava/util/Collection<Lorg/apache/cassandra/utils/MerkleTree;>;
            5   13     6            i  I
            7   11     7         tree  Lorg/apache/cassandra/utils/MerkleTree;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      in       
      version  

  public long serializedSize(org.apache.cassandra.utils.MerkleTrees, int);
    descriptor: (Lorg/apache/cassandra/utils/MerkleTrees;I)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer this
        start local 1 // org.apache.cassandra.utils.MerkleTrees trees
        start local 2 // int version
         0: .line 423
            getstatic org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer.$assertionsDisabled:Z
            ifne 1
            aload 1 /* trees */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 425
      StackMap locals:
      StackMap stack:
            aload 1 /* trees */
            getfield org.apache.cassandra.utils.MerkleTrees.merkleTrees:Ljava/util/Map;
            invokeinterface java.util.Map.size:()I
            invokestatic org.apache.cassandra.db.TypeSizes.sizeof:(I)I
            i2l
            lstore 3 /* size */
        start local 3 // long size
         2: .line 426
            aload 1 /* trees */
            getfield org.apache.cassandra.utils.MerkleTrees.merkleTrees:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 6
            goto 5
      StackMap locals: org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer org.apache.cassandra.utils.MerkleTrees int long top java.util.Iterator
      StackMap stack:
         3: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.MerkleTree
            astore 5 /* tree */
        start local 5 // org.apache.cassandra.utils.MerkleTree tree
         4: .line 428
            lload 3 /* size */
            getstatic org.apache.cassandra.utils.MerkleTree.serializer:Lorg/apache/cassandra/utils/MerkleTree$MerkleTreeSerializer;
            aload 5 /* tree */
            iload 2 /* version */
            invokevirtual org.apache.cassandra.utils.MerkleTree$MerkleTreeSerializer.serializedSize:(Lorg/apache/cassandra/utils/MerkleTree;I)J
            ladd
            lstore 3 /* size */
        end local 5 // org.apache.cassandra.utils.MerkleTree tree
         5: .line 426
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 430
            lload 3 /* size */
            lreturn
        end local 3 // long size
        end local 2 // int version
        end local 1 // org.apache.cassandra.utils.MerkleTrees trees
        end local 0 // org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lorg/apache/cassandra/utils/MerkleTrees$MerkleTreesSerializer;
            0    7     1    trees  Lorg/apache/cassandra/utils/MerkleTrees;
            0    7     2  version  I
            2    7     3     size  J
            4    5     5     tree  Lorg/apache/cassandra/utils/MerkleTree;
    MethodParameters:
         Name  Flags
      trees    
      version  

  public void serialize(java.lang.Object, org.apache.cassandra.io.util.DataOutputPlus, int);
    descriptor: (Ljava/lang/Object;Lorg/apache/cassandra/io/util/DataOutputPlus;I)V
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=4, locals=4, args_size=4
         0: .line 1
            aload 0
            aload 1
            checkcast org.apache.cassandra.utils.MerkleTrees
            aload 2
            iload 3
            invokevirtual org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer.serialize:(Lorg/apache/cassandra/utils/MerkleTrees;Lorg/apache/cassandra/io/util/DataOutputPlus;I)V
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.io.IOException

  public long serializedSize(java.lang.Object, int);
    descriptor: (Ljava/lang/Object;I)J
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            checkcast org.apache.cassandra.utils.MerkleTrees
            iload 2
            invokevirtual org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer.serializedSize:(Lorg/apache/cassandra/utils/MerkleTrees;I)J
            lreturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public java.lang.Object deserialize(org.apache.cassandra.io.util.DataInputPlus, int);
    descriptor: (Lorg/apache/cassandra/io/util/DataInputPlus;I)Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            iload 2
            invokevirtual org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer.deserialize:(Lorg/apache/cassandra/io/util/DataInputPlus;I)Lorg/apache/cassandra/utils/MerkleTrees;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.io.IOException
}
Signature: Ljava/lang/Object;Lorg/apache/cassandra/io/IVersionedSerializer<Lorg/apache/cassandra/utils/MerkleTrees;>;
SourceFile: "MerkleTrees.java"
NestHost: org.apache.cassandra.utils.MerkleTrees
InnerClasses:
  public MerkleTreeSerializer = org.apache.cassandra.utils.MerkleTree$MerkleTreeSerializer of org.apache.cassandra.utils.MerkleTree
  public MerkleTreesSerializer = org.apache.cassandra.utils.MerkleTrees$MerkleTreesSerializer of org.apache.cassandra.utils.MerkleTrees