public class org.apache.cassandra.dht.RandomPartitioner 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.RandomPartitioner
  super_class: java.lang.Object
{
  public static final java.math.BigInteger ZERO;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken MINIMUM;
    descriptor: Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final java.math.BigInteger MAXIMUM;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  private static final java.lang.ThreadLocal<java.security.MessageDigest> localMD5Digest;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Ljava/security/MessageDigest;>;

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

  public static final org.apache.cassandra.dht.RandomPartitioner instance;
    descriptor: Lorg/apache/cassandra/dht/RandomPartitioner;
    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 final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 43
            ldc Lorg/apache/cassandra/dht/RandomPartitioner;
            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.dht.RandomPartitioner.$assertionsDisabled:Z
         3: .line 45
            new java.math.BigInteger
            dup
            ldc "0"
            invokespecial java.math.BigInteger.<init>:(Ljava/lang/String;)V
            putstatic org.apache.cassandra.dht.RandomPartitioner.ZERO:Ljava/math/BigInteger;
         4: .line 46
            new org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            dup
            ldc "-1"
            invokespecial org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.<init>:(Ljava/lang/String;)V
            putstatic org.apache.cassandra.dht.RandomPartitioner.MINIMUM:Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
         5: .line 47
            new java.math.BigInteger
            dup
            ldc "2"
            invokespecial java.math.BigInteger.<init>:(Ljava/lang/String;)V
            bipush 127
            invokevirtual java.math.BigInteger.pow:(I)Ljava/math/BigInteger;
            putstatic org.apache.cassandra.dht.RandomPartitioner.MAXIMUM:Ljava/math/BigInteger;
         6: .line 55
            new org.apache.cassandra.dht.RandomPartitioner$1
            dup
            invokespecial org.apache.cassandra.dht.RandomPartitioner$1.<init>:()V
            putstatic org.apache.cassandra.dht.RandomPartitioner.localMD5Digest:Ljava/lang/ThreadLocal;
         7: .line 72
            new org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            dup
            iconst_1
            invokestatic java.nio.ByteBuffer.allocate:(I)Ljava/nio/ByteBuffer;
            invokestatic org.apache.cassandra.dht.RandomPartitioner.hashToBigInteger:(Ljava/nio/ByteBuffer;)Ljava/math/BigInteger;
            invokespecial org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.<init>:(Ljava/math/BigInteger;)V
            invokestatic org.apache.cassandra.utils.ObjectSizes.measureDeep:(Ljava/lang/Object;)J
            l2i
            putstatic org.apache.cassandra.dht.RandomPartitioner.HEAP_SIZE:I
         8: .line 74
            new org.apache.cassandra.dht.RandomPartitioner
            dup
            invokespecial org.apache.cassandra.dht.RandomPartitioner.<init>:()V
            putstatic org.apache.cassandra.dht.RandomPartitioner.instance:Lorg/apache/cassandra/dht/RandomPartitioner;
         9: .line 75
            new org.apache.cassandra.db.marshal.PartitionerDefinedOrder
            dup
            getstatic org.apache.cassandra.dht.RandomPartitioner.instance:Lorg/apache/cassandra/dht/RandomPartitioner;
            invokespecial org.apache.cassandra.db.marshal.PartitionerDefinedOrder.<init>:(Lorg/apache/cassandra/dht/IPartitioner;)V
            putstatic org.apache.cassandra.dht.RandomPartitioner.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.RandomPartitioner this
         0: .line 43
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 77
            aload 0 /* this */
            new org.apache.cassandra.dht.RandomPartitioner$2
            dup
            aload 0 /* this */
            aload 0 /* this */
            invokespecial org.apache.cassandra.dht.RandomPartitioner$2.<init>:(Lorg/apache/cassandra/dht/RandomPartitioner;Lorg/apache/cassandra/dht/IPartitioner;)V
            putfield org.apache.cassandra.dht.RandomPartitioner.splitter:Lorg/apache/cassandra/dht/Splitter;
         2: .line 156
            aload 0 /* this */
            new org.apache.cassandra.dht.RandomPartitioner$3
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.dht.RandomPartitioner$3.<init>:(Lorg/apache/cassandra/dht/RandomPartitioner;)V
            putfield org.apache.cassandra.dht.RandomPartitioner.tokenFactory:Lorg/apache/cassandra/dht/Token$TokenFactory;
         3: .line 43
            return
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/dht/RandomPartitioner;

  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=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.dht.RandomPartitioner this
        start local 1 // java.nio.ByteBuffer key
         0: .line 92
            new org.apache.cassandra.db.CachedHashDecoratedKey
            dup
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual org.apache.cassandra.dht.RandomPartitioner.getToken:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            aload 1 /* key */
            invokespecial org.apache.cassandra.db.CachedHashDecoratedKey.<init>:(Lorg/apache/cassandra/dht/Token;Ljava/nio/ByteBuffer;)V
            areturn
        end local 1 // java.nio.ByteBuffer key
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/RandomPartitioner;
            0    1     1   key  Ljava/nio/ByteBuffer;
    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=3, locals=6, args_size=3
        start local 0 // org.apache.cassandra.dht.RandomPartitioner this
        start local 1 // org.apache.cassandra.dht.Token ltoken
        start local 2 // org.apache.cassandra.dht.Token rtoken
         0: .line 98
            aload 1 /* ltoken */
            getstatic org.apache.cassandra.dht.RandomPartitioner.MINIMUM:Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 1
            getstatic org.apache.cassandra.dht.RandomPartitioner.ZERO:Ljava/math/BigInteger;
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 1 /* ltoken */
            checkcast org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            getfield org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.token:Ljava/lang/Comparable;
            checkcast java.math.BigInteger
      StackMap locals:
      StackMap stack: java.math.BigInteger
         2: astore 3 /* left */
        start local 3 // java.math.BigInteger left
         3: .line 99
            aload 2 /* rtoken */
            getstatic org.apache.cassandra.dht.RandomPartitioner.MINIMUM:Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 4
            getstatic org.apache.cassandra.dht.RandomPartitioner.ZERO:Ljava/math/BigInteger;
            goto 5
      StackMap locals: java.math.BigInteger
      StackMap stack:
         4: aload 2 /* rtoken */
            checkcast org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            getfield org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.token:Ljava/lang/Comparable;
            checkcast java.math.BigInteger
      StackMap locals:
      StackMap stack: java.math.BigInteger
         5: astore 4 /* right */
        start local 4 // java.math.BigInteger right
         6: .line 100
            aload 3 /* left */
            aload 4 /* right */
            bipush 127
            invokestatic org.apache.cassandra.utils.FBUtilities.midpoint:(Ljava/math/BigInteger;Ljava/math/BigInteger;I)Lorg/apache/cassandra/utils/Pair;
            astore 5 /* midpair */
        start local 5 // org.apache.cassandra.utils.Pair midpair
         7: .line 102
            new org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            dup
            aload 5 /* midpair */
            getfield org.apache.cassandra.utils.Pair.left:Ljava/lang/Object;
            checkcast java.math.BigInteger
            invokespecial org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.<init>:(Ljava/math/BigInteger;)V
            areturn
        end local 5 // org.apache.cassandra.utils.Pair midpair
        end local 4 // java.math.BigInteger right
        end local 3 // java.math.BigInteger left
        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.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0     this  Lorg/apache/cassandra/dht/RandomPartitioner;
            0    8     1   ltoken  Lorg/apache/cassandra/dht/Token;
            0    8     2   rtoken  Lorg/apache/cassandra/dht/Token;
            3    8     3     left  Ljava/math/BigInteger;
            6    8     4    right  Ljava/math/BigInteger;
            7    8     5  midpair  Lorg/apache/cassandra/utils/Pair<Ljava/math/BigInteger;Ljava/lang/Boolean;>;
    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=3, locals=10, args_size=4
        start local 0 // org.apache.cassandra.dht.RandomPartitioner 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 107
            aload 1 /* ltoken */
            getstatic org.apache.cassandra.dht.RandomPartitioner.MINIMUM:Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 1
            getstatic java.math.BigDecimal.ZERO:Ljava/math/BigDecimal;
            goto 2
      StackMap locals:
      StackMap stack:
         1: new java.math.BigDecimal
            dup
            aload 1 /* ltoken */
            checkcast org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            getfield org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.token:Ljava/lang/Comparable;
            checkcast java.math.BigInteger
            invokespecial java.math.BigDecimal.<init>:(Ljava/math/BigInteger;)V
      StackMap locals:
      StackMap stack: java.math.BigDecimal
         2: astore 5 /* left */
        start local 5 // java.math.BigDecimal left
         3: .line 108
            aload 2 /* rtoken */
            getstatic org.apache.cassandra.dht.RandomPartitioner.MINIMUM:Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 4
            getstatic java.math.BigDecimal.ZERO:Ljava/math/BigDecimal;
            goto 5
      StackMap locals: java.math.BigDecimal
      StackMap stack:
         4: new java.math.BigDecimal
            dup
            aload 2 /* rtoken */
            checkcast org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            getfield org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.token:Ljava/lang/Comparable;
            checkcast java.math.BigInteger
            invokespecial java.math.BigDecimal.<init>:(Ljava/math/BigInteger;)V
      StackMap locals:
      StackMap stack: java.math.BigDecimal
         5: astore 6 /* right */
        start local 6 // java.math.BigDecimal right
         6: .line 109
            dload 3 /* ratioToLeft */
            invokestatic java.math.BigDecimal.valueOf:(D)Ljava/math/BigDecimal;
            astore 7 /* ratio */
        start local 7 // java.math.BigDecimal ratio
         7: .line 113
            aload 5 /* left */
            aload 6 /* right */
            invokevirtual java.math.BigDecimal.compareTo:(Ljava/math/BigDecimal;)I
            ifge 10
         8: .line 115
            aload 6 /* right */
            aload 5 /* left */
            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 /* left */
            invokevirtual java.math.BigDecimal.add:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            invokevirtual java.math.BigDecimal.toBigInteger:()Ljava/math/BigInteger;
            astore 8 /* newToken */
        start local 8 // java.math.BigInteger newToken
         9: .line 116
            goto 12
        end local 8 // java.math.BigInteger newToken
        10: .line 121
      StackMap locals: java.math.BigDecimal java.math.BigDecimal
      StackMap stack:
            new java.math.BigDecimal
            dup
            getstatic org.apache.cassandra.dht.RandomPartitioner.MAXIMUM:Ljava/math/BigInteger;
            invokespecial java.math.BigDecimal.<init>:(Ljava/math/BigInteger;)V
            astore 9 /* max */
        start local 9 // java.math.BigDecimal max
        11: .line 123
            aload 9 /* max */
            aload 6 /* right */
            invokevirtual java.math.BigDecimal.add:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            aload 5 /* left */
            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 /* left */
            invokevirtual java.math.BigDecimal.add:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            invokevirtual java.math.BigDecimal.toBigInteger:()Ljava/math/BigInteger;
            getstatic org.apache.cassandra.dht.RandomPartitioner.MAXIMUM:Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 8 /* newToken */
        end local 9 // java.math.BigDecimal max
        start local 8 // java.math.BigInteger newToken
        12: .line 126
      StackMap locals: java.math.BigInteger
      StackMap stack:
            getstatic org.apache.cassandra.dht.RandomPartitioner.$assertionsDisabled:Z
            ifne 13
            aload 0 /* this */
            aload 8 /* newToken */
            invokevirtual org.apache.cassandra.dht.RandomPartitioner.isValidToken:(Ljava/math/BigInteger;)Z
            ifne 13
            new java.lang.AssertionError
            dup
            ldc "Invalid tokens from split"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        13: .line 128
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            dup
            aload 8 /* newToken */
            invokespecial org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.<init>:(Ljava/math/BigInteger;)V
            areturn
        end local 8 // java.math.BigInteger newToken
        end local 7 // java.math.BigDecimal ratio
        end local 6 // java.math.BigDecimal right
        end local 5 // java.math.BigDecimal left
        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.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   14     0         this  Lorg/apache/cassandra/dht/RandomPartitioner;
            0   14     1       ltoken  Lorg/apache/cassandra/dht/Token;
            0   14     2       rtoken  Lorg/apache/cassandra/dht/Token;
            0   14     3  ratioToLeft  D
            3   14     5         left  Ljava/math/BigDecimal;
            6   14     6        right  Ljava/math/BigDecimal;
            7   14     7        ratio  Ljava/math/BigDecimal;
            9   10     8     newToken  Ljava/math/BigInteger;
           12   14     8     newToken  Ljava/math/BigInteger;
           11   12     9          max  Ljava/math/BigDecimal;
    MethodParameters:
             Name  Flags
      ltoken       
      rtoken       
      ratioToLeft  

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

  public org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken getRandomToken();
    descriptor: ()Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.apache.cassandra.dht.RandomPartitioner this
         0: .line 138
            invokestatic org.apache.cassandra.utils.GuidGenerator.guidAsBytes:()Ljava/nio/ByteBuffer;
            invokestatic org.apache.cassandra.dht.RandomPartitioner.hashToBigInteger:(Ljava/nio/ByteBuffer;)Ljava/math/BigInteger;
            astore 1 /* token */
        start local 1 // java.math.BigInteger token
         1: .line 139
            aload 1 /* token */
            invokevirtual java.math.BigInteger.signum:()I
            iconst_m1
            if_icmpne 3
         2: .line 140
            aload 1 /* token */
            ldc -1
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 1 /* token */
         3: .line 141
      StackMap locals: java.math.BigInteger
      StackMap stack:
            new org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            dup
            aload 1 /* token */
            invokespecial org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.<init>:(Ljava/math/BigInteger;)V
            areturn
        end local 1 // java.math.BigInteger token
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/apache/cassandra/dht/RandomPartitioner;
            1    4     1  token  Ljava/math/BigInteger;

  public org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken getRandomToken(java.util.Random);
    descriptor: (Ljava/util/Random;)Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // org.apache.cassandra.dht.RandomPartitioner this
        start local 1 // java.util.Random random
         0: .line 146
            aload 1 /* random */
            ldc "host/127.0.0.1"
            lconst_0
            invokestatic org.apache.cassandra.utils.GuidGenerator.guidAsBytes:(Ljava/util/Random;Ljava/lang/String;J)Ljava/nio/ByteBuffer;
            invokestatic org.apache.cassandra.dht.RandomPartitioner.hashToBigInteger:(Ljava/nio/ByteBuffer;)Ljava/math/BigInteger;
            astore 2 /* token */
        start local 2 // java.math.BigInteger token
         1: .line 147
            aload 2 /* token */
            invokevirtual java.math.BigInteger.signum:()I
            iconst_m1
            if_icmpne 3
         2: .line 148
            aload 2 /* token */
            ldc -1
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
            astore 2 /* token */
         3: .line 149
      StackMap locals: java.math.BigInteger
      StackMap stack:
            new org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            dup
            aload 2 /* token */
            invokespecial org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.<init>:(Ljava/math/BigInteger;)V
            areturn
        end local 2 // java.math.BigInteger token
        end local 1 // java.util.Random random
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/apache/cassandra/dht/RandomPartitioner;
            0    4     1  random  Ljava/util/Random;
            1    4     2   token  Ljava/math/BigInteger;
    MethodParameters:
        Name  Flags
      random  

  private boolean isValidToken(java.math.BigInteger);
    descriptor: (Ljava/math/BigInteger;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.dht.RandomPartitioner this
        start local 1 // java.math.BigInteger token
         0: .line 153
            aload 1 /* token */
            getstatic org.apache.cassandra.dht.RandomPartitioner.ZERO:Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            iflt 1
            aload 1 /* token */
            getstatic org.apache.cassandra.dht.RandomPartitioner.MAXIMUM:Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            ifgt 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // java.math.BigInteger token
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lorg/apache/cassandra/dht/RandomPartitioner;
            0    2     1  token  Ljava/math/BigInteger;
    MethodParameters:
       Name  Flags
      token  

  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.RandomPartitioner this
         0: .line 196
            aload 0 /* this */
            getfield org.apache.cassandra.dht.RandomPartitioner.tokenFactory:Lorg/apache/cassandra/dht/Token$TokenFactory;
            areturn
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/RandomPartitioner;

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

  public org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken getToken(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.dht.RandomPartitioner this
        start local 1 // java.nio.ByteBuffer key
         0: .line 248
            aload 1 /* key */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            ifne 2
         1: .line 249
            getstatic org.apache.cassandra.dht.RandomPartitioner.MINIMUM:Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            areturn
         2: .line 251
      StackMap locals:
      StackMap stack:
            new org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            dup
            aload 1 /* key */
            invokestatic org.apache.cassandra.dht.RandomPartitioner.hashToBigInteger:(Ljava/nio/ByteBuffer;)Ljava/math/BigInteger;
            invokespecial org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.<init>:(Ljava/math/BigInteger;)V
            areturn
        end local 1 // java.nio.ByteBuffer key
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/dht/RandomPartitioner;
            0    3     1   key  Ljava/nio/ByteBuffer;
    MethodParameters:
      Name  Flags
      key   

  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.RandomPartitioner this
        start local 1 // java.util.List sortedTokens
         0: .line 256
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 2 /* ownerships */
        start local 2 // java.util.Map ownerships
         1: .line 257
            aload 1 /* sortedTokens */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3 /* i */
        start local 3 // java.util.Iterator i
         2: .line 260
            aload 3 /* i */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
            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
         3: .line 262
      StackMap locals: java.util.Map java.util.Iterator
      StackMap stack:
            aload 1 /* sortedTokens */
            invokeinterface java.util.List.size:()I
            iconst_1
            if_icmpne 6
         4: .line 264
            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
         5: .line 265
            goto 20
         6: .line 270
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.dht.RandomPartitioner.MAXIMUM:Ljava/math/BigInteger;
            astore 4 /* ri */
        start local 4 // java.math.BigInteger ri
         7: .line 271
            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 272
            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.RandomPartitioner$BigIntegerToken
            getfield org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.token:Ljava/lang/Comparable;
            checkcast java.math.BigInteger
            astore 7 /* ti */
        start local 7 // java.math.BigInteger ti
        10: .line 273
            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.RandomPartitioner 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.RandomPartitioner$BigIntegerToken
            getfield org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.token:Ljava/lang/Comparable;
            checkcast java.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 */
            invokevirtual java.math.BigDecimal.divide:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            invokevirtual java.math.BigDecimal.floatValue:()F
            fstore 10 /* x */
        start local 10 // float x
        15: .line 278
            aload 2 /* ownerships */
            aload 8 /* t */
            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
        16: .line 279
            aload 7 /* ti */
            astore 9 /* tim1 */
        end local 10 // float x
        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 282
            new java.math.BigDecimal
            dup
            aload 6 /* start */
            checkcast org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            getfield org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.token:Ljava/lang/Comparable;
            checkcast java.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 */
            invokevirtual java.math.BigDecimal.divide:(Ljava/math/BigDecimal;)Ljava/math/BigDecimal;
            invokevirtual java.math.BigDecimal.floatValue:()F
            fstore 10 /* x */
        start local 10 // float x
        19: .line 283
            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 285
      StackMap locals: org.apache.cassandra.dht.RandomPartitioner 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.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   21     0          this  Lorg/apache/cassandra/dht/RandomPartitioner;
            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             x  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 getMaximumToken();
    descriptor: ()Lorg/apache/cassandra/dht/Token;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.RandomPartitioner this
         0: .line 290
            new org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
            dup
            getstatic org.apache.cassandra.dht.RandomPartitioner.MAXIMUM:Ljava/math/BigInteger;
            invokespecial org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken.<init>:(Ljava/math/BigInteger;)V
            areturn
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/RandomPartitioner;

  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.RandomPartitioner this
         0: .line 295
            getstatic org.apache.cassandra.db.marshal.IntegerType.instance:Lorg/apache/cassandra/db/marshal/IntegerType;
            areturn
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/RandomPartitioner;
    Signature: ()Lorg/apache/cassandra/db/marshal/AbstractType<*>;

  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.RandomPartitioner this
         0: .line 300
            getstatic org.apache.cassandra.dht.RandomPartitioner.partitionOrdering:Lorg/apache/cassandra/db/marshal/AbstractType;
            areturn
        end local 0 // org.apache.cassandra.dht.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/RandomPartitioner;
    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.RandomPartitioner this
         0: .line 305
            aload 0 /* this */
            getfield org.apache.cassandra.dht.RandomPartitioner.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.RandomPartitioner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/dht/RandomPartitioner;
    Signature: ()Ljava/util/Optional<Lorg/apache/cassandra/dht/Splitter;>;

  private static java.math.BigInteger hashToBigInteger(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)Ljava/math/BigInteger;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // java.nio.ByteBuffer data
         0: .line 310
            getstatic org.apache.cassandra.dht.RandomPartitioner.localMD5Digest:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.security.MessageDigest
            astore 1 /* messageDigest */
        start local 1 // java.security.MessageDigest messageDigest
         1: .line 311
            aload 0 /* data */
            invokevirtual java.nio.ByteBuffer.hasArray:()Z
            ifeq 3
         2: .line 312
            aload 1 /* messageDigest */
            aload 0 /* data */
            invokevirtual java.nio.ByteBuffer.array:()[B
            aload 0 /* data */
            invokevirtual java.nio.ByteBuffer.arrayOffset:()I
            aload 0 /* data */
            invokevirtual java.nio.ByteBuffer.position:()I
            iadd
            aload 0 /* data */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            invokevirtual java.security.MessageDigest.update:([BII)V
            goto 4
         3: .line 314
      StackMap locals: java.security.MessageDigest
      StackMap stack:
            aload 1 /* messageDigest */
            aload 0 /* data */
            invokevirtual java.nio.ByteBuffer.duplicate:()Ljava/nio/ByteBuffer;
            invokevirtual java.security.MessageDigest.update:(Ljava/nio/ByteBuffer;)V
         4: .line 316
      StackMap locals:
      StackMap stack:
            new java.math.BigInteger
            dup
            aload 1 /* messageDigest */
            invokevirtual java.security.MessageDigest.digest:()[B
            invokespecial java.math.BigInteger.<init>:([B)V
            invokevirtual java.math.BigInteger.abs:()Ljava/math/BigInteger;
            areturn
        end local 1 // java.security.MessageDigest messageDigest
        end local 0 // java.nio.ByteBuffer data
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    5     0           data  Ljava/nio/ByteBuffer;
            1    5     1  messageDigest  Ljava/security/MessageDigest;
    MethodParameters:
      Name  Flags
      data  

  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.RandomPartitioner.getToken:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            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.RandomPartitioner.getRandomToken:(Ljava/util/Random;)Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            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.RandomPartitioner.getRandomToken:()Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            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.RandomPartitioner.getMinimumToken:()Lorg/apache/cassandra/dht/RandomPartitioner$BigIntegerToken;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "RandomPartitioner.java"
NestMembers:
  org.apache.cassandra.dht.RandomPartitioner$1  org.apache.cassandra.dht.RandomPartitioner$2  org.apache.cassandra.dht.RandomPartitioner$3  org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken
InnerClasses:
  org.apache.cassandra.dht.RandomPartitioner$1
  org.apache.cassandra.dht.RandomPartitioner$2
  org.apache.cassandra.dht.RandomPartitioner$3
  public BigIntegerToken = org.apache.cassandra.dht.RandomPartitioner$BigIntegerToken of org.apache.cassandra.dht.RandomPartitioner
  public abstract TokenFactory = org.apache.cassandra.dht.Token$TokenFactory of org.apache.cassandra.dht.Token