public class com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper implements java.lang.AutoCloseable
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper
super_class: java.lang.Object
{
private static final org.slf4j.Logger LOG;
descriptor: Lorg/slf4j/Logger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private final com.datastax.oss.driver.internal.core.context.InternalDriverContext context;
descriptor: Lcom/datastax/oss/driver/internal/core/context/InternalDriverContext;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.Set<com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy> policies;
descriptor: Ljava/util/Set;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Set<Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;>;
private final java.util.Map<java.lang.String, com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy> policiesPerProfile;
descriptor: Ljava/util/Map;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Map<Ljava/lang/String;Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;>;
private final java.util.Map<com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy, com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$SinglePolicyDistanceReporter> reporters;
descriptor: Ljava/util/Map;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Map<Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$SinglePolicyDistanceReporter;>;
private final java.util.concurrent.locks.Lock distancesLock;
descriptor: Ljava/util/concurrent/locks/Lock;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.Map<com.datastax.oss.driver.api.core.metadata.Node, java.util.Map<com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy, com.datastax.oss.driver.api.core.loadbalancing.NodeDistance>> distances;
descriptor: Ljava/util/Map;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Map<Lcom/datastax/oss/driver/api/core/metadata/Node;Ljava/util/Map<Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;Lcom/datastax/oss/driver/api/core/loadbalancing/NodeDistance;>;>;
RuntimeVisibleAnnotations:
net.jcip.annotations.GuardedBy(value = "distancesLock")
private final java.lang.String logPrefix;
descriptor: Ljava/lang/String;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final com.datastax.oss.driver.internal.core.util.concurrent.ReplayingEventFilter<com.datastax.oss.driver.internal.core.metadata.NodeStateEvent> eventFilter;
descriptor: Lcom/datastax/oss/driver/internal/core/util/concurrent/ReplayingEventFilter;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lcom/datastax/oss/driver/internal/core/util/concurrent/ReplayingEventFilter<Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;>;
private final java.util.concurrent.atomic.AtomicReference<com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State> stateRef;
descriptor: Ljava/util/concurrent/atomic/AtomicReference;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicReference<Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;>;
static final boolean $assertionsDisabled;
descriptor: Z
flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC
private static volatile int[] $SWITCH_TABLE$com$datastax$oss$driver$internal$core$metadata$LoadBalancingPolicyWrapper$State;
descriptor: [I
flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
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 com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.$assertionsDisabled:Z
3: ldc Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
putstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.LOG:Lorg/slf4j/Logger;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(com.datastax.oss.driver.internal.core.context.InternalDriverContext, java.util.Map<java.lang.String, com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy>);
descriptor: (Lcom/datastax/oss/driver/internal/core/context/InternalDriverContext;Ljava/util/Map;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.concurrent.locks.ReentrantLock
dup
invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.distancesLock:Ljava/util/concurrent/locks/Lock;
2: aload 0
3: new com.datastax.oss.driver.internal.core.util.concurrent.ReplayingEventFilter
dup
aload 0
invokedynamic accept(Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;)Ljava/util/function/Consumer;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
(Ljava/lang/Object;)V
com/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper.processNodeStateEvent(Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;)V (7)
(Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;)V
invokespecial com.datastax.oss.driver.internal.core.util.concurrent.ReplayingEventFilter.<init>:(Ljava/util/function/Consumer;)V
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.eventFilter:Lcom/datastax/oss/driver/internal/core/util/concurrent/ReplayingEventFilter;
4: aload 0
new java.util.concurrent.atomic.AtomicReference
dup
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.BEFORE_INIT:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
invokespecial java.util.concurrent.atomic.AtomicReference.<init>:(Ljava/lang/Object;)V
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.stateRef:Ljava/util/concurrent/atomic/AtomicReference;
5: aload 0
aload 1
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.context:Lcom/datastax/oss/driver/internal/core/context/InternalDriverContext;
6: aload 0
aload 2
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.policiesPerProfile:Ljava/util/Map;
7: invokestatic com.datastax.oss.driver.shaded.guava.common.collect.ImmutableMap.builder:()Lcom/datastax/oss/driver/shaded/guava/common/collect/ImmutableMap$Builder;
8: astore 3
start local 3 9: aload 2
invokeinterface java.util.Map.values:()Ljava/util/Collection;
invokestatic com.datastax.oss.driver.shaded.guava.common.collect.ImmutableSet.copyOf:(Ljava/util/Collection;)Lcom/datastax/oss/driver/shaded/guava/common/collect/ImmutableSet;
invokevirtual com.datastax.oss.driver.shaded.guava.common.collect.ImmutableSet.iterator:()Ljava/util/Iterator;
astore 5
goto 12
StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.context.InternalDriverContext java.util.Map com.datastax.oss.driver.shaded.guava.common.collect.ImmutableMap$Builder top java.util.Iterator
StackMap stack:
10: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
astore 4
start local 4 11: aload 3
aload 4
new com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$SinglePolicyDistanceReporter
dup
aload 0
aload 4
invokespecial com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$SinglePolicyDistanceReporter.<init>:(Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;)V
invokevirtual com.datastax.oss.driver.shaded.guava.common.collect.ImmutableMap$Builder.put:(Ljava/lang/Object;Ljava/lang/Object;)Lcom/datastax/oss/driver/shaded/guava/common/collect/ImmutableMap$Builder;
pop
end local 4 12: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 10
13: aload 0
aload 3
invokevirtual com.datastax.oss.driver.shaded.guava.common.collect.ImmutableMap$Builder.build:()Lcom/datastax/oss/driver/shaded/guava/common/collect/ImmutableMap;
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.reporters:Ljava/util/Map;
14: aload 0
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.reporters:Ljava/util/Map;
invokeinterface java.util.Map.keySet:()Ljava/util/Set;
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.policies:Ljava/util/Set;
15: aload 0
new java.util.HashMap
dup
invokespecial java.util.HashMap.<init>:()V
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.distances:Ljava/util/Map;
16: aload 0
aload 1
invokeinterface com.datastax.oss.driver.internal.core.context.InternalDriverContext.getSessionName:()Ljava/lang/String;
putfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.logPrefix:Ljava/lang/String;
17: aload 1
invokeinterface com.datastax.oss.driver.internal.core.context.InternalDriverContext.getEventBus:()Lcom/datastax/oss/driver/internal/core/context/EventBus;
ldc Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;
aload 0
invokedynamic accept(Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;)Ljava/util/function/Consumer;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
(Ljava/lang/Object;)V
com/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper.onNodeStateEvent(Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;)V (7)
(Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;)V
invokevirtual com.datastax.oss.driver.internal.core.context.EventBus.register:(Ljava/lang/Class;Ljava/util/function/Consumer;)Ljava/lang/Object;
pop
18: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
0 19 1 context Lcom/datastax/oss/driver/internal/core/context/InternalDriverContext;
0 19 2 policiesPerProfile Ljava/util/Map<Ljava/lang/String;Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;>;
9 19 3 reportersBuilder Lcom/datastax/oss/driver/shaded/guava/common/collect/ImmutableMap$Builder<Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$SinglePolicyDistanceReporter;>;
11 12 4 policy Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;
Signature: (Lcom/datastax/oss/driver/internal/core/context/InternalDriverContext;Ljava/util/Map<Ljava/lang/String;Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;>;)V
RuntimeInvisibleParameterAnnotations:
0:
edu.umd.cs.findbugs.annotations.NonNull()
1:
edu.umd.cs.findbugs.annotations.NonNull()
MethodParameters:
Name Flags
context
policiesPerProfile
public void init();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=5, args_size=1
start local 0 0: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.stateRef:Ljava/util/concurrent/atomic/AtomicReference;
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.BEFORE_INIT:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.DURING_INIT:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
invokevirtual java.util.concurrent.atomic.AtomicReference.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Z
ifeq 17
1: getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.LOG:Lorg/slf4j/Logger;
ldc "[{}] Initializing policies"
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.logPrefix:Ljava/lang/String;
invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
2: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.eventFilter:Lcom/datastax/oss/driver/internal/core/util/concurrent/ReplayingEventFilter;
invokevirtual com.datastax.oss.driver.internal.core.util.concurrent.ReplayingEventFilter.start:()V
3: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.context:Lcom/datastax/oss/driver/internal/core/context/InternalDriverContext;
invokeinterface com.datastax.oss.driver.internal.core.context.InternalDriverContext.getMetadataManager:()Lcom/datastax/oss/driver/internal/core/metadata/MetadataManager;
astore 1
start local 1 4: aload 1
invokevirtual com.datastax.oss.driver.internal.core.metadata.MetadataManager.getMetadata:()Lcom/datastax/oss/driver/api/core/metadata/Metadata;
astore 2
start local 2 5: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.policies:Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 4
goto 8
StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.MetadataManager com.datastax.oss.driver.api.core.metadata.Metadata top java.util.Iterator
StackMap stack:
6: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
astore 3
start local 3 7: aload 3
aload 2
invokeinterface com.datastax.oss.driver.api.core.metadata.Metadata.getNodes:()Ljava/util/Map;
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.reporters:Ljava/util/Map;
aload 3
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy$DistanceReporter
invokeinterface com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy.init:(Ljava/util/Map;Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy$DistanceReporter;)V
end local 3 8: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 6
9: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.stateRef:Ljava/util/concurrent/atomic/AtomicReference;
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.DURING_INIT:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.RUNNING:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
invokevirtual java.util.concurrent.atomic.AtomicReference.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Z
ifeq 12
10: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.eventFilter:Lcom/datastax/oss/driver/internal/core/util/concurrent/ReplayingEventFilter;
invokevirtual com.datastax.oss.driver.internal.core.util.concurrent.ReplayingEventFilter.markReady:()V
11: goto 17
12: StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.MetadataManager com.datastax.oss.driver.api.core.metadata.Metadata
StackMap stack:
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.$assertionsDisabled:Z
ifne 13
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.stateRef:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.CLOSING:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
if_acmpeq 13
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
13: StackMap locals:
StackMap stack:
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.policies:Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 4
goto 16
StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.MetadataManager com.datastax.oss.driver.api.core.metadata.Metadata top java.util.Iterator
StackMap stack:
14: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
astore 3
start local 3 15: aload 3
invokeinterface com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy.close:()V
end local 3 16: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 14
end local 2 end local 1 17: StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
4 17 1 metadataManager Lcom/datastax/oss/driver/internal/core/metadata/MetadataManager;
5 17 2 metadata Lcom/datastax/oss/driver/api/core/metadata/Metadata;
7 8 3 policy Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;
15 16 3 policy Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;
public java.util.Queue<com.datastax.oss.driver.api.core.metadata.Node> newQueryPlan(com.datastax.oss.driver.api.core.session.Request, java.lang.String, com.datastax.oss.driver.api.core.session.Session);
descriptor: (Lcom/datastax/oss/driver/api/core/session/Request;Ljava/lang/String;Lcom/datastax/oss/driver/api/core/session/Session;)Ljava/util/Queue;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=4
start local 0 start local 1 start local 2 start local 3 0: invokestatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.$SWITCH_TABLE$com$datastax$oss$driver$internal$core$metadata$LoadBalancingPolicyWrapper$State:()[I
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.stateRef:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State
invokevirtual com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.ordinal:()I
iaload
tableswitch { // 1 - 3
1: 1
2: 1
3: 4
default: 8
}
1: StackMap locals:
StackMap stack:
new java.util.ArrayList
dup
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.context:Lcom/datastax/oss/driver/internal/core/context/InternalDriverContext;
invokeinterface com.datastax.oss.driver.internal.core.context.InternalDriverContext.getMetadataManager:()Lcom/datastax/oss/driver/internal/core/metadata/MetadataManager;
invokevirtual com.datastax.oss.driver.internal.core.metadata.MetadataManager.getContactPoints:()Ljava/util/Set;
invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
astore 4
start local 4 2: aload 4
invokestatic java.util.Collections.shuffle:(Ljava/util/List;)V
3: new java.util.concurrent.ConcurrentLinkedQueue
dup
aload 4
invokespecial java.util.concurrent.ConcurrentLinkedQueue.<init>:(Ljava/util/Collection;)V
areturn
end local 4 4: StackMap locals:
StackMap stack:
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.policiesPerProfile:Ljava/util/Map;
aload 2
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
astore 5
start local 5 5: aload 5
ifnonnull 7
6: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.policiesPerProfile:Ljava/util/Map;
ldc "default"
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
astore 5
7: StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.api.core.session.Request java.lang.String com.datastax.oss.driver.api.core.session.Session top com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
StackMap stack:
aload 5
aload 1
aload 3
invokeinterface com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy.newQueryPlan:(Lcom/datastax/oss/driver/api/core/session/Request;Lcom/datastax/oss/driver/api/core/session/Session;)Ljava/util/Queue;
areturn
end local 5 8: StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.api.core.session.Request java.lang.String com.datastax.oss.driver.api.core.session.Session
StackMap stack:
new java.util.concurrent.ConcurrentLinkedQueue
dup
invokespecial java.util.concurrent.ConcurrentLinkedQueue.<init>:()V
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
0 9 1 request Lcom/datastax/oss/driver/api/core/session/Request;
0 9 2 executionProfileName Ljava/lang/String;
0 9 3 session Lcom/datastax/oss/driver/api/core/session/Session;
2 4 4 nodes Ljava/util/List<Lcom/datastax/oss/driver/api/core/metadata/Node;>;
5 8 5 policy Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;
Signature: (Lcom/datastax/oss/driver/api/core/session/Request;Ljava/lang/String;Lcom/datastax/oss/driver/api/core/session/Session;)Ljava/util/Queue<Lcom/datastax/oss/driver/api/core/metadata/Node;>;
RuntimeInvisibleAnnotations:
edu.umd.cs.findbugs.annotations.NonNull()
RuntimeInvisibleParameterAnnotations:
0:
edu.umd.cs.findbugs.annotations.Nullable()
1:
edu.umd.cs.findbugs.annotations.NonNull()
2:
edu.umd.cs.findbugs.annotations.Nullable()
MethodParameters:
Name Flags
request
executionProfileName
session
public java.util.Queue<com.datastax.oss.driver.api.core.metadata.Node> newQueryPlan();
descriptor: ()Ljava/util/Queue;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
aconst_null
ldc "default"
aconst_null
invokevirtual com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.newQueryPlan:(Lcom/datastax/oss/driver/api/core/session/Request;Ljava/lang/String;Lcom/datastax/oss/driver/api/core/session/Session;)Ljava/util/Queue;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
Signature: ()Ljava/util/Queue<Lcom/datastax/oss/driver/api/core/metadata/Node;>;
RuntimeInvisibleAnnotations:
edu.umd.cs.findbugs.annotations.NonNull()
private void onNodeStateEvent(com.datastax.oss.driver.internal.core.metadata.NodeStateEvent);
descriptor: (Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.eventFilter:Lcom/datastax/oss/driver/internal/core/util/concurrent/ReplayingEventFilter;
aload 1
invokevirtual com.datastax.oss.driver.internal.core.util.concurrent.ReplayingEventFilter.accept:(Ljava/lang/Object;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
0 2 1 event Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;
MethodParameters:
Name Flags
event
private void processNodeStateEvent(com.datastax.oss.driver.internal.core.metadata.NodeStateEvent);
descriptor: (Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=4, args_size=2
start local 0 start local 1 0: invokestatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.$SWITCH_TABLE$com$datastax$oss$driver$internal$core$metadata$LoadBalancingPolicyWrapper$State:()[I
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.stateRef:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State
invokevirtual com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.ordinal:()I
iaload
tableswitch { // 1 - 4
1: 1
2: 1
3: 3
4: 2
default: 19
}
1: StackMap locals:
StackMap stack:
new java.lang.AssertionError
dup
ldc "Filter should not be marked ready until LBP init"
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
2: StackMap locals:
StackMap stack:
return
3: StackMap locals:
StackMap stack:
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.policies:Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 3
goto 18
StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.NodeStateEvent top java.util.Iterator
StackMap stack:
4: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
astore 2
start local 2 5: aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.newState:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
getstatic com.datastax.oss.driver.api.core.metadata.NodeState.UP:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
if_acmpne 8
6: aload 2
aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.node:Lcom/datastax/oss/driver/internal/core/metadata/DefaultNode;
invokeinterface com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy.onUp:(Lcom/datastax/oss/driver/api/core/metadata/Node;)V
7: goto 18
StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.NodeStateEvent com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy java.util.Iterator
StackMap stack:
8: aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.newState:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
getstatic com.datastax.oss.driver.api.core.metadata.NodeState.DOWN:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
if_acmpeq 9
aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.newState:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
getstatic com.datastax.oss.driver.api.core.metadata.NodeState.FORCED_DOWN:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
if_acmpne 11
9: StackMap locals:
StackMap stack:
aload 2
aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.node:Lcom/datastax/oss/driver/internal/core/metadata/DefaultNode;
invokeinterface com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy.onDown:(Lcom/datastax/oss/driver/api/core/metadata/Node;)V
10: goto 18
StackMap locals:
StackMap stack:
11: aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.newState:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
getstatic com.datastax.oss.driver.api.core.metadata.NodeState.UNKNOWN:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
if_acmpne 14
12: aload 2
aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.node:Lcom/datastax/oss/driver/internal/core/metadata/DefaultNode;
invokeinterface com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy.onAdd:(Lcom/datastax/oss/driver/api/core/metadata/Node;)V
13: goto 18
StackMap locals:
StackMap stack:
14: aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.newState:Lcom/datastax/oss/driver/api/core/metadata/NodeState;
ifnonnull 17
15: aload 2
aload 1
getfield com.datastax.oss.driver.internal.core.metadata.NodeStateEvent.node:Lcom/datastax/oss/driver/internal/core/metadata/DefaultNode;
invokeinterface com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy.onRemove:(Lcom/datastax/oss/driver/api/core/metadata/Node;)V
16: goto 18
17: StackMap locals:
StackMap stack:
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.LOG:Lorg/slf4j/Logger;
ldc "[{}] Unsupported event: {}"
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.logPrefix:Ljava/lang/String;
aload 1
invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
end local 2 18: StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.NodeStateEvent top java.util.Iterator
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
19: StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.NodeStateEvent
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 20 0 this Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
0 20 1 event Lcom/datastax/oss/driver/internal/core/metadata/NodeStateEvent;
5 18 2 policy Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;
MethodParameters:
Name Flags
event
public void close();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=1
start local 0 0: StackMap locals:
StackMap stack:
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.stateRef:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State
astore 1
start local 1 1: aload 1
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.CLOSING:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
if_acmpne 3
2: return
3: StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State
StackMap stack:
aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.stateRef:Ljava/util/concurrent/atomic/AtomicReference;
aload 1
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.CLOSING:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
invokevirtual java.util.concurrent.atomic.AtomicReference.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Z
ifeq 0
4: aload 1
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.RUNNING:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
if_acmpne 9
5: aload 0
getfield com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.policies:Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 3
goto 8
StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State top java.util.Iterator
StackMap stack:
6: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
astore 2
start local 2 7: aload 2
invokeinterface com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy.close:()V
end local 2 8: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 6
9: StackMap locals: com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper;
1 10 1 old Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
7 8 2 policy Lcom/datastax/oss/driver/api/core/loadbalancing/LoadBalancingPolicy;
static int[] $SWITCH_TABLE$com$datastax$oss$driver$internal$core$metadata$LoadBalancingPolicyWrapper$State();
descriptor: ()[I
flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
Code:
stack=3, locals=1, args_size=0
0: getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.$SWITCH_TABLE$com$datastax$oss$driver$internal$core$metadata$LoadBalancingPolicyWrapper$State:[I
dup
ifnull 1
areturn
StackMap locals:
StackMap stack: int[]
1: pop
invokestatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.values:()[Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
arraylength
newarray 10
astore 0
2: aload 0
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.BEFORE_INIT:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
invokevirtual com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.ordinal:()I
iconst_1
iastore
3: goto 5
StackMap locals: int[]
StackMap stack: java.lang.NoSuchFieldError
4: pop
StackMap locals:
StackMap stack:
5: aload 0
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.CLOSING:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
invokevirtual com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.ordinal:()I
iconst_4
iastore
6: goto 8
StackMap locals:
StackMap stack: java.lang.NoSuchFieldError
7: pop
StackMap locals:
StackMap stack:
8: aload 0
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.DURING_INIT:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
invokevirtual com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.ordinal:()I
iconst_2
iastore
9: goto 11
StackMap locals:
StackMap stack: java.lang.NoSuchFieldError
10: pop
StackMap locals:
StackMap stack:
11: aload 0
getstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.RUNNING:Lcom/datastax/oss/driver/internal/core/metadata/LoadBalancingPolicyWrapper$State;
invokevirtual com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State.ordinal:()I
iconst_3
iastore
12: goto 14
StackMap locals:
StackMap stack: java.lang.NoSuchFieldError
13: pop
StackMap locals:
StackMap stack:
14: aload 0
dup
putstatic com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper.$SWITCH_TABLE$com$datastax$oss$driver$internal$core$metadata$LoadBalancingPolicyWrapper$State:[I
areturn
LocalVariableTable:
Start End Slot Name Signature
Exception table:
from to target type
2 3 4 Class java.lang.NoSuchFieldError
5 6 7 Class java.lang.NoSuchFieldError
8 9 10 Class java.lang.NoSuchFieldError
11 12 13 Class java.lang.NoSuchFieldError
}
SourceFile: "LoadBalancingPolicyWrapper.java"
NestMembers:
com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$SinglePolicyDistanceReporter com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State
InnerClasses:
public abstract DistanceReporter = com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy$DistanceReporter of com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy
private SinglePolicyDistanceReporter = com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$SinglePolicyDistanceReporter of com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper
private final State = com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper$State of com.datastax.oss.driver.internal.core.metadata.LoadBalancingPolicyWrapper
public Builder = com.datastax.oss.driver.shaded.guava.common.collect.ImmutableMap$Builder of com.datastax.oss.driver.shaded.guava.common.collect.ImmutableMap
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
RuntimeVisibleAnnotations:
net.jcip.annotations.ThreadSafe()