public class org.apache.cassandra.dht.OrderPreservingPartitioner 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.OrderPreservingPartitioner
super_class: java.lang.Object
{
private static final java.lang.String rndchars;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
public static final org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken MINIMUM;
descriptor: Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
public static final java.math.BigInteger CHAR_MASK;
descriptor: Ljava/math/BigInteger;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
private static final long EMPTY_SIZE;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
public static final org.apache.cassandra.dht.OrderPreservingPartitioner instance;
descriptor: Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, 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: ldc Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
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.OrderPreservingPartitioner.$assertionsDisabled:Z
3: new org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
dup
ldc ""
invokespecial org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken.<init>:(Ljava/lang/String;)V
putstatic org.apache.cassandra.dht.OrderPreservingPartitioner.MINIMUM:Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
4: new java.math.BigInteger
dup
ldc "65535"
invokespecial java.math.BigInteger.<init>:(Ljava/lang/String;)V
putstatic org.apache.cassandra.dht.OrderPreservingPartitioner.CHAR_MASK:Ljava/math/BigInteger;
5: getstatic org.apache.cassandra.dht.OrderPreservingPartitioner.MINIMUM:Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
invokestatic org.apache.cassandra.utils.ObjectSizes.measure:(Ljava/lang/Object;)J
putstatic org.apache.cassandra.dht.OrderPreservingPartitioner.EMPTY_SIZE:J
6: new org.apache.cassandra.dht.OrderPreservingPartitioner
dup
invokespecial org.apache.cassandra.dht.OrderPreservingPartitioner.<init>:()V
putstatic org.apache.cassandra.dht.OrderPreservingPartitioner.instance:Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new org.apache.cassandra.dht.OrderPreservingPartitioner$1
dup
aload 0
invokespecial org.apache.cassandra.dht.OrderPreservingPartitioner$1.<init>:(Lorg/apache/cassandra/dht/OrderPreservingPartitioner;)V
putfield org.apache.cassandra.dht.OrderPreservingPartitioner.tokenFactory:Lorg/apache/cassandra/dht/Token$TokenFactory;
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
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 start local 1 0: new org.apache.cassandra.db.CachedHashDecoratedKey
dup
aload 0
aload 1
invokevirtual org.apache.cassandra.dht.OrderPreservingPartitioner.getToken:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
aload 1
invokespecial org.apache.cassandra.db.CachedHashDecoratedKey.<init>:(Lorg/apache/cassandra/dht/Token;Ljava/nio/ByteBuffer;)V
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
0 1 1 key Ljava/nio/ByteBuffer;
MethodParameters:
Name Flags
key
public org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken 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/OrderPreservingPartitioner$StringToken;
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=7, args_size=3
start local 0 start local 1 start local 2 0: aload 1
checkcast org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
getfield org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken.token:Ljava/lang/Comparable;
checkcast java.lang.String
invokevirtual java.lang.String.length:()I
aload 2
checkcast org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
getfield org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken.token:Ljava/lang/Comparable;
checkcast java.lang.String
invokevirtual java.lang.String.length:()I
invokestatic java.lang.Math.max:(II)I
istore 3
start local 3 1: aload 1
checkcast org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
getfield org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken.token:Ljava/lang/Comparable;
checkcast java.lang.String
iload 3
invokestatic org.apache.cassandra.dht.OrderPreservingPartitioner.bigForString:(Ljava/lang/String;I)Ljava/math/BigInteger;
astore 4
start local 4 2: aload 2
checkcast org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
getfield org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken.token:Ljava/lang/Comparable;
checkcast java.lang.String
iload 3
invokestatic org.apache.cassandra.dht.OrderPreservingPartitioner.bigForString:(Ljava/lang/String;I)Ljava/math/BigInteger;
astore 5
start local 5 3: aload 4
aload 5
bipush 16
iload 3
imul
invokestatic org.apache.cassandra.utils.FBUtilities.midpoint:(Ljava/math/BigInteger;Ljava/math/BigInteger;I)Lorg/apache/cassandra/utils/Pair;
astore 6
start local 6 4: new org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
dup
aload 0
aload 6
getfield org.apache.cassandra.utils.Pair.left:Ljava/lang/Object;
checkcast java.math.BigInteger
iload 3
aload 6
getfield org.apache.cassandra.utils.Pair.right:Ljava/lang/Object;
checkcast java.lang.Boolean
invokevirtual java.lang.Boolean.booleanValue:()Z
invokevirtual org.apache.cassandra.dht.OrderPreservingPartitioner.stringForBig:(Ljava/math/BigInteger;IZ)Ljava/lang/String;
invokespecial org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken.<init>:(Ljava/lang/String;)V
areturn
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
0 5 1 ltoken Lorg/apache/cassandra/dht/Token;
0 5 2 rtoken Lorg/apache/cassandra/dht/Token;
1 5 3 sigchars I
2 5 4 left Ljava/math/BigInteger;
3 5 5 right Ljava/math/BigInteger;
4 5 6 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=2, locals=5, args_size=4
start local 0 start local 1 start local 2 start local 3 0: new java.lang.UnsupportedOperationException
dup
invokespecial java.lang.UnsupportedOperationException.<init>:()V
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
0 1 1 left Lorg/apache/cassandra/dht/Token;
0 1 2 right Lorg/apache/cassandra/dht/Token;
0 1 3 ratioToLeft D
MethodParameters:
Name Flags
left
right
ratioToLeft
private static java.math.BigInteger bigForString(java.lang.String, int);
descriptor: (Ljava/lang/String;I)Ljava/math/BigInteger;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=6, args_size=2
start local 0 start local 1 0: getstatic org.apache.cassandra.dht.OrderPreservingPartitioner.$assertionsDisabled:Z
ifne 1
aload 0
invokevirtual java.lang.String.length:()I
iload 1
if_icmple 1
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
1: StackMap locals:
StackMap stack:
getstatic java.math.BigInteger.ZERO:Ljava/math/BigInteger;
astore 2
start local 2 2: iconst_0
istore 3
start local 3 3: goto 8
4: StackMap locals: java.math.BigInteger int
StackMap stack:
bipush 16
iload 1
iload 3
iconst_1
iadd
isub
imul
istore 4
start local 4 5: aload 0
iload 3
invokevirtual java.lang.String.charAt:(I)C
ldc 65535
iand
i2l
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
astore 5
start local 5 6: aload 2
aload 5
iload 4
invokevirtual java.math.BigInteger.shiftLeft:(I)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.or:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 2
end local 5 end local 4 7: iinc 3 1
StackMap locals:
StackMap stack:
8: iload 3
aload 0
invokevirtual java.lang.String.length:()I
if_icmplt 4
end local 3 9: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 str Ljava/lang/String;
0 10 1 sigchars I
2 10 2 big Ljava/math/BigInteger;
3 9 3 i I
5 7 4 charpos I
6 7 5 charbig Ljava/math/BigInteger;
MethodParameters:
Name Flags
str
sigchars
private java.lang.String stringForBig(java.math.BigInteger, int, boolean);
descriptor: (Ljava/math/BigInteger;IZ)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=7, args_size=4
start local 0 start local 1 start local 2 start local 3 0: iload 2
iload 3
ifeq 1
iconst_1
goto 2
StackMap locals:
StackMap stack: int
1: iconst_0
StackMap locals: org.apache.cassandra.dht.OrderPreservingPartitioner java.math.BigInteger int int
StackMap stack: int int
2: iadd
newarray 5
astore 4
start local 4 3: iload 3
ifeq 5
4: aload 4
iload 2
dup2
caload
ldc 32768
ior
i2c
castore
5: StackMap locals: char[]
StackMap stack:
iconst_0
istore 5
start local 5 6: goto 10
7: StackMap locals: int
StackMap stack:
bipush 16
iload 2
iload 5
iconst_1
iadd
isub
imul
istore 6
start local 6 8: aload 4
iload 5
aload 1
getstatic org.apache.cassandra.dht.OrderPreservingPartitioner.CHAR_MASK:Ljava/math/BigInteger;
iload 6
invokevirtual java.math.BigInteger.shiftLeft:(I)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.and:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
iload 6
invokevirtual java.math.BigInteger.shiftRight:(I)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.intValue:()I
ldc 65535
iand
i2c
castore
end local 6 9: iinc 5 1
StackMap locals:
StackMap stack:
10: iload 5
iload 2
if_icmplt 7
end local 5 11: new java.lang.String
dup
aload 4
invokespecial java.lang.String.<init>:([C)V
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
0 12 1 big Ljava/math/BigInteger;
0 12 2 sigchars I
0 12 3 remainder Z
3 12 4 chars [C
6 11 5 i I
8 9 6 maskpos I
MethodParameters:
Name Flags
big
sigchars
remainder
public org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken getMinimumToken();
descriptor: ()Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: getstatic org.apache.cassandra.dht.OrderPreservingPartitioner.MINIMUM:Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
public org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken getRandomToken();
descriptor: ()Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokestatic java.util.concurrent.ThreadLocalRandom.current:()Ljava/util/concurrent/ThreadLocalRandom;
invokevirtual org.apache.cassandra.dht.OrderPreservingPartitioner.getRandomToken:(Ljava/util/Random;)Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
public org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken getRandomToken(java.util.Random);
descriptor: (Ljava/util/Random;)Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=4, args_size=2
start local 0 start local 1 0: new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 2
start local 2 1: iconst_0
istore 3
start local 3 2: goto 5
3: StackMap locals: java.lang.StringBuilder int
StackMap stack:
aload 2
ldc "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
aload 1
ldc "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
invokevirtual java.lang.String.length:()I
invokevirtual java.util.Random.nextInt:(I)I
invokevirtual java.lang.String.charAt:(I)C
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
4: iinc 3 1
StackMap locals:
StackMap stack:
5: iload 3
bipush 16
if_icmplt 3
end local 3 6: new org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
dup
aload 2
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken.<init>:(Ljava/lang/String;)V
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
0 7 1 random Ljava/util/Random;
1 7 2 buffer Ljava/lang/StringBuilder;
2 6 3 j I
MethodParameters:
Name Flags
random
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 0: aload 0
getfield org.apache.cassandra.dht.OrderPreservingPartitioner.tokenFactory:Lorg/apache/cassandra/dht/Token$TokenFactory;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
public boolean preservesOrder();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
public org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken getToken(java.nio.ByteBuffer);
descriptor: (Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 1
invokestatic org.apache.cassandra.utils.ByteBufferUtil.string:(Ljava/nio/ByteBuffer;)Ljava/lang/String;
astore 2
start local 2 1: goto 4
end local 2 2: StackMap locals:
StackMap stack: java.nio.charset.CharacterCodingException
pop
3: aload 1
invokestatic org.apache.cassandra.utils.ByteBufferUtil.bytesToHex:(Ljava/nio/ByteBuffer;)Ljava/lang/String;
astore 2
start local 2 4: StackMap locals: java.lang.String
StackMap stack:
new org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
dup
aload 2
invokespecial org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken.<init>:(Ljava/lang/String;)V
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
0 5 1 key Ljava/nio/ByteBuffer;
1 2 2 skey Ljava/lang/String;
4 5 2 skey Ljava/lang/String;
Exception table:
from to target type
0 1 2 Class java.nio.charset.CharacterCodingException
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=8, locals=11, args_size=2
start local 0 start local 1 0: new java.util.HashMap
dup
invokespecial java.util.HashMap.<init>:()V
astore 2
start local 2 1: new java.util.ArrayList
dup
aload 1
invokeinterface java.util.List.size:()I
invokespecial java.util.ArrayList.<init>:(I)V
astore 3
start local 3 2: aload 1
aload 1
invokeinterface java.util.List.size:()I
iconst_1
isub
invokeinterface java.util.List.get:(I)Ljava/lang/Object;
checkcast org.apache.cassandra.dht.Token
astore 4
start local 4 3: aload 1
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 6
goto 8
StackMap locals: org.apache.cassandra.dht.OrderPreservingPartitioner java.util.List java.util.Map java.util.List org.apache.cassandra.dht.Token top java.util.Iterator
StackMap stack:
4: aload 6
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.apache.cassandra.dht.Token
astore 5
start local 5 5: aload 2
aload 5
new java.lang.Float
dup
dconst_0
invokespecial java.lang.Float.<init>:(D)V
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
6: aload 3
new org.apache.cassandra.dht.Range
dup
aload 4
aload 5
invokespecial org.apache.cassandra.dht.Range.<init>:(Lorg/apache/cassandra/dht/RingPosition;Lorg/apache/cassandra/dht/RingPosition;)V
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
7: aload 5
astore 4
end local 5 8: StackMap locals:
StackMap stack:
aload 6
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
9: getstatic org.apache.cassandra.config.Schema.instance:Lorg/apache/cassandra/config/Schema;
invokevirtual org.apache.cassandra.config.Schema.getKeyspaces:()Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 6
goto 18
StackMap locals:
StackMap stack:
10: aload 6
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 5
start local 5 11: getstatic org.apache.cassandra.config.Schema.instance:Lorg/apache/cassandra/config/Schema;
aload 5
invokevirtual org.apache.cassandra.config.Schema.getTablesAndViews:(Ljava/lang/String;)Ljava/lang/Iterable;
invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
astore 8
goto 17
StackMap locals: org.apache.cassandra.dht.OrderPreservingPartitioner java.util.List java.util.Map java.util.List org.apache.cassandra.dht.Token java.lang.String java.util.Iterator top java.util.Iterator
StackMap stack:
12: aload 8
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.apache.cassandra.config.CFMetaData
astore 7
start local 7 13: aload 3
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 10
goto 16
StackMap locals: org.apache.cassandra.dht.OrderPreservingPartitioner java.util.List java.util.Map java.util.List org.apache.cassandra.dht.Token java.lang.String java.util.Iterator org.apache.cassandra.config.CFMetaData java.util.Iterator top java.util.Iterator
StackMap stack:
14: aload 10
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.apache.cassandra.dht.Range
astore 9
start local 9 15: aload 2
aload 9
getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
checkcast org.apache.cassandra.dht.Token
aload 2
aload 9
getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.Float
invokevirtual java.lang.Float.floatValue:()F
getstatic org.apache.cassandra.service.StorageService.instance:Lorg/apache/cassandra/service/StorageService;
aload 5
aload 7
getfield org.apache.cassandra.config.CFMetaData.cfName:Ljava/lang/String;
aload 9
aload 7
getfield org.apache.cassandra.config.CFMetaData.params:Lorg/apache/cassandra/schema/TableParams;
getfield org.apache.cassandra.schema.TableParams.minIndexInterval:I
invokevirtual org.apache.cassandra.service.StorageService.getSplits:(Ljava/lang/String;Ljava/lang/String;Lorg/apache/cassandra/dht/Range;I)Ljava/util/List;
invokeinterface java.util.List.size:()I
i2f
fadd
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 9 16: StackMap locals:
StackMap stack:
aload 10
invokeinterface java.util.Iterator.hasNext:()Z
ifne 14
end local 7 17: StackMap locals: org.apache.cassandra.dht.OrderPreservingPartitioner java.util.List java.util.Map java.util.List org.apache.cassandra.dht.Token java.lang.String java.util.Iterator top java.util.Iterator
StackMap stack:
aload 8
invokeinterface java.util.Iterator.hasNext:()Z
ifne 12
end local 5 18: StackMap locals: org.apache.cassandra.dht.OrderPreservingPartitioner java.util.List java.util.Map java.util.List org.apache.cassandra.dht.Token top java.util.Iterator
StackMap stack:
aload 6
invokeinterface java.util.Iterator.hasNext:()Z
ifne 10
19: new java.lang.Float
dup
dconst_0
invokespecial java.lang.Float.<init>:(D)V
astore 5
start local 5 20: aload 2
invokeinterface java.util.Map.values:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 7
goto 23
StackMap locals: org.apache.cassandra.dht.OrderPreservingPartitioner java.util.List java.util.Map java.util.List org.apache.cassandra.dht.Token java.lang.Float top java.util.Iterator
StackMap stack:
21: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.Float
astore 6
start local 6 22: aload 5
invokevirtual java.lang.Float.floatValue:()F
aload 6
invokevirtual java.lang.Float.floatValue:()F
fadd
invokestatic java.lang.Float.valueOf:(F)Ljava/lang/Float;
astore 5
end local 6 23: StackMap locals:
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 21
24: aload 2
invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 7
goto 27
StackMap locals:
StackMap stack:
25: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.util.Map$Entry
astore 6
start local 6 26: aload 2
aload 6
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
checkcast org.apache.cassandra.dht.Token
aload 6
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast java.lang.Float
invokevirtual java.lang.Float.floatValue:()F
aload 5
invokevirtual java.lang.Float.floatValue:()F
fdiv
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 6 27: StackMap locals:
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 25
28: aload 2
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 29 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
0 29 1 sortedTokens Ljava/util/List<Lorg/apache/cassandra/dht/Token;>;
1 29 2 allTokens Ljava/util/Map<Lorg/apache/cassandra/dht/Token;Ljava/lang/Float;>;
2 29 3 sortedRanges Ljava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
3 29 4 lastToken Lorg/apache/cassandra/dht/Token;
5 8 5 node Lorg/apache/cassandra/dht/Token;
11 18 5 ks Ljava/lang/String;
13 17 7 cfmd Lorg/apache/cassandra/config/CFMetaData;
15 16 9 r Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
20 29 5 total Ljava/lang/Float;
22 23 6 f Ljava/lang/Float;
26 27 6 row Ljava/util/Map$Entry<Lorg/apache/cassandra/dht/Token;Ljava/lang/Float;>;
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.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 0: getstatic org.apache.cassandra.db.marshal.UTF8Type.instance:Lorg/apache/cassandra/db/marshal/UTF8Type;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
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 0: getstatic org.apache.cassandra.db.marshal.UTF8Type.instance:Lorg/apache/cassandra/db/marshal/UTF8Type;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/dht/OrderPreservingPartitioner;
Signature: ()Lorg/apache/cassandra/db/marshal/AbstractType<*>;
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: aload 0
aload 1
invokevirtual org.apache.cassandra.dht.OrderPreservingPartitioner.getToken:(Ljava/nio/ByteBuffer;)Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
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: aload 0
aload 1
invokevirtual org.apache.cassandra.dht.OrderPreservingPartitioner.getRandomToken:(Ljava/util/Random;)Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
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: aload 0
invokevirtual org.apache.cassandra.dht.OrderPreservingPartitioner.getRandomToken:()Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
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: aload 0
invokevirtual org.apache.cassandra.dht.OrderPreservingPartitioner.getMinimumToken:()Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
areturn
LocalVariableTable:
Start End Slot Name Signature
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: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=3, locals=3, args_size=3
0: aload 0
aload 1
aload 2
invokevirtual org.apache.cassandra.dht.OrderPreservingPartitioner.midpoint:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/OrderPreservingPartitioner$StringToken;
areturn
LocalVariableTable:
Start End Slot Name Signature
}
SourceFile: "OrderPreservingPartitioner.java"
NestMembers:
org.apache.cassandra.dht.OrderPreservingPartitioner$1 org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken
InnerClasses:
public abstract Entry = java.util.Map$Entry of java.util.Map
org.apache.cassandra.dht.OrderPreservingPartitioner$1
public StringToken = org.apache.cassandra.dht.OrderPreservingPartitioner$StringToken of org.apache.cassandra.dht.OrderPreservingPartitioner
public abstract TokenFactory = org.apache.cassandra.dht.Token$TokenFactory of org.apache.cassandra.dht.Token