public class org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor extends org.apache.kafkaesqueesqueesque.clients.consumer.internals.AbstractPartitionAssignor
{
public void <init>()
{
org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor v;
v := @this: org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor;
specialinvoke v.<org.apache.kafkaesqueesqueesque.clients.consumer.internals.AbstractPartitionAssignor: void <init>()>();
return;
}
public java.util.Map assign(java.util.Map, java.util.Map)
{
java.util.HashMap v;
java.util.ArrayList v, v;
org.apache.kafkaesqueesqueesque.common.utils.CircularIterator v;
java.util.Map v, v;
org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor v;
java.lang.String v, v, v;
boolean v, v, v;
java.util.Iterator v, v;
java.util.Set v;
org.apache.kafkaesqueesqueesque.clients.consumer.internals.AbstractPartitionAssignor$MemberInfo v;
java.util.List v, v, v;
java.util.Optional v;
java.lang.Object v, v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = new org.apache.kafkaesqueesqueesque.clients.consumer.internals.AbstractPartitionAssignor$MemberInfo;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.kafkaesqueesqueesque.clients.consumer.ConsumerPartitionAssignor$Subscription: java.util.Optional groupInstanceId()>();
specialinvoke v.<org.apache.kafkaesqueesqueesque.clients.consumer.internals.AbstractPartitionAssignor$MemberInfo: void <init>(java.lang.String,java.util.Optional)>(v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = new org.apache.kafkaesqueesqueesque.common.utils.CircularIterator;
v = staticinvoke <org.apache.kafkaesqueesqueesque.common.utils.Utils: java.util.List sorted(java.util.Collection)>(v);
specialinvoke v.<org.apache.kafkaesqueesqueesque.common.utils.CircularIterator: void <init>(java.util.List)>(v);
v = specialinvoke v.<org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor: java.util.List allPartitionsSorted(java.util.Map,java.util.Map)>(v, v);
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.kafkaesqueesqueesque.common.TopicPartition: java.lang.String topic()>();
label:
v = virtualinvoke v.<org.apache.kafkaesqueesqueesque.common.utils.CircularIterator: java.lang.Object peek()>();
v = v.<org.apache.kafkaesqueesqueesque.clients.consumer.internals.AbstractPartitionAssignor$MemberInfo: java.lang.String memberId>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.kafkaesqueesqueesque.clients.consumer.ConsumerPartitionAssignor$Subscription: java.util.List topics()>();
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
virtualinvoke v.<org.apache.kafkaesqueesqueesque.common.utils.CircularIterator: java.lang.Object next()>();
goto label;
label:
v = virtualinvoke v.<org.apache.kafkaesqueesqueesque.common.utils.CircularIterator: java.lang.Object next()>();
v = v.<org.apache.kafkaesqueesqueesque.clients.consumer.internals.AbstractPartitionAssignor$MemberInfo: java.lang.String memberId>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
return v;
}
private java.util.List allPartitionsSorted(java.util.Map, java.util.Map)
{
java.util.TreeSet v;
java.util.ArrayList v;
java.util.Map v, v;
int v;
org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor v;
boolean v, v;
java.util.Iterator v, v;
java.util.Collection v;
java.util.List v, v;
java.lang.Object v, v, v;
v := @this: org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = new java.util.TreeSet;
specialinvoke v.<java.util.TreeSet: void <init>()>();
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.kafkaesqueesqueesque.clients.consumer.ConsumerPartitionAssignor$Subscription: java.util.List topics()>();
interfaceinvoke v.<java.util.SortedSet: boolean addAll(java.util.Collection)>(v);
goto label;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<java.util.SortedSet: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = staticinvoke <org.apache.kafkaesqueesqueesque.clients.consumer.internals.AbstractPartitionAssignor: java.util.List partitions(java.lang.String,int)>(v, v);
interfaceinvoke v.<java.util.List: boolean addAll(java.util.Collection)>(v);
goto label;
label:
return v;
}
public java.lang.String name()
{
org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor v;
v := @this: org.apache.kafkaesqueesqueesque.clients.consumer.RoundRobinAssignor;
return "roundrobin";
}
}