public abstract class org.apache.cassandra.locator.AbstractReplicationStrategy
minor version: 0
major version: 59
flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
this_class: org.apache.cassandra.locator.AbstractReplicationStrategy
super_class: java.lang.Object
{
private static final org.slf4j.Logger logger;
descriptor: Lorg/slf4j/Logger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
final java.lang.String keyspaceName;
descriptor: Ljava/lang/String;
flags: (0x0010) ACC_FINAL
RuntimeInvisibleAnnotations:
com.google.common.annotations.VisibleForTesting()
private org.apache.cassandra.db.Keyspace keyspace;
descriptor: Lorg/apache/cassandra/db/Keyspace;
flags: (0x0002) ACC_PRIVATE
public final java.util.Map<java.lang.String, java.lang.String> configOptions;
descriptor: Ljava/util/Map;
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
private final org.apache.cassandra.locator.TokenMetadata tokenMetadata;
descriptor: Lorg/apache/cassandra/locator/TokenMetadata;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private volatile long lastInvalidatedVersion;
descriptor: J
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
public org.apache.cassandra.locator.IEndpointSnitch snitch;
descriptor: Lorg/apache/cassandra/locator/IEndpointSnitch;
flags: (0x0001) ACC_PUBLIC
private final java.util.Map<org.apache.cassandra.dht.Token, java.util.ArrayList<java.net.InetAddress>> cachedEndpoints;
descriptor: Ljava/util/Map;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Map<Lorg/apache/cassandra/dht/Token;Ljava/util/ArrayList<Ljava/net/InetAddress;>;>;
static final boolean $assertionsDisabled;
descriptor: Z
flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
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.locator.AbstractReplicationStrategy.$assertionsDisabled:Z
3: ldc Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
putstatic org.apache.cassandra.locator.AbstractReplicationStrategy.logger:Lorg/slf4j/Logger;
return
LocalVariableTable:
Start End Slot Name Signature
protected void <init>(java.lang.String, org.apache.cassandra.locator.TokenMetadata, org.apache.cassandra.locator.IEndpointSnitch, java.util.Map<java.lang.String, java.lang.String>);
descriptor: (Ljava/lang/String;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=5, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
lconst_0
putfield org.apache.cassandra.locator.AbstractReplicationStrategy.lastInvalidatedVersion:J
2: aload 0
new org.cliffc.high_scale_lib.NonBlockingHashMap
dup
invokespecial org.cliffc.high_scale_lib.NonBlockingHashMap.<init>:()V
putfield org.apache.cassandra.locator.AbstractReplicationStrategy.cachedEndpoints:Ljava/util/Map;
3: getstatic org.apache.cassandra.locator.AbstractReplicationStrategy.$assertionsDisabled:Z
ifne 4
aload 1
ifnonnull 4
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
4: StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy java.lang.String org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.IEndpointSnitch java.util.Map
StackMap stack:
getstatic org.apache.cassandra.locator.AbstractReplicationStrategy.$assertionsDisabled:Z
ifne 5
aload 3
ifnonnull 5
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
5: StackMap locals:
StackMap stack:
getstatic org.apache.cassandra.locator.AbstractReplicationStrategy.$assertionsDisabled:Z
ifne 6
aload 2
ifnonnull 6
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
6: StackMap locals:
StackMap stack:
aload 0
aload 2
putfield org.apache.cassandra.locator.AbstractReplicationStrategy.tokenMetadata:Lorg/apache/cassandra/locator/TokenMetadata;
7: aload 0
aload 3
putfield org.apache.cassandra.locator.AbstractReplicationStrategy.snitch:Lorg/apache/cassandra/locator/IEndpointSnitch;
8: aload 0
aload 4
ifnonnull 9
invokestatic java.util.Collections.emptyMap:()Ljava/util/Map;
goto 10
StackMap locals:
StackMap stack: org.apache.cassandra.locator.AbstractReplicationStrategy
9: aload 4
StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy java.lang.String org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.IEndpointSnitch java.util.Map
StackMap stack: org.apache.cassandra.locator.AbstractReplicationStrategy java.util.Map
10: putfield org.apache.cassandra.locator.AbstractReplicationStrategy.configOptions:Ljava/util/Map;
11: aload 0
aload 1
putfield org.apache.cassandra.locator.AbstractReplicationStrategy.keyspaceName:Ljava/lang/String;
12: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
0 13 1 keyspaceName Ljava/lang/String;
0 13 2 tokenMetadata Lorg/apache/cassandra/locator/TokenMetadata;
0 13 3 snitch Lorg/apache/cassandra/locator/IEndpointSnitch;
0 13 4 configOptions Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
Signature: (Ljava/lang/String;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;)V
MethodParameters:
Name Flags
keyspaceName
tokenMetadata
snitch
configOptions
public java.util.ArrayList<java.net.InetAddress> getCachedEndpoints(org.apache.cassandra.dht.Token);
descriptor: (Lorg/apache/cassandra/dht/Token;)Ljava/util/ArrayList;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=5, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.tokenMetadata:Lorg/apache/cassandra/locator/TokenMetadata;
invokevirtual org.apache.cassandra.locator.TokenMetadata.getRingVersion:()J
lstore 2
start local 2 1: lload 2
aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.lastInvalidatedVersion:J
lcmp
ifle 11
2: aload 0
dup
astore 4
monitorenter
3: lload 2
aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.lastInvalidatedVersion:J
lcmp
ifle 7
4: getstatic org.apache.cassandra.locator.AbstractReplicationStrategy.logger:Lorg/slf4j/Logger;
ldc "clearing cached endpoints"
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
5: aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.cachedEndpoints:Ljava/util/Map;
invokeinterface java.util.Map.clear:()V
6: aload 0
lload 2
putfield org.apache.cassandra.locator.AbstractReplicationStrategy.lastInvalidatedVersion:J
7: StackMap locals: long org.apache.cassandra.locator.AbstractReplicationStrategy
StackMap stack:
aload 4
monitorexit
8: goto 11
StackMap locals:
StackMap stack: java.lang.Throwable
9: aload 4
monitorexit
10: athrow
11: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.cachedEndpoints:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.util.ArrayList
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
0 12 1 t Lorg/apache/cassandra/dht/Token;
1 12 2 lastVersion J
Exception table:
from to target type
3 8 9 any
9 10 9 any
Signature: (Lorg/apache/cassandra/dht/Token;)Ljava/util/ArrayList<Ljava/net/InetAddress;>;
MethodParameters:
Name Flags
t
public java.util.ArrayList<java.net.InetAddress> getNaturalEndpoints(org.apache.cassandra.dht.RingPosition);
descriptor: (Lorg/apache/cassandra/dht/RingPosition;)Ljava/util/ArrayList;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=6, args_size=2
start local 0 start local 1 0: aload 1
invokeinterface org.apache.cassandra.dht.RingPosition.getToken:()Lorg/apache/cassandra/dht/Token;
astore 2
start local 2 1: aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.tokenMetadata:Lorg/apache/cassandra/locator/TokenMetadata;
invokevirtual org.apache.cassandra.locator.TokenMetadata.sortedTokens:()Ljava/util/ArrayList;
aload 2
invokestatic org.apache.cassandra.locator.TokenMetadata.firstToken:(Ljava/util/ArrayList;Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
astore 3
start local 3 2: aload 0
aload 3
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getCachedEndpoints:(Lorg/apache/cassandra/dht/Token;)Ljava/util/ArrayList;
astore 4
start local 4 3: aload 4
ifnonnull 8
4: aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.tokenMetadata:Lorg/apache/cassandra/locator/TokenMetadata;
invokevirtual org.apache.cassandra.locator.TokenMetadata.cachedOnlyTokenMap:()Lorg/apache/cassandra/locator/TokenMetadata;
astore 5
start local 5 5: aload 5
invokevirtual org.apache.cassandra.locator.TokenMetadata.sortedTokens:()Ljava/util/ArrayList;
aload 2
invokestatic org.apache.cassandra.locator.TokenMetadata.firstToken:(Ljava/util/ArrayList;Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Token;
astore 3
6: new java.util.ArrayList
dup
aload 0
aload 2
aload 5
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.calculateNaturalEndpoints:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List;
invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
astore 4
7: aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.cachedEndpoints:Ljava/util/Map;
aload 3
aload 4
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
end local 5 8: StackMap locals: org.apache.cassandra.dht.Token org.apache.cassandra.dht.Token java.util.ArrayList
StackMap stack:
new java.util.ArrayList
dup
aload 4
invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
0 9 1 searchPosition Lorg/apache/cassandra/dht/RingPosition;
1 9 2 searchToken Lorg/apache/cassandra/dht/Token;
2 9 3 keyToken Lorg/apache/cassandra/dht/Token;
3 9 4 endpoints Ljava/util/ArrayList<Ljava/net/InetAddress;>;
5 8 5 tm Lorg/apache/cassandra/locator/TokenMetadata;
Signature: (Lorg/apache/cassandra/dht/RingPosition;)Ljava/util/ArrayList<Ljava/net/InetAddress;>;
MethodParameters:
Name Flags
searchPosition
public abstract java.util.List<java.net.InetAddress> calculateNaturalEndpoints(org.apache.cassandra.dht.Token, org.apache.cassandra.locator.TokenMetadata);
descriptor: (Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List;
flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
Signature: (Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List<Ljava/net/InetAddress;>;
MethodParameters:
Name Flags
searchToken
tokenMetadata
public <T> org.apache.cassandra.service.AbstractWriteResponseHandler<T> getWriteResponseHandler(java.util.Collection<java.net.InetAddress>, java.util.Collection<java.net.InetAddress>, org.apache.cassandra.db.ConsistencyLevel, java.lang.Runnable, org.apache.cassandra.db.WriteType, long);
descriptor: (Ljava/util/Collection;Ljava/util/Collection;Lorg/apache/cassandra/db/ConsistencyLevel;Ljava/lang/Runnable;Lorg/apache/cassandra/db/WriteType;J)Lorg/apache/cassandra/service/AbstractWriteResponseHandler;
flags: (0x0001) ACC_PUBLIC
Code:
stack=10, locals=8, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 3
invokevirtual org.apache.cassandra.db.ConsistencyLevel.isDatacenterLocal:()Z
ifeq 2
1: new org.apache.cassandra.service.DatacenterWriteResponseHandler
dup
aload 1
aload 2
aload 3
aload 0
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getKeyspace:()Lorg/apache/cassandra/db/Keyspace;
aload 4
aload 5
lload 6
invokespecial org.apache.cassandra.service.DatacenterWriteResponseHandler.<init>:(Ljava/util/Collection;Ljava/util/Collection;Lorg/apache/cassandra/db/ConsistencyLevel;Lorg/apache/cassandra/db/Keyspace;Ljava/lang/Runnable;Lorg/apache/cassandra/db/WriteType;J)V
areturn
2: StackMap locals:
StackMap stack:
aload 3
getstatic org.apache.cassandra.db.ConsistencyLevel.EACH_QUORUM:Lorg/apache/cassandra/db/ConsistencyLevel;
if_acmpne 4
aload 0
instanceof org.apache.cassandra.locator.NetworkTopologyStrategy
ifeq 4
3: new org.apache.cassandra.service.DatacenterSyncWriteResponseHandler
dup
aload 1
aload 2
aload 3
aload 0
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getKeyspace:()Lorg/apache/cassandra/db/Keyspace;
aload 4
aload 5
lload 6
invokespecial org.apache.cassandra.service.DatacenterSyncWriteResponseHandler.<init>:(Ljava/util/Collection;Ljava/util/Collection;Lorg/apache/cassandra/db/ConsistencyLevel;Lorg/apache/cassandra/db/Keyspace;Ljava/lang/Runnable;Lorg/apache/cassandra/db/WriteType;J)V
areturn
4: StackMap locals:
StackMap stack:
new org.apache.cassandra.service.WriteResponseHandler
dup
aload 1
aload 2
aload 3
aload 0
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getKeyspace:()Lorg/apache/cassandra/db/Keyspace;
aload 4
aload 5
lload 6
invokespecial org.apache.cassandra.service.WriteResponseHandler.<init>:(Ljava/util/Collection;Ljava/util/Collection;Lorg/apache/cassandra/db/ConsistencyLevel;Lorg/apache/cassandra/db/Keyspace;Ljava/lang/Runnable;Lorg/apache/cassandra/db/WriteType;J)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/locator/AbstractReplicationStrategy;
0 5 1 naturalEndpoints Ljava/util/Collection<Ljava/net/InetAddress;>;
0 5 2 pendingEndpoints Ljava/util/Collection<Ljava/net/InetAddress;>;
0 5 3 consistency_level Lorg/apache/cassandra/db/ConsistencyLevel;
0 5 4 callback Ljava/lang/Runnable;
0 5 5 writeType Lorg/apache/cassandra/db/WriteType;
0 5 6 queryStartNanoTime J
Signature: <T:Ljava/lang/Object;>(Ljava/util/Collection<Ljava/net/InetAddress;>;Ljava/util/Collection<Ljava/net/InetAddress;>;Lorg/apache/cassandra/db/ConsistencyLevel;Ljava/lang/Runnable;Lorg/apache/cassandra/db/WriteType;J)Lorg/apache/cassandra/service/AbstractWriteResponseHandler<TT;>;
MethodParameters:
Name Flags
naturalEndpoints
pendingEndpoints
consistency_level
callback
writeType
queryStartNanoTime
private org.apache.cassandra.db.Keyspace getKeyspace();
descriptor: ()Lorg/apache/cassandra/db/Keyspace;
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.keyspace:Lorg/apache/cassandra/db/Keyspace;
ifnonnull 2
1: aload 0
aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.keyspaceName:Ljava/lang/String;
invokestatic org.apache.cassandra.db.Keyspace.open:(Ljava/lang/String;)Lorg/apache/cassandra/db/Keyspace;
putfield org.apache.cassandra.locator.AbstractReplicationStrategy.keyspace:Lorg/apache/cassandra/db/Keyspace;
2: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.keyspace:Lorg/apache/cassandra/db/Keyspace;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
public abstract int getReplicationFactor();
descriptor: ()I
flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
public com.google.common.collect.Multimap<java.net.InetAddress, org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>> getAddressRanges(org.apache.cassandra.locator.TokenMetadata);
descriptor: (Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=8, args_size=2
start local 0 start local 1 0: invokestatic com.google.common.collect.HashMultimap.create:()Lcom/google/common/collect/HashMultimap;
astore 2
start local 2 1: aload 1
invokevirtual org.apache.cassandra.locator.TokenMetadata.sortedTokens:()Ljava/util/ArrayList;
invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
astore 4
goto 8
StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap top java.util.Iterator
StackMap stack:
2: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.apache.cassandra.dht.Token
astore 3
start local 3 3: aload 1
aload 3
invokevirtual org.apache.cassandra.locator.TokenMetadata.getPrimaryRangeFor:(Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Range;
astore 5
start local 5 4: aload 0
aload 3
aload 1
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.calculateNaturalEndpoints:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 7
goto 7
StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap org.apache.cassandra.dht.Token java.util.Iterator org.apache.cassandra.dht.Range top java.util.Iterator
StackMap stack:
5: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.net.InetAddress
astore 6
start local 6 6: aload 2
aload 6
aload 5
invokeinterface com.google.common.collect.Multimap.put:(Ljava/lang/Object;Ljava/lang/Object;)Z
pop
end local 6 7: StackMap locals:
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 5
end local 5 end local 3 8: StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 2
9: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
0 10 1 metadata Lorg/apache/cassandra/locator/TokenMetadata;
1 10 2 map Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
3 8 3 token Lorg/apache/cassandra/dht/Token;
4 8 5 range Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
6 7 6 ep Ljava/net/InetAddress;
Signature: (Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
MethodParameters:
Name Flags
metadata
public com.google.common.collect.Multimap<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>, java.net.InetAddress> getRangeAddresses(org.apache.cassandra.locator.TokenMetadata);
descriptor: (Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=8, args_size=2
start local 0 start local 1 0: invokestatic com.google.common.collect.HashMultimap.create:()Lcom/google/common/collect/HashMultimap;
astore 2
start local 2 1: aload 1
invokevirtual org.apache.cassandra.locator.TokenMetadata.sortedTokens:()Ljava/util/ArrayList;
invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
astore 4
goto 8
StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap top java.util.Iterator
StackMap stack:
2: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.apache.cassandra.dht.Token
astore 3
start local 3 3: aload 1
aload 3
invokevirtual org.apache.cassandra.locator.TokenMetadata.getPrimaryRangeFor:(Lorg/apache/cassandra/dht/Token;)Lorg/apache/cassandra/dht/Range;
astore 5
start local 5 4: aload 0
aload 3
aload 1
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.calculateNaturalEndpoints:(Lorg/apache/cassandra/dht/Token;Lorg/apache/cassandra/locator/TokenMetadata;)Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 7
goto 7
StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap org.apache.cassandra.dht.Token java.util.Iterator org.apache.cassandra.dht.Range top java.util.Iterator
StackMap stack:
5: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.net.InetAddress
astore 6
start local 6 6: aload 2
aload 5
aload 6
invokeinterface com.google.common.collect.Multimap.put:(Ljava/lang/Object;Ljava/lang/Object;)Z
pop
end local 6 7: StackMap locals:
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 5
end local 5 end local 3 8: StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy org.apache.cassandra.locator.TokenMetadata com.google.common.collect.Multimap top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 2
9: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
0 10 1 metadata Lorg/apache/cassandra/locator/TokenMetadata;
1 10 2 map Lcom/google/common/collect/Multimap<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;>;
3 8 3 token Lorg/apache/cassandra/dht/Token;
4 8 5 range Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
6 7 6 ep Ljava/net/InetAddress;
Signature: (Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;>;
MethodParameters:
Name Flags
metadata
public com.google.common.collect.Multimap<java.net.InetAddress, org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>> getAddressRanges();
descriptor: ()Lcom/google/common/collect/Multimap;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.tokenMetadata:Lorg/apache/cassandra/locator/TokenMetadata;
invokevirtual org.apache.cassandra.locator.TokenMetadata.cloneOnlyTokenMap:()Lorg/apache/cassandra/locator/TokenMetadata;
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
Signature: ()Lcom/google/common/collect/Multimap<Ljava/net/InetAddress;Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
public java.util.Collection<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>> getPendingAddressRanges(org.apache.cassandra.locator.TokenMetadata, org.apache.cassandra.dht.Token, java.net.InetAddress);
descriptor: (Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;)Ljava/util/Collection;
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
aload 1
iconst_1
anewarray org.apache.cassandra.dht.Token
dup
iconst_0
aload 2
aastore
invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
aload 3
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getPendingAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;Ljava/util/Collection;Ljava/net/InetAddress;)Ljava/util/Collection;
areturn
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/locator/AbstractReplicationStrategy;
0 1 1 metadata Lorg/apache/cassandra/locator/TokenMetadata;
0 1 2 pendingToken Lorg/apache/cassandra/dht/Token;
0 1 3 pendingAddress Ljava/net/InetAddress;
Signature: (Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/dht/Token;Ljava/net/InetAddress;)Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
MethodParameters:
Name Flags
metadata
pendingToken
pendingAddress
public java.util.Collection<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>> getPendingAddressRanges(org.apache.cassandra.locator.TokenMetadata, java.util.Collection<org.apache.cassandra.dht.Token>, java.net.InetAddress);
descriptor: (Lorg/apache/cassandra/locator/TokenMetadata;Ljava/util/Collection;Ljava/net/InetAddress;)Ljava/util/Collection;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=5, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 1
invokevirtual org.apache.cassandra.locator.TokenMetadata.cloneOnlyTokenMap:()Lorg/apache/cassandra/locator/TokenMetadata;
astore 4
start local 4 1: aload 4
aload 2
aload 3
invokevirtual org.apache.cassandra.locator.TokenMetadata.updateNormalTokens:(Ljava/util/Collection;Ljava/net/InetAddress;)V
2: aload 0
aload 4
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getAddressRanges:(Lorg/apache/cassandra/locator/TokenMetadata;)Lcom/google/common/collect/Multimap;
aload 3
invokeinterface com.google.common.collect.Multimap.get:(Ljava/lang/Object;)Ljava/util/Collection;
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
0 3 1 metadata Lorg/apache/cassandra/locator/TokenMetadata;
0 3 2 pendingTokens Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;
0 3 3 pendingAddress Ljava/net/InetAddress;
1 3 4 temp Lorg/apache/cassandra/locator/TokenMetadata;
Signature: (Lorg/apache/cassandra/locator/TokenMetadata;Ljava/util/Collection<Lorg/apache/cassandra/dht/Token;>;Ljava/net/InetAddress;)Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
MethodParameters:
Name Flags
metadata
pendingTokens
pendingAddress
public abstract void validateOptions();
descriptor: ()V
flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
Exceptions:
throws org.apache.cassandra.exceptions.ConfigurationException
public java.util.Collection<java.lang.String> recognizedOptions();
descriptor: ()Ljava/util/Collection;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
Signature: ()Ljava/util/Collection<Ljava/lang/String;>;
private static org.apache.cassandra.locator.AbstractReplicationStrategy createInternal(java.lang.String, java.lang.Class<? extends org.apache.cassandra.locator.AbstractReplicationStrategy>, org.apache.cassandra.locator.TokenMetadata, org.apache.cassandra.locator.IEndpointSnitch, java.util.Map<java.lang.String, java.lang.String>);
descriptor: (Ljava/lang/String;Ljava/lang/Class;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map;)Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=5, locals=9, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: iconst_4
anewarray java.lang.Class
dup
iconst_0
ldc Ljava/lang/String;
aastore
dup
iconst_1
ldc Lorg/apache/cassandra/locator/TokenMetadata;
aastore
dup
iconst_2
ldc Lorg/apache/cassandra/locator/IEndpointSnitch;
aastore
dup
iconst_3
ldc Ljava/util/Map;
aastore
astore 6
start local 6 1: aload 1
aload 6
invokevirtual java.lang.Class.getConstructor:([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
astore 7
start local 7 2: aload 7
iconst_4
anewarray java.lang.Object
dup
iconst_0
aload 0
aastore
dup
iconst_1
aload 2
aastore
dup
iconst_2
aload 3
aastore
dup
iconst_3
aload 4
aastore
invokevirtual java.lang.reflect.Constructor.newInstance:([Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.cassandra.locator.AbstractReplicationStrategy
astore 5
end local 7 start local 5 3: goto 9
end local 5 4: StackMap locals: java.lang.String java.lang.Class org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.IEndpointSnitch java.util.Map top java.lang.Class[]
StackMap stack: java.lang.reflect.InvocationTargetException
astore 7
start local 7 5: aload 7
invokevirtual java.lang.reflect.InvocationTargetException.getTargetException:()Ljava/lang/Throwable;
astore 8
start local 8 6: new org.apache.cassandra.exceptions.ConfigurationException
dup
aload 8
invokevirtual java.lang.Throwable.getMessage:()Ljava/lang/String;
aload 8
invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 8 end local 7 7: StackMap locals:
StackMap stack: java.lang.Exception
astore 7
start local 7 8: new org.apache.cassandra.exceptions.ConfigurationException
dup
ldc "Error constructing replication strategy class"
aload 7
invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 7 start local 5 9: StackMap locals: java.lang.String java.lang.Class org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.IEndpointSnitch java.util.Map org.apache.cassandra.locator.AbstractReplicationStrategy java.lang.Class[]
StackMap stack:
aload 5
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 10 0 keyspaceName Ljava/lang/String;
0 10 1 strategyClass Ljava/lang/Class<+Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;
0 10 2 tokenMetadata Lorg/apache/cassandra/locator/TokenMetadata;
0 10 3 snitch Lorg/apache/cassandra/locator/IEndpointSnitch;
0 10 4 strategyOptions Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
3 4 5 strategy Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
9 10 5 strategy Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
1 10 6 parameterTypes [Ljava/lang/Class;
2 3 7 constructor Ljava/lang/reflect/Constructor<+Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;
5 7 7 e Ljava/lang/reflect/InvocationTargetException;
6 7 8 targetException Ljava/lang/Throwable;
8 9 7 e Ljava/lang/Exception;
Exception table:
from to target type
1 3 4 Class java.lang.reflect.InvocationTargetException
1 3 7 Class java.lang.Exception
Exceptions:
throws org.apache.cassandra.exceptions.ConfigurationException
Signature: (Ljava/lang/String;Ljava/lang/Class<+Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;)Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
MethodParameters:
Name Flags
keyspaceName
strategyClass
tokenMetadata
snitch
strategyOptions
public static org.apache.cassandra.locator.AbstractReplicationStrategy createReplicationStrategy(java.lang.String, java.lang.Class<? extends org.apache.cassandra.locator.AbstractReplicationStrategy>, org.apache.cassandra.locator.TokenMetadata, org.apache.cassandra.locator.IEndpointSnitch, java.util.Map<java.lang.String, java.lang.String>);
descriptor: (Ljava/lang/String;Ljava/lang/Class;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map;)Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=5, locals=7, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
aload 1
aload 2
aload 3
aload 4
invokestatic org.apache.cassandra.locator.AbstractReplicationStrategy.createInternal:(Ljava/lang/String;Ljava/lang/Class;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map;)Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
astore 5
start local 5 1: aload 5
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.validateExpectedOptions:()V
2: goto 5
3: StackMap locals: java.lang.String java.lang.Class org.apache.cassandra.locator.TokenMetadata org.apache.cassandra.locator.IEndpointSnitch java.util.Map org.apache.cassandra.locator.AbstractReplicationStrategy
StackMap stack: org.apache.cassandra.exceptions.ConfigurationException
astore 6
start local 6 4: getstatic org.apache.cassandra.locator.AbstractReplicationStrategy.logger:Lorg/slf4j/Logger;
ldc "Ignoring {}"
aload 6
invokevirtual org.apache.cassandra.exceptions.ConfigurationException.getMessage:()Ljava/lang/String;
invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Object;)V
end local 6 5: StackMap locals:
StackMap stack:
aload 5
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.validateOptions:()V
6: aload 5
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 7 0 keyspaceName Ljava/lang/String;
0 7 1 strategyClass Ljava/lang/Class<+Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;
0 7 2 tokenMetadata Lorg/apache/cassandra/locator/TokenMetadata;
0 7 3 snitch Lorg/apache/cassandra/locator/IEndpointSnitch;
0 7 4 strategyOptions Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
1 7 5 strategy Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
4 5 6 e Lorg/apache/cassandra/exceptions/ConfigurationException;
Exception table:
from to target type
1 2 3 Class org.apache.cassandra.exceptions.ConfigurationException
Signature: (Ljava/lang/String;Ljava/lang/Class<+Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;)Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
MethodParameters:
Name Flags
keyspaceName
strategyClass
tokenMetadata
snitch
strategyOptions
public static void validateReplicationStrategy(java.lang.String, java.lang.Class<? extends org.apache.cassandra.locator.AbstractReplicationStrategy>, org.apache.cassandra.locator.TokenMetadata, org.apache.cassandra.locator.IEndpointSnitch, java.util.Map<java.lang.String, java.lang.String>);
descriptor: (Ljava/lang/String;Ljava/lang/Class;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map;)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=5, locals=6, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
aload 1
aload 2
aload 3
aload 4
invokestatic org.apache.cassandra.locator.AbstractReplicationStrategy.createInternal:(Ljava/lang/String;Ljava/lang/Class;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map;)Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
astore 5
start local 5 1: aload 5
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.validateExpectedOptions:()V
2: aload 5
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.validateOptions:()V
3: return
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 4 0 keyspaceName Ljava/lang/String;
0 4 1 strategyClass Ljava/lang/Class<+Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;
0 4 2 tokenMetadata Lorg/apache/cassandra/locator/TokenMetadata;
0 4 3 snitch Lorg/apache/cassandra/locator/IEndpointSnitch;
0 4 4 strategyOptions Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
1 4 5 strategy Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
Exceptions:
throws org.apache.cassandra.exceptions.ConfigurationException
Signature: (Ljava/lang/String;Ljava/lang/Class<+Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;Lorg/apache/cassandra/locator/TokenMetadata;Lorg/apache/cassandra/locator/IEndpointSnitch;Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;)V
MethodParameters:
Name Flags
keyspaceName
strategyClass
tokenMetadata
snitch
strategyOptions
public static java.lang.Class<org.apache.cassandra.locator.AbstractReplicationStrategy> getClass(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/Class;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=7, locals=3, args_size=1
start local 0 0: aload 0
ldc "."
invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
ifeq 1
aload 0
goto 2
StackMap locals:
StackMap stack:
1: new java.lang.StringBuilder
dup
ldc "org.apache.cassandra.locator."
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
StackMap locals:
StackMap stack: java.lang.String
2: astore 1
start local 1 3: aload 1
ldc "replication strategy"
invokestatic org.apache.cassandra.utils.FBUtilities.classForName:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Class;
astore 2
start local 2 4: ldc Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
aload 2
invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
ifne 6
5: new org.apache.cassandra.exceptions.ConfigurationException
dup
ldc "Specified replication strategy class (%s) is not derived from AbstractReplicationStrategy"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 1
aastore
invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;)V
athrow
6: StackMap locals: java.lang.String java.lang.Class
StackMap stack:
aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 cls Ljava/lang/String;
3 7 1 className Ljava/lang/String;
4 7 2 strategyClass Ljava/lang/Class<Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;
Exceptions:
throws org.apache.cassandra.exceptions.ConfigurationException
Signature: (Ljava/lang/String;)Ljava/lang/Class<Lorg/apache/cassandra/locator/AbstractReplicationStrategy;>;
MethodParameters:
Name Flags
cls
public boolean hasSameSettings(org.apache.cassandra.locator.AbstractReplicationStrategy);
descriptor: (Lorg/apache/cassandra/locator/AbstractReplicationStrategy;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
aload 1
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifeq 1
aload 0
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getReplicationFactor:()I
aload 1
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.getReplicationFactor:()I
if_icmpne 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
0 2 1 other Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
MethodParameters:
Name Flags
other
protected void validateReplicationFactor(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
ifge 4
1: new org.apache.cassandra.exceptions.ConfigurationException
dup
new java.lang.StringBuilder
dup
ldc "Replication factor must be non-negative; found "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack: java.lang.NumberFormatException
pop
3: new org.apache.cassandra.exceptions.ConfigurationException
dup
new java.lang.StringBuilder
dup
ldc "Replication factor must be numeric; found "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;)V
athrow
4: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
0 5 1 rf Ljava/lang/String;
Exception table:
from to target type
0 2 2 Class java.lang.NumberFormatException
Exceptions:
throws org.apache.cassandra.exceptions.ConfigurationException
MethodParameters:
Name Flags
rf
private void validateExpectedOptions();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=7, locals=4, args_size=1
start local 0 0: aload 0
invokevirtual org.apache.cassandra.locator.AbstractReplicationStrategy.recognizedOptions:()Ljava/util/Collection;
astore 1
start local 1 1: aload 1
ifnonnull 3
2: return
3: StackMap locals: java.util.Collection
StackMap stack:
aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.configOptions:Ljava/util/Map;
invokeinterface java.util.Map.keySet:()Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 3
goto 7
StackMap locals: org.apache.cassandra.locator.AbstractReplicationStrategy java.util.Collection top java.util.Iterator
StackMap stack:
4: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 2
start local 2 5: aload 1
aload 2
invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
ifne 7
6: new org.apache.cassandra.exceptions.ConfigurationException
dup
ldc "Unrecognized strategy option {%s} passed to %s for keyspace %s"
iconst_3
anewarray java.lang.Object
dup
iconst_0
aload 2
aastore
dup
iconst_1
aload 0
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokevirtual java.lang.Class.getSimpleName:()Ljava/lang/String;
aastore
dup
iconst_2
aload 0
getfield org.apache.cassandra.locator.AbstractReplicationStrategy.keyspaceName:Ljava/lang/String;
aastore
invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;)V
athrow
end local 2 7: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
8: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/apache/cassandra/locator/AbstractReplicationStrategy;
1 9 1 expectedOptions Ljava/util/Collection;
5 7 2 key Ljava/lang/String;
Exceptions:
throws org.apache.cassandra.exceptions.ConfigurationException
}
SourceFile: "AbstractReplicationStrategy.java"