public class org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter
super_class: java.lang.Object
{
private final java.lang.String localRack;
descriptor: Ljava/lang/String;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final com.google.common.collect.Multimap<java.lang.String, java.net.InetAddress> endpoints;
descriptor: Lcom/google/common/collect/Multimap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lcom/google/common/collect/Multimap<Ljava/lang/String;Ljava/net/InetAddress;>;
public void <init>(java.lang.String, com.google.common.collect.Multimap<java.lang.String, java.net.InetAddress>);
descriptor: (Ljava/lang/String;Lcom/google/common/collect/Multimap;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 1
putfield org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.localRack:Ljava/lang/String;
2: aload 0
aload 2
putfield org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.endpoints:Lcom/google/common/collect/Multimap;
3: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/cassandra/batchlog/BatchlogManager$EndpointFilter;
0 4 1 localRack Ljava/lang/String;
0 4 2 endpoints Lcom/google/common/collect/Multimap<Ljava/lang/String;Ljava/net/InetAddress;>;
Signature: (Ljava/lang/String;Lcom/google/common/collect/Multimap<Ljava/lang/String;Ljava/net/InetAddress;>;)V
MethodParameters:
Name Flags
localRack
endpoints
public java.util.Collection<java.net.InetAddress> filter();
descriptor: ()Ljava/util/Collection;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=7, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.endpoints:Lcom/google/common/collect/Multimap;
invokeinterface com.google.common.collect.Multimap.values:()Ljava/util/Collection;
invokeinterface java.util.Collection.size:()I
iconst_1
if_icmpne 2
1: aload 0
getfield org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.endpoints:Lcom/google/common/collect/Multimap;
invokeinterface com.google.common.collect.Multimap.values:()Ljava/util/Collection;
areturn
2: StackMap locals:
StackMap stack:
invokestatic com.google.common.collect.ArrayListMultimap.create:()Lcom/google/common/collect/ArrayListMultimap;
astore 1
start local 1 3: aload 0
getfield org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.endpoints:Lcom/google/common/collect/Multimap;
invokeinterface com.google.common.collect.Multimap.entries:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 3
goto 7
StackMap locals: org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter com.google.common.collect.ListMultimap top java.util.Iterator
StackMap stack:
4: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.util.Map$Entry
astore 2
start local 2 5: aload 0
aload 2
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast java.net.InetAddress
invokevirtual org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.isValid:(Ljava/net/InetAddress;)Z
ifeq 7
6: aload 1
aload 2
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
checkcast java.lang.String
aload 2
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast java.net.InetAddress
invokeinterface com.google.common.collect.ListMultimap.put:(Ljava/lang/Object;Ljava/lang/Object;)Z
pop
end local 2 7: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
8: aload 1
invokeinterface com.google.common.collect.ListMultimap.size:()I
iconst_2
if_icmpgt 10
9: aload 1
invokeinterface com.google.common.collect.ListMultimap.values:()Ljava/util/Collection;
areturn
10: StackMap locals: org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter com.google.common.collect.ListMultimap
StackMap stack:
aload 1
invokeinterface com.google.common.collect.ListMultimap.size:()I
aload 1
aload 0
getfield org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.localRack:Ljava/lang/String;
invokeinterface com.google.common.collect.ListMultimap.get:(Ljava/lang/Object;)Ljava/util/List;
invokeinterface java.util.List.size:()I
isub
iconst_2
if_icmplt 12
11: aload 1
aload 0
getfield org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.localRack:Ljava/lang/String;
invokeinterface com.google.common.collect.ListMultimap.removeAll:(Ljava/lang/Object;)Ljava/util/List;
pop
12: StackMap locals:
StackMap stack:
aload 1
invokeinterface com.google.common.collect.ListMultimap.keySet:()Ljava/util/Set;
invokeinterface java.util.Set.size:()I
iconst_1
if_icmpne 16
13: aload 1
invokeinterface com.google.common.collect.ListMultimap.values:()Ljava/util/Collection;
invokestatic com.google.common.collect.Lists.newArrayList:(Ljava/lang/Iterable;)Ljava/util/ArrayList;
astore 2
start local 2 14: aload 0
aload 2
invokevirtual org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.shuffle:(Ljava/util/List;)V
15: aload 2
iconst_0
iconst_2
invokeinterface java.util.List.subList:(II)Ljava/util/List;
areturn
end local 2 16: StackMap locals:
StackMap stack:
aload 1
invokeinterface com.google.common.collect.ListMultimap.keySet:()Ljava/util/Set;
invokeinterface java.util.Set.size:()I
iconst_2
if_icmpne 19
17: aload 1
invokeinterface com.google.common.collect.ListMultimap.keySet:()Ljava/util/Set;
astore 2
start local 2 18: goto 21
end local 2 19: StackMap locals:
StackMap stack:
aload 1
invokeinterface com.google.common.collect.ListMultimap.keySet:()Ljava/util/Set;
invokestatic com.google.common.collect.Lists.newArrayList:(Ljava/lang/Iterable;)Ljava/util/ArrayList;
astore 2
start local 2 20: aload 0
aload 2
checkcast java.util.List
invokevirtual org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.shuffle:(Ljava/util/List;)V
21: StackMap locals: java.util.Collection
StackMap stack:
new java.util.ArrayList
dup
iconst_2
invokespecial java.util.ArrayList.<init>:(I)V
astore 3
start local 3 22: aload 2
iconst_2
invokestatic com.google.common.collect.Iterables.limit:(Ljava/lang/Iterable;I)Ljava/lang/Iterable;
invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
astore 5
goto 26
StackMap locals: org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter com.google.common.collect.ListMultimap java.util.Collection java.util.List top java.util.Iterator
StackMap stack:
23: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 4
start local 4 24: aload 1
aload 4
invokeinterface com.google.common.collect.ListMultimap.get:(Ljava/lang/Object;)Ljava/util/List;
astore 6
start local 6 25: aload 3
aload 6
aload 0
aload 6
invokeinterface java.util.List.size:()I
invokevirtual org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter.getRandomInt:(I)I
invokeinterface java.util.List.get:(I)Ljava/lang/Object;
checkcast java.net.InetAddress
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 6 end local 4 26: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 23
27: aload 3
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Lorg/apache/cassandra/batchlog/BatchlogManager$EndpointFilter;
3 28 1 validated Lcom/google/common/collect/ListMultimap<Ljava/lang/String;Ljava/net/InetAddress;>;
5 7 2 entry Ljava/util/Map$Entry<Ljava/lang/String;Ljava/net/InetAddress;>;
14 16 2 otherRack Ljava/util/List<Ljava/net/InetAddress;>;
18 19 2 racks Ljava/util/Collection<Ljava/lang/String;>;
20 28 2 racks Ljava/util/Collection<Ljava/lang/String;>;
22 28 3 result Ljava/util/List<Ljava/net/InetAddress;>;
24 26 4 rack Ljava/lang/String;
25 26 6 rackMembers Ljava/util/List<Ljava/net/InetAddress;>;
Signature: ()Ljava/util/Collection<Ljava/net/InetAddress;>;
protected boolean isValid(java.net.InetAddress);
descriptor: (Ljava/net/InetAddress;)Z
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokestatic org.apache.cassandra.utils.FBUtilities.getBroadcastAddress:()Ljava/net/InetAddress;
invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
ifne 1
getstatic org.apache.cassandra.gms.FailureDetector.instance:Lorg/apache/cassandra/gms/IFailureDetector;
aload 1
invokeinterface org.apache.cassandra.gms.IFailureDetector.isAlive:(Ljava/net/InetAddress;)Z
ifeq 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/batchlog/BatchlogManager$EndpointFilter;
0 2 1 input Ljava/net/InetAddress;
RuntimeInvisibleAnnotations:
com.google.common.annotations.VisibleForTesting()
RuntimeInvisibleTypeAnnotations:
METHOD_RETURN
com.google.common.annotations.VisibleForTesting()
MethodParameters:
Name Flags
input
protected int getRandomInt(int);
descriptor: (I)I
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: invokestatic java.util.concurrent.ThreadLocalRandom.current:()Ljava/util/concurrent/ThreadLocalRandom;
iload 1
invokevirtual java.util.concurrent.ThreadLocalRandom.nextInt:(I)I
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/batchlog/BatchlogManager$EndpointFilter;
0 1 1 bound I
RuntimeInvisibleAnnotations:
com.google.common.annotations.VisibleForTesting()
RuntimeInvisibleTypeAnnotations:
METHOD_RETURN
com.google.common.annotations.VisibleForTesting()
MethodParameters:
Name Flags
bound
protected void shuffle(java.util.List<?>);
descriptor: (Ljava/util/List;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokestatic java.util.Collections.shuffle:(Ljava/util/List;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/cassandra/batchlog/BatchlogManager$EndpointFilter;
0 2 1 list Ljava/util/List<*>;
Signature: (Ljava/util/List<*>;)V
RuntimeInvisibleAnnotations:
com.google.common.annotations.VisibleForTesting()
MethodParameters:
Name Flags
list
}
SourceFile: "BatchlogManager.java"
NestHost: org.apache.cassandra.batchlog.BatchlogManager
InnerClasses:
public abstract Entry = java.util.Map$Entry of java.util.Map
public EndpointFilter = org.apache.cassandra.batchlog.BatchlogManager$EndpointFilter of org.apache.cassandra.batchlog.BatchlogManager