public class org.apache.cassandra.dht.Murmur3Partitioner implements org.apache.cassandra.dht.IPartitioner
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.dht.Murmur3Partitioner
  super_class: java.lang.Object
{
  public static final org.apache.cassandra.dht.Murmur3Partitioner$LongToken MINIMUM;
    descriptor: Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final long MAXIMUM;
    descriptor: J
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 9223372036854775807

  private static final int HEAP_SIZE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  public static final org.apache.cassandra.dht.Murmur3Partitioner instance;
    descriptor: Lorg/apache/cassandra/dht/Murmur3Partitioner;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final org.apache.cassandra.db.marshal.AbstractType<?> partitionOrdering;
    descriptor: Lorg/apache/cassandra/db/marshal/AbstractType;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    Signature: Lorg/apache/cassandra/db/marshal/AbstractType<*>;

  private final org.apache.cassandra.dht.Splitter splitter;
    descriptor: Lorg/apache/cassandra/dht/Splitter;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.cassandra.dht.Token$TokenFactory tokenFactory;
    descriptor: Lorg/apache/cassandra/dht/Token$TokenFactory;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 43
            new org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            dup
            ldc -9223372036854775808
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$LongToken.<init>:(J)V
            putstatic org.apache.cassandra.dht.Murmur3Partitioner.MINIMUM:Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
         1: .line 46
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.MINIMUM:Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            invokestatic org.apache.cassandra.utils.ObjectSizes.measureDeep:(Ljava/lang/Object;)J
            l2i
            putstatic org.apache.cassandra.dht.Murmur3Partitioner.HEAP_SIZE:I
         2: .line 48
            new org.apache.cassandra.dht.Murmur3Partitioner
            dup
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner.<init>:()V
            putstatic org.apache.cassandra.dht.Murmur3Partitioner.instance:Lorg/apache/cassandra/dht/Murmur3Partitioner;
         3: .line 49
            new org.apache.cassandra.db.marshal.PartitionerDefinedOrder
            dup
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.instance:Lorg/apache/cassandra/dht/Murmur3Partitioner;
            invokespecial org.apache.cassandra.db.marshal.PartitionerDefinedOrder.<init>:(Lorg/apache/cassandra/dht/IPartitioner;)V
            putstatic org.apache.cassandra.dht.Murmur3Partitioner.partitionOrdering:Lorg/apache/cassandra/db/marshal/AbstractType;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 41
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 51
            aload 0 /* this */
            new org.apache.cassandra.dht.Murmur3Partitioner$1
            dup
            aload 0 /* this */
            aload 0 /* this */
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$1.<init>:(Lorg/apache/cassandra/dht/Murmur3Partitioner;Lorg/apache/cassandra/dht/IPartitioner;)V
            putfield org.apache.cassandra.dht.Murmur3Partitioner.splitter:Lorg/apache/cassandra/dht/Splitter;
         2: .line 295
            aload 0 /* this */
            new org.apache.cassandra.dht.Murmur3Partitioner$2
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$2.<init>:(Lorg/apache/cassandra/dht/Murmur3Partitioner;)V
            putfield org.apache.cassandra.dht.Murmur3Partitioner.tokenFactory:Lorg/apache/cassandra/dht/Token$TokenFactory;
         3: .line 41
            return
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;

  public org.apache.cassandra.db.DecoratedKey decorateKey(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/db/DecoratedKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=3, args_size=2
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // java.nio.ByteBuffer key
         0: .line 66
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getHash:(Ljava/nio/ByteBuffer;)[J
            astore 2 /* hash */
        start local 2 // long[] hash
         1: .line 67
            new org.apache.cassandra.db.PreHashedDecoratedKey
            dup
            aload 0 /* this */
            aload 1 /* key */
            aload 2 /* hash */
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getToken:(Ljava/nio/ByteBuffer;[J)Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            aload 1 /* key */
            aload 2 /* hash */
            iconst_0
            laload
            aload 2 /* hash */
            iconst_1
            laload
            invokespecial org.apache.cassandra.db.PreHashedDecoratedKey.<init>:(Lorg/apache/cassandra/dht/Token;Ljava/nio/ByteBuffer;JJ)V
            areturn
        end local 2 // long[] hash
        end local 1 // java.nio.ByteBuffer key
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0    2     1   key  Ljava/nio/ByteBuffer;
            1    2     2  hash  [J
    MethodParameters:
      Name  Flags
      key   

  public org.apache.cassandra.dht.Token midpoint(org.apache.cassandra.dht.Token, org.apache.cassandra.dht.Token);
    descriptor: (Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=8, args_size=3
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // org.apache.cassandra.dht.Token lToken
        start local 2 // org.apache.cassandra.dht.Token rToken
         0: .line 73
            aload 1 /* lToken */
            checkcast org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            astore 3 /* l */
        start local 3 // java.math.BigInteger l
         1: .line 74
            aload 2 /* rToken */
            checkcast org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            astore 4 /* r */
        start local 4 // java.math.BigInteger r
         2: .line 77
            aload 3 /* l */
            aload 4 /* r */
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            ifge 6
         3: .line 79
            aload 3 /* l */
            aload 4 /* r */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 6 /* sum */
        start local 6 // java.math.BigInteger sum
         4: .line 80
            aload 6 /* sum */
            iconst_1
            invokevirtual java.math.BigInteger.shiftRight:(I)Ljava/math/BigInteger;
            astore 5 /* midpoint */
        end local 6 // java.math.BigInteger sum
        start local 5 // java.math.BigInteger midpoint
         5: .line 81
            goto 11
        end local 5 // java.math.BigInteger midpoint
         6: .line 84
      StackMap locals: java.math.BigInteger java.math.BigInteger
      StackMap stack:
            ldc 9223372036854775807
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            astore 6 /* max */
        start local 6 // java.math.BigInteger max
         7: .line 85
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.MINIMUM:Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            astore 7 /* min */
        start local 7 // java.math.BigInteger min
         8: .line 89
            aload 6 /* max */
            aload 7 /* min */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 3 /* l */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 4 /* r */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            iconst_1
            invokevirtual java.math.BigInteger.shiftRight:(I)Ljava/math/BigInteger;
            astore 5 /* midpoint */
        start local 5 // java.math.BigInteger midpoint
         9: .line 90
            aload 5 /* midpoint */
            aload 6 /* max */
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            ifle 11
        10: .line 91
            aload 7 /* min */
            aload 5 /* midpoint */
            aload 6 /* max */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 5 /* midpoint */
        end local 7 // java.math.BigInteger min
        end local 6 // java.math.BigInteger max
        11: .line 94
      StackMap locals: java.math.BigInteger
      StackMap stack:
            new org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            dup
            aload 5 /* midpoint */
            invokevirtual java.math.BigInteger.longValue:()J
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$LongToken.<init>:(J)V
            areturn
        end local 5 // java.math.BigInteger midpoint
        end local 4 // java.math.BigInteger r
        end local 3 // java.math.BigInteger l
        end local 2 // org.apache.cassandra.dht.Token rToken
        end local 1 // org.apache.cassandra.dht.Token lToken
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   12     0      this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0   12     1    lToken  Lorg/apache/cassandra/dht/Token;
            0   12     2    rToken  Lorg/apache/cassandra/dht/Token;
            1   12     3         l  Ljava/math/BigInteger;
            2   12     4         r  Ljava/math/BigInteger;
            5    6     5  midpoint  Ljava/math/BigInteger;
            9   12     5  midpoint  Ljava/math/BigInteger;
            4    5     6       sum  Ljava/math/BigInteger;
            7   11     6       max  Ljava/math/BigInteger;
            8   11     7       min  Ljava/math/BigInteger;
    MethodParameters:
        Name  Flags
      lToken  
      rToken  

  public org.apache.cassandra.dht.Token split(org.apache.cassandra.dht.Token, org.apache.cassandra.dht.Token, double);
    descriptor: (Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/dht/Token;D)Lorg/apache/cassandra/dht/Token;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=15, args_size=4
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // org.apache.cassandra.dht.Token lToken
        start local 2 // org.apache.cassandra.dht.Token rToken
        start local 3 // double ratioToLeft
         0: .line 99
            aload 1 /* lToken */
            checkcast org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigDecimal.valueOf:(J)Ljava/math/BigDecimal;
            astore 5 /* l */
        start local 5 // java.math.BigDecimal l
         1: .line 100
            aload 2 /* rToken */
            checkcast org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigDecimal.valueOf:(J)Ljava/math/BigDecimal;
            astore 6 /* r */
        start local 6 // java.math.BigDecimal r
         2: .line 101
            dload 3 /* ratioToLeft */
            invokestatic java.math.BigDecimal.valueOf:(D)Ljava/math/BigDecimal;
            astore 7 /* ratio */
        start local 7 // java.math.BigDecimal ratio
         3: .line 104
            aload 5 /* l */
            aload 6 /* r */
            invokevirtual java.math.BigDecimal.compareTo:(Ljava/math/BigDecimal;)I
            ifge 6
         4: .line 106
            aload 6 /* r */
            aload 5 /* l */
            invokevirtual java.math.BigDecimal.subtract:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            aload 7 /* ratio */
            invokevirtual java.math.BigDecimal.multiply:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            aload 5 /* l */
            invokevirtual java.math.BigDecimal.add:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            invokevirtual java.math.BigDecimal.toBigInteger:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.longValue:()J
            lstore 8 /* newToken */
        start local 8 // long newToken
         5: .line 107
            goto 15
        end local 8 // long newToken
         6: .line 112
      StackMap locals: java.math.BigDecimal java.math.BigDecimal java.math.BigDecimal
      StackMap stack:
            ldc 9223372036854775807
            invokestatic java.math.BigDecimal.valueOf:(J)Ljava/math/BigDecimal;
            astore 10 /* max */
        start local 10 // java.math.BigDecimal max
         7: .line 113
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.MINIMUM:Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigDecimal.valueOf:(J)Ljava/math/BigDecimal;
            astore 11 /* min */
        start local 11 // java.math.BigDecimal min
         8: .line 115
            aload 10 /* max */
            aload 11 /* min */
            invokevirtual java.math.BigDecimal.subtract:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            aload 6 /* r */
            invokevirtual java.math.BigDecimal.add:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            aload 5 /* l */
            invokevirtual java.math.BigDecimal.subtract:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            aload 7 /* ratio */
            invokevirtual java.math.BigDecimal.multiply:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            aload 5 /* l */
            invokevirtual java.math.BigDecimal.add:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            invokevirtual java.math.BigDecimal.toBigInteger:()Ljava/math/BigInteger;
            astore 12 /* token */
        start local 12 // java.math.BigInteger token
         9: .line 117
            ldc 9223372036854775807
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            astore 13 /* maxToken */
        start local 13 // java.math.BigInteger maxToken
        10: .line 119
            aload 12 /* token */
            aload 13 /* maxToken */
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            ifgt 13
        11: .line 121
            aload 12 /* token */
            invokevirtual java.math.BigInteger.longValue:()J
            lstore 8 /* newToken */
        start local 8 // long newToken
        12: .line 122
            goto 15
        end local 8 // long newToken
        13: .line 126
      StackMap locals: org.apache.cassandra.dht.Murmur3Partitioner org.apache.cassandra.dht.Token org.apache.cassandra.dht.Token double java.math.BigDecimal java.math.BigDecimal java.math.BigDecimal top top java.math.BigDecimal java.math.BigDecimal java.math.BigInteger java.math.BigInteger
      StackMap stack:
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.MINIMUM:Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            astore 14 /* minToken */
        start local 14 // java.math.BigInteger minToken
        14: .line 127
            aload 14 /* minToken */
            aload 12 /* token */
            aload 13 /* maxToken */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.longValue:()J
            lstore 8 /* newToken */
        end local 14 // java.math.BigInteger minToken
        end local 13 // java.math.BigInteger maxToken
        end local 12 // java.math.BigInteger token
        end local 11 // java.math.BigDecimal min
        end local 10 // java.math.BigDecimal max
        start local 8 // long newToken
        15: .line 130
      StackMap locals: org.apache.cassandra.dht.Murmur3Partitioner org.apache.cassandra.dht.Token org.apache.cassandra.dht.Token double java.math.BigDecimal java.math.BigDecimal java.math.BigDecimal long
      StackMap stack:
            new org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            dup
            lload 8 /* newToken */
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$LongToken.<init>:(J)V
            areturn
        end local 8 // long newToken
        end local 7 // java.math.BigDecimal ratio
        end local 6 // java.math.BigDecimal r
        end local 5 // java.math.BigDecimal l
        end local 3 // double ratioToLeft
        end local 2 // org.apache.cassandra.dht.Token rToken
        end local 1 // org.apache.cassandra.dht.Token lToken
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   16     0         this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0   16     1       lToken  Lorg/apache/cassandra/dht/Token;
            0   16     2       rToken  Lorg/apache/cassandra/dht/Token;
            0   16     3  ratioToLeft  D
            1   16     5            l  Ljava/math/BigDecimal;
            2   16     6            r  Ljava/math/BigDecimal;
            3   16     7        ratio  Ljava/math/BigDecimal;
            5    6     8     newToken  J
           12   13     8     newToken  J
           15   16     8     newToken  J
            7   15    10          max  Ljava/math/BigDecimal;
            8   15    11          min  Ljava/math/BigDecimal;
            9   15    12        token  Ljava/math/BigInteger;
           10   15    13     maxToken  Ljava/math/BigInteger;
           14   15    14     minToken  Ljava/math/BigInteger;
    MethodParameters:
             Name  Flags
      lToken       
      rToken       
      ratioToLeft  

  public org.apache.cassandra.dht.Murmur3Partitioner$LongToken getMinimumToken();
    descriptor: ()Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 135
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.MINIMUM:Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            areturn
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;

  public org.apache.cassandra.dht.Murmur3Partitioner$LongToken getToken(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // java.nio.ByteBuffer key
         0: .line 216
            aload 0 /* this */
            aload 1 /* key */
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getHash:(Ljava/nio/ByteBuffer;)[J
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getToken:(Ljava/nio/ByteBuffer;[J)Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            areturn
        end local 1 // java.nio.ByteBuffer key
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0    1     1   key  Ljava/nio/ByteBuffer;
    MethodParameters:
      Name  Flags
      key   

  private org.apache.cassandra.dht.Murmur3Partitioner$LongToken getToken(java.nio.ByteBuffer, long[]);
    descriptor: (Ljava/nio/ByteBuffer;[J)Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // java.nio.ByteBuffer key
        start local 2 // long[] hash
         0: .line 221
            aload 1 /* key */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            ifne 2
         1: .line 222
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.MINIMUM:Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            areturn
         2: .line 224
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            dup
            aload 0 /* this */
            aload 2 /* hash */
            iconst_0
            laload
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.normalize:(J)J
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$LongToken.<init>:(J)V
            areturn
        end local 2 // long[] hash
        end local 1 // java.nio.ByteBuffer key
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0    3     1   key  Ljava/nio/ByteBuffer;
            0    3     2  hash  [J
    MethodParameters:
      Name  Flags
      key   
      hash  

  private long[] getHash(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)[J
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=3, args_size=2
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // java.nio.ByteBuffer key
         0: .line 229
            iconst_2
            newarray 11
            astore 2 /* hash */
        start local 2 // long[] hash
         1: .line 230
            aload 1 /* key */
            aload 1 /* key */
            invokevirtual java.nio.ByteBuffer.position:()I
            aload 1 /* key */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            lconst_0
            aload 2 /* hash */
            invokestatic org.apache.cassandra.utils.MurmurHash.hash3_x64_128:(Ljava/nio/ByteBuffer;IIJ[J)V
         2: .line 231
            aload 2 /* hash */
            areturn
        end local 2 // long[] hash
        end local 1 // java.nio.ByteBuffer key
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0    3     1   key  Ljava/nio/ByteBuffer;
            1    3     2  hash  [J
    MethodParameters:
      Name  Flags
      key   

  public org.apache.cassandra.dht.Murmur3Partitioner$LongToken getRandomToken();
    descriptor: ()Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 236
            aload 0 /* this */
            invokestatic java.util.concurrent.ThreadLocalRandom.current:()Ljava/util/concurrent/ThreadLocalRandom;
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getRandomToken:(Ljava/util/Random;)Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            areturn
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;

  public org.apache.cassandra.dht.Murmur3Partitioner$LongToken getRandomToken(java.util.Random);
    descriptor: (Ljava/util/Random;)Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // java.util.Random r
         0: .line 241
            new org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            dup
            aload 0 /* this */
            aload 1 /* r */
            invokevirtual java.util.Random.nextLong:()J
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.normalize:(J)J
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$LongToken.<init>:(J)V
            areturn
        end local 1 // java.util.Random r
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0    1     1     r  Ljava/util/Random;
    MethodParameters:
      Name  Flags
      r     

  private long normalize(long);
    descriptor: (J)J
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // long v
         0: .line 247
            lload 1 /* v */
            ldc -9223372036854775808
            lcmp
            ifne 1
            ldc 9223372036854775807
            goto 2
      StackMap locals:
      StackMap stack:
         1: lload 1 /* v */
      StackMap locals:
      StackMap stack: long
         2: lreturn
        end local 1 // long v
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0    3     1     v  J
    MethodParameters:
      Name  Flags
      v     

  public boolean preservesOrder();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 252
            iconst_0
            ireturn
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;

  public java.util.Map<org.apache.cassandra.dht.Token, java.lang.Float> describeOwnership(java.util.List<org.apache.cassandra.dht.Token>);
    descriptor: (Ljava/util/List;)Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=11, args_size=2
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
        start local 1 // java.util.List sortedTokens
         0: .line 257
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 2 /* ownerships */
        start local 2 // java.util.Map ownerships
         1: .line 258
            aload 1 /* sortedTokens */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3 /* i */
        start local 3 // java.util.Iterator i
         2: .line 261
            aload 3 /* i */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         3: .line 262
            new java.lang.RuntimeException
            dup
            ldc "No nodes present in the cluster. Has this node finished starting up?"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 264
      StackMap locals: java.util.Map java.util.Iterator
      StackMap stack:
            aload 1 /* sortedTokens */
            invokeinterface java.util.List.size:()I
            iconst_1
            if_icmpne 6
         5: .line 265
            aload 2 /* ownerships */
            aload 3 /* i */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            new java.lang.Float
            dup
            dconst_1
            invokespecial java.lang.Float.<init>:(D)V
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
            goto 20
         6: .line 269
      StackMap locals:
      StackMap stack:
            ldc 9223372036854775807
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.MINIMUM:Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            lconst_1
            ladd
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 4 /* ri */
        start local 4 // java.math.BigInteger ri
         7: .line 270
            new java.math.BigDecimal
            dup
            aload 4 /* ri */
            invokespecial java.math.BigDecimal.<init>:(Ljava/math/BigInteger;)V
            astore 5 /* r */
        start local 5 // java.math.BigDecimal r
         8: .line 271
            aload 3 /* i */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 6 /* start */
        start local 6 // org.apache.cassandra.dht.Token start
         9: aload 6 /* start */
            checkcast org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            astore 7 /* ti */
        start local 7 // java.math.BigInteger ti
        10: .line 272
            aload 7 /* ti */
            astore 9 /* tim1 */
        start local 9 // java.math.BigInteger tim1
        11: .line 274
            goto 17
        12: .line 276
      StackMap locals: org.apache.cassandra.dht.Murmur3Partitioner java.util.List java.util.Map java.util.Iterator java.math.BigInteger java.math.BigDecimal org.apache.cassandra.dht.Token java.math.BigInteger top java.math.BigInteger
      StackMap stack:
            aload 3 /* i */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Token
            astore 8 /* t */
        start local 8 // org.apache.cassandra.dht.Token t
        13: aload 8 /* t */
            checkcast org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            astore 7 /* ti */
        14: .line 277
            new java.math.BigDecimal
            dup
            aload 7 /* ti */
            aload 9 /* tim1 */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 4 /* ri */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 4 /* ri */
            invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokespecial java.math.BigDecimal.<init>:(Ljava/math/BigInteger;)V
            aload 5 /* r */
            bipush 6
            bipush 6
            invokevirtual java.math.BigDecimal.divide:(Ljava/math/BigDecimal;II)Ljava/math/BigDecimal;
            invokevirtual java.math.BigDecimal.floatValue:()F
            fstore 10 /* age */
        start local 10 // float age
        15: .line 278
            aload 2 /* ownerships */
            aload 8 /* t */
            fload 10 /* age */
            invokestatic java.lang.Float.valueOf:(F)Ljava/lang/Float;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        16: .line 279
            aload 7 /* ti */
            astore 9 /* tim1 */
        end local 10 // float age
        end local 8 // org.apache.cassandra.dht.Token t
        17: .line 274
      StackMap locals:
      StackMap stack:
            aload 3 /* i */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        18: .line 283
            new java.math.BigDecimal
            dup
            aload 6 /* start */
            checkcast org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            getfield org.apache.cassandra.dht.Murmur3Partitioner$LongToken.token:J
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            aload 7 /* ti */
            invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 4 /* ri */
            invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            aload 4 /* ri */
            invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            invokespecial java.math.BigDecimal.<init>:(Ljava/math/BigInteger;)V
            aload 5 /* r */
            bipush 6
            bipush 6
            invokevirtual java.math.BigDecimal.divide:(Ljava/math/BigDecimal;II)Ljava/math/BigDecimal;
            invokevirtual java.math.BigDecimal.floatValue:()F
            fstore 10 /* x */
        start local 10 // float x
        19: .line 284
            aload 2 /* ownerships */
            aload 6 /* start */
            fload 10 /* x */
            invokestatic java.lang.Float.valueOf:(F)Ljava/lang/Float;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 10 // float x
        end local 9 // java.math.BigInteger tim1
        end local 7 // java.math.BigInteger ti
        end local 6 // org.apache.cassandra.dht.Token start
        end local 5 // java.math.BigDecimal r
        end local 4 // java.math.BigInteger ri
        20: .line 287
      StackMap locals: org.apache.cassandra.dht.Murmur3Partitioner java.util.List java.util.Map java.util.Iterator
      StackMap stack:
            aload 2 /* ownerships */
            areturn
        end local 3 // java.util.Iterator i
        end local 2 // java.util.Map ownerships
        end local 1 // java.util.List sortedTokens
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   21     0          this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
            0   21     1  sortedTokens  Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
            1   21     2    ownerships  Ljava/util/Map<Lorg/apache/cassandra/dht/Token;Ljava/lang/Float;>;
            2   21     3             i  Ljava/util/Iterator<Lorg/apache/cassandra/dht/Token;>;
            7   20     4            ri  Ljava/math/BigInteger;
            8   20     5             r  Ljava/math/BigDecimal;
            9   20     6         start  Lorg/apache/cassandra/dht/Token;
           10   20     7            ti  Ljava/math/BigInteger;
           13   17     8             t  Lorg/apache/cassandra/dht/Token;
           11   20     9          tim1  Ljava/math/BigInteger;
           15   17    10           age  F
           19   20    10             x  F
    Signature: (Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;)Ljava/util/Map<Lorg/apache/cassandra/dht/Token;Ljava/lang/Float;>;
    MethodParameters:
              Name  Flags
      sortedTokens  

  public org.apache.cassandra.dht.Token$TokenFactory getTokenFactory();
    descriptor: ()Lorg/apache/cassandra/dht/Token$TokenFactory;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 292
            aload 0 /* this */
            getfield org.apache.cassandra.dht.Murmur3Partitioner.tokenFactory:Lorg/apache/cassandra/dht/Token$TokenFactory;
            areturn
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;

  public org.apache.cassandra.db.marshal.AbstractType<?> getTokenValidator();
    descriptor: ()Lorg/apache/cassandra/db/marshal/AbstractType;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 340
            getstatic org.apache.cassandra.db.marshal.LongType.instance:Lorg/apache/cassandra/db/marshal/LongType;
            areturn
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
    Signature: ()Lorg/apache/cassandra/db/marshal/AbstractType<*>;

  public org.apache.cassandra.dht.Token getMaximumToken();
    descriptor: ()Lorg/apache/cassandra/dht/Token;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 345
            new org.apache.cassandra.dht.Murmur3Partitioner$LongToken
            dup
            ldc 9223372036854775807
            invokespecial org.apache.cassandra.dht.Murmur3Partitioner$LongToken.<init>:(J)V
            areturn
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;

  public org.apache.cassandra.db.marshal.AbstractType<?> partitionOrdering();
    descriptor: ()Lorg/apache/cassandra/db/marshal/AbstractType;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 350
            getstatic org.apache.cassandra.dht.Murmur3Partitioner.partitionOrdering:Lorg/apache/cassandra/db/marshal/AbstractType;
            areturn
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
    Signature: ()Lorg/apache/cassandra/db/marshal/AbstractType<*>;

  public java.util.Optional<org.apache.cassandra.dht.Splitter> splitter();
    descriptor: ()Ljava/util/Optional;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
         0: .line 355
            aload 0 /* this */
            getfield org.apache.cassandra.dht.Murmur3Partitioner.splitter:Lorg/apache/cassandra/dht/Splitter;
            invokestatic java.util.Optional.of:(Ljava/lang/Object;)Ljava/util/Optional;
            areturn
        end local 0 // org.apache.cassandra.dht.Murmur3Partitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/Murmur3Partitioner;
    Signature: ()Ljava/util/Optional<Lorg/apache/cassandra/dht/Splitter;>;

  public org.apache.cassandra.dht.Token getToken(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/Token;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getToken:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public org.apache.cassandra.dht.Token getRandomToken(java.util.Random);
    descriptor: (Ljava/util/Random;)Lorg/apache/cassandra/dht/Token;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getRandomToken:(Ljava/util/Random;)Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public org.apache.cassandra.dht.Token getRandomToken();
    descriptor: ()Lorg/apache/cassandra/dht/Token;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getRandomToken:()Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public org.apache.cassandra.dht.Token getMinimumToken();
    descriptor: ()Lorg/apache/cassandra/dht/Token;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.apache.cassandra.dht.Murmur3Partitioner.getMinimumToken:()Lorg/apache/cassandra/dht/Murmur3Partitioner$LongToken;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "Murmur3Partitioner.java"
NestMembers:
  org.apache.cassandra.dht.Murmur3Partitioner$1  org.apache.cassandra.dht.Murmur3Partitioner$2  org.apache.cassandra.dht.Murmur3Partitioner$LongToken
InnerClasses:
  org.apache.cassandra.dht.Murmur3Partitioner$1
  org.apache.cassandra.dht.Murmur3Partitioner$2
  public LongToken = org.apache.cassandra.dht.Murmur3Partitioner$LongToken of org.apache.cassandra.dht.Murmur3Partitioner
  public abstract TokenFactory = org.apache.cassandra.dht.Token$TokenFactory of org.apache.cassandra.dht.Token