public abstract class org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor extends org.apache.kafkaesque.clients.consumer.internals.AbstractPartitionAssignor
{
private static final org.slf4j.Logger log;
public static final int DEFAULT_GENERATION;
private org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements partitionMovements;
static final boolean $assertionsDisabled;
public void <init>()
{
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractPartitionAssignor: void <init>()>();
return;
}
protected abstract org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData memberData(org.apache.kafkaesque.clients.consumer.ConsumerPartitionAssignor$Subscription);
public java.util.Map assign(java.util.Map, java.util.Map)
{
java.util.Map v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements v;
java.util.Set v, v, v, v, v, v;
java.util.stream.Stream v, v;
java.util.TreeSet v;
java.util.ArrayList v, v, v, v;
java.lang.String v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.function.Predicate v;
java.util.List v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$SubscriptionComparator v;
org.apache.kafkaesque.common.TopicPartition v;
java.util.HashMap v, v, v, v, v;
int v, v;
java.util.Iterator v, v, v, v, v, v, v;
java.util.function.Consumer v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
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.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = new org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements: void <init>()>();
v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements partitionMovements> = v;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void prepopulateCurrentAssignments(java.util.Map,java.util.Map,java.util.Map)>(v, v, v);
v = interfaceinvoke v.<java.util.Map: boolean isEmpty()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: 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 = 0;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v >= v goto label;
v = new org.apache.kafkaesque.common.TopicPartition;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
specialinvoke v.<org.apache.kafkaesque.common.TopicPartition: void <init>(java.lang.String,int)>(v, v);
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 = v + 1;
goto label;
label:
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.kafkaesque.clients.consumer.ConsumerPartitionAssignor$Subscription: java.util.List topics()>();
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$lambda_assign_0__953: java.util.function.Predicate bootstrap$(java.util.Map)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream filter(java.util.function.Predicate)>(v);
v = staticinvoke <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$lambda_assign_1__954: java.util.function.Consumer bootstrap$(java.util.Map,java.util.Map,java.lang.String,java.util.Map)>(v, v, v, v);
interfaceinvoke v.<java.util.stream.Stream: void forEach(java.util.function.Consumer)>(v);
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
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);
goto label;
label:
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: 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 getValue()>();
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: java.util.List sortPartitions(java.util.Map,java.util.Set,boolean,java.util.Map,java.util.Map)>(v, v, v, v, v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = 0;
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 = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
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()>();
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
goto label;
label:
interfaceinvoke v.<java.util.Iterator: void remove()>();
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
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 = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
interfaceinvoke v.<java.util.Iterator: void remove()>();
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.kafkaesque.clients.consumer.ConsumerPartitionAssignor$Subscription: java.util.List topics()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.TopicPartition: java.lang.String topic()>();
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
interfaceinvoke v.<java.util.Iterator: void remove()>();
v = 1;
goto label;
label:
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
goto label;
label:
v = new java.util.TreeSet;
v = new org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$SubscriptionComparator;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$SubscriptionComparator: void <init>(java.util.Map)>(v);
specialinvoke v.<java.util.TreeSet: void <init>(java.util.Comparator)>(v);
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
virtualinvoke v.<java.util.TreeSet: boolean addAll(java.util.Collection)>(v);
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void balance(java.util.Map,java.util.Map,java.util.List,java.util.List,java.util.TreeSet,java.util.Map,java.util.Map,java.util.Map,boolean)>(v, v, v, v, v, v, v, v, v);
return v;
}
private void prepopulateCurrentAssignments(java.util.Map, java.util.Map, java.util.Map)
{
java.lang.Integer v, v, v;
java.util.Map v, v, v;
boolean v, v, v, v, v, v, v;
java.util.Set v, v;
java.util.NavigableSet v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$ConsumerGenerationPair v;
java.util.List v;
java.util.Optional v, v, v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData v;
java.util.HashMap v;
java.util.function.Function v;
int v, v, v;
org.slf4j.Logger v;
java.util.Iterator v, v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.TreeMap v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: 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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData memberData(org.apache.kafkaesque.clients.consumer.ConsumerPartitionAssignor$Subscription)>(v);
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData: java.util.List partitions>;
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 = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData: java.util.Optional generation>;
v = virtualinvoke v.<java.util.Optional: boolean isPresent()>();
if v == 0 goto label;
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData: java.util.Optional generation>;
v = virtualinvoke v.<java.util.Optional: java.lang.Object get()>();
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.slf4j.Logger log>;
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData: java.util.Optional generation>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Partition \'{}\' is assigned to multiple consumers following sticky assignment generation {}.", v, v);
goto label;
label:
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData: java.util.Optional generation>;
v = (int) -1;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<java.util.Optional: java.lang.Object orElse(java.lang.Object)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$MemberData: java.util.Optional generation>;
v = (int) -1;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<java.util.Optional: java.lang.Object orElse(java.lang.Object)>(v);
virtualinvoke v.<java.util.TreeMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<java.util.TreeMap: java.util.NavigableSet descendingKeySet()>();
v = interfaceinvoke v.<java.util.NavigableSet: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.util.TreeMap: java.lang.Object get(java.lang.Object)>(v);
v = staticinvoke <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$lambda_prepopulateCurrentAssignments_2__955: java.util.function.Function bootstrap$()>();
interfaceinvoke v.<java.util.Map: java.lang.Object computeIfAbsent(java.lang.Object,java.util.function.Function)>(v, v);
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);
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.<java.lang.Integer: int intValue()>();
v = new org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$ConsumerGenerationPair;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<java.util.TreeMap: java.lang.Object get(java.lang.Object)>(v);
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$ConsumerGenerationPair: void <init>(java.lang.String,int)>(v, v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
return;
}
private boolean isBalanced(java.util.Map, java.util.TreeSet, java.util.Map)
{
java.util.Map v, v;
boolean v, v, v, v, v, v;
java.util.Set v;
java.lang.Object[] v;
java.util.HashMap v;
java.util.TreeSet v;
int v, v, v, v, v, v;
org.slf4j.Logger v, v;
java.util.Iterator v, v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.TreeSet;
v := @parameter: java.util.Map;
v = virtualinvoke v.<java.util.TreeSet: java.lang.Object first()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = virtualinvoke v.<java.util.TreeSet: java.lang.Object last()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = v - 1;
if v < v goto label;
return 1;
label:
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: 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 getValue()>();
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 = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object)>("{} is assigned to more than one consumer.", v);
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = virtualinvoke v.<java.util.TreeSet: 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);
v = interfaceinvoke v.<java.util.List: int size()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
if v == v goto label;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(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 = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.slf4j.Logger log>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v[1] = v;
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("{} can be moved from consumer {} to consumer {} for a more balanced assignment.", v);
return 0;
label:
return 1;
}
private int getBalanceScore(java.util.Map)
{
java.util.HashMap v;
java.lang.Integer v;
java.util.Map v;
int v, v, v, v, v, v;
boolean v, v, v;
java.util.Iterator v, v, v;
java.util.Set v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.lang.Object v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Map;
v = 0;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: 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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = interfaceinvoke v.<java.util.List: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
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 getValue()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
interfaceinvoke v.<java.util.Iterator: void remove()>();
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 getValue()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = v - v;
v = staticinvoke <java.lang.Math: int abs(int)>(v);
v = v + v;
goto label;
label:
return v;
}
private java.util.List sortPartitions(java.util.Map, java.util.Set, boolean, java.util.Map, java.util.Map)
{
java.util.Map v, v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionComparator v;
boolean v, v, v, v, v, v, v, v, v, v, v, v;
java.util.Set v, v, v, v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$SubscriptionComparator v;
java.util.TreeSet v, v;
java.util.ArrayList v, v, v;
java.util.Iterator v, v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.Set;
v := @parameter: boolean;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
if v != 0 goto label;
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean areSubscriptionsIdentical(java.util.Map,java.util.Map)>(v, v);
if v == 0 goto label;
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: java.util.Map deepCopy(java.util.Map)>(v);
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 = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
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 = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
goto label;
label:
v = new java.util.TreeSet;
v = new org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$SubscriptionComparator;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$SubscriptionComparator: void <init>(java.util.Map)>(v);
specialinvoke v.<java.util.TreeSet: void <init>(java.util.Comparator)>(v);
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
virtualinvoke v.<java.util.TreeSet: boolean addAll(java.util.Collection)>(v);
label:
v = virtualinvoke v.<java.util.TreeSet: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.TreeSet: java.lang.Object pollLast()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
interfaceinvoke v.<java.util.List: boolean retainAll(java.util.Collection)>(v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object remove(int)>(0);
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
virtualinvoke v.<java.util.TreeSet: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object remove(int)>(0);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
virtualinvoke v.<java.util.TreeSet: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
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.List: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = new java.util.TreeSet;
v = new org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionComparator;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionComparator: void <init>(java.util.Map)>(v);
specialinvoke v.<java.util.TreeSet: void <init>(java.util.Comparator)>(v);
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
virtualinvoke v.<java.util.TreeSet: boolean addAll(java.util.Collection)>(v);
label:
v = virtualinvoke v.<java.util.TreeSet: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.TreeSet: java.lang.Object pollFirst()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
return v;
}
private boolean areSubscriptionsIdentical(java.util.Map, java.util.Map)
{
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.Collection v, v;
java.util.Map v, v;
boolean v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean hasIdenticalListElements(java.util.Collection)>(v);
if v != 0 goto label;
return 0;
label:
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean hasIdenticalListElements(java.util.Collection)>(v);
return v;
}
private void assignPartition(org.apache.kafkaesque.common.TopicPartition, java.util.TreeSet, java.util.Map, java.util.Map, java.util.Map)
{
java.util.Iterator v;
org.apache.kafkaesque.common.TopicPartition v;
java.util.TreeSet v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.Map v, v, v;
java.lang.Object v, v, v;
boolean v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: org.apache.kafkaesque.common.TopicPartition;
v := @parameter: java.util.TreeSet;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = virtualinvoke v.<java.util.TreeSet: 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);
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
virtualinvoke v.<java.util.TreeSet: boolean remove(java.lang.Object)>(v);
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);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
virtualinvoke v.<java.util.TreeSet: boolean add(java.lang.Object)>(v);
label:
return;
}
private boolean canParticipateInReassignment(org.apache.kafkaesque.common.TopicPartition, java.util.Map)
{
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
org.apache.kafkaesque.common.TopicPartition v;
java.util.Map v;
int v;
java.lang.Object v;
boolean v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: org.apache.kafkaesque.common.TopicPartition;
v := @parameter: java.util.Map;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
if v < 2 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private boolean canParticipateInReassignment(java.lang.String, java.util.Map, java.util.Map, java.util.Map)
{
org.slf4j.Logger v;
java.util.Iterator v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.Map v, v, v;
int v, v;
java.lang.Object v, v, v;
java.lang.String v;
boolean v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.lang.String;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= v goto label;
v = <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object)>("The consumer {} is assigned more partitions than the maximum possible.", v);
label:
if v >= v goto label;
return 1;
label:
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 = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean canParticipateInReassignment(org.apache.kafkaesque.common.TopicPartition,java.util.Map)>(v, v);
if v == 0 goto label;
return 1;
label:
return 0;
}
private void balance(java.util.Map, java.util.Map, java.util.List, java.util.List, java.util.TreeSet, java.util.Map, java.util.Map, java.util.Map, boolean)
{
java.util.Map v, v, v, v, v, v;
boolean v, v, v, v, v, v, v, v, v, v;
java.util.Set v, v, v;
java.util.List v, v;
java.util.HashMap v, v;
java.util.TreeSet v;
java.util.HashSet v;
int v, v;
java.util.Iterator v, v, v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.lang.Object v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.util.List;
v := @parameter: java.util.List;
v := @parameter: java.util.TreeSet;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: boolean;
v = virtualinvoke v.<java.util.TreeSet: java.lang.Object last()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
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 = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void assignPartition(org.apache.kafkaesque.common.TopicPartition,java.util.TreeSet,java.util.Map,java.util.Map,java.util.Map)>(v, v, v, v, v);
goto label;
label:
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
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 = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean canParticipateInReassignment(org.apache.kafkaesque.common.TopicPartition,java.util.Map)>(v, v);
if v != 0 goto label;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
interfaceinvoke v.<java.util.List: boolean removeAll(java.util.Collection)>(v);
interfaceinvoke v.<java.util.List: boolean removeAll(java.util.Collection)>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
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 = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean canParticipateInReassignment(java.lang.String,java.util.Map,java.util.Map,java.util.Map)>(v, v, v, v);
if v != 0 goto label;
virtualinvoke v.<java.util.TreeSet: boolean remove(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: java.util.Map deepCopy(java.util.Map)>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>(java.util.Map)>(v);
if v != 0 goto label;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean performReassignments(java.util.List,java.util.Map,java.util.Map,java.util.TreeSet,java.util.Map,java.util.Map,java.util.Map)>(v, v, v, v, v, v, v);
label:
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean performReassignments(java.util.List,java.util.Map,java.util.Map,java.util.TreeSet,java.util.Map,java.util.Map,java.util.Map)>(v, v, v, v, v, v, v);
if v != 0 goto label;
if v == 0 goto label;
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: int getBalanceScore(java.util.Map)>(v);
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: int getBalanceScore(java.util.Map)>(v);
if v < v goto label;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void deepCopy(java.util.Map,java.util.Map)>(v, v);
interfaceinvoke v.<java.util.Map: void clear()>();
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
label:
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
virtualinvoke v.<java.util.TreeSet: boolean add(java.lang.Object)>(v);
goto label;
label:
interfaceinvoke v.<java.util.Map: void clear()>();
return;
}
private boolean performReassignments(java.util.List, java.util.Map, java.util.Map, java.util.TreeSet, java.util.Map, java.util.Map, java.util.Map)
{
java.util.Map v, v, v, v, v;
boolean v, v, v, v, v, v;
java.util.List v;
java.util.TreeSet v;
int v, v, v, v, v, v, v;
java.lang.String v, v;
org.slf4j.Logger v, v;
java.util.Iterator v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.List;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.util.TreeSet;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = 0;
label:
v = 0;
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 = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean isBalanced(java.util.Map,java.util.TreeSet,java.util.Map)>(v, v, v);
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);
v = interfaceinvoke v.<java.util.List: int size()>();
if v > 1 goto label;
v = <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object)>("Expected more than one potential consumer for partition \'{}\'", v);
label:
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object)>("Expected partition \'{}\' to be assigned to a consumer", v);
label:
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$ConsumerGenerationPair: java.lang.String consumer>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = v + 1;
if v <= v goto label;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$ConsumerGenerationPair: java.lang.String consumer>;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void reassignPartition(org.apache.kafkaesque.common.TopicPartition,java.util.Map,java.util.TreeSet,java.util.Map,java.lang.String)>(v, v, v, v, v);
v = 1;
v = 1;
goto label;
label:
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(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 = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = v + 1;
if v <= v goto label;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void reassignPartition(org.apache.kafkaesque.common.TopicPartition,java.util.Map,java.util.TreeSet,java.util.Map,java.util.Map)>(v, v, v, v, v);
v = 1;
v = 1;
goto label;
label:
if v != 0 goto label;
return v;
}
private void reassignPartition(org.apache.kafkaesque.common.TopicPartition, java.util.Map, java.util.TreeSet, java.util.Map, java.util.Map)
{
java.util.Iterator v;
org.apache.kafkaesque.common.TopicPartition v;
java.lang.AssertionError v;
java.util.TreeSet v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.Map v, v, v;
java.lang.Object v, v;
java.lang.String v;
boolean v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: org.apache.kafkaesque.common.TopicPartition;
v := @parameter: java.util.Map;
v := @parameter: java.util.TreeSet;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = null;
v = virtualinvoke v.<java.util.TreeSet: 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);
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = v;
label:
v = <org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean $assertionsDisabled>;
if v != 0 goto label;
if v != null goto label;
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>()>();
throw v;
label:
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void reassignPartition(org.apache.kafkaesque.common.TopicPartition,java.util.Map,java.util.TreeSet,java.util.Map,java.lang.String)>(v, v, v, v, v);
return;
}
private void reassignPartition(org.apache.kafkaesque.common.TopicPartition, java.util.Map, java.util.TreeSet, java.util.Map, java.lang.String)
{
org.apache.kafkaesque.common.TopicPartition v, v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements v;
java.util.TreeSet v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.Map v, v;
java.lang.Object v;
java.lang.String v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: org.apache.kafkaesque.common.TopicPartition;
v := @parameter: java.util.Map;
v := @parameter: java.util.TreeSet;
v := @parameter: java.util.Map;
v := @parameter: java.lang.String;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements partitionMovements>;
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements: org.apache.kafkaesque.common.TopicPartition getTheActualPartitionToBeMoved(org.apache.kafkaesque.common.TopicPartition,java.lang.String,java.lang.String)>(v, v, v);
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void processPartitionMovement(org.apache.kafkaesque.common.TopicPartition,java.lang.String,java.util.Map,java.util.TreeSet,java.util.Map)>(v, v, v, v, v);
return;
}
private void processPartitionMovement(org.apache.kafkaesque.common.TopicPartition, java.lang.String, java.util.Map, java.util.TreeSet, java.util.Map)
{
org.apache.kafkaesque.common.TopicPartition v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements v;
java.util.TreeSet v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.Map v, v;
java.lang.Object v, v, v;
java.lang.String v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: org.apache.kafkaesque.common.TopicPartition;
v := @parameter: java.lang.String;
v := @parameter: java.util.Map;
v := @parameter: java.util.TreeSet;
v := @parameter: java.util.Map;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
virtualinvoke v.<java.util.TreeSet: boolean remove(java.lang.Object)>(v);
virtualinvoke v.<java.util.TreeSet: boolean remove(java.lang.Object)>(v);
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements partitionMovements>;
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements: void movePartition(org.apache.kafkaesque.common.TopicPartition,java.lang.String,java.lang.String)>(v, v, v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
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);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
virtualinvoke v.<java.util.TreeSet: boolean add(java.lang.Object)>(v);
virtualinvoke v.<java.util.TreeSet: boolean add(java.lang.Object)>(v);
return;
}
public boolean isSticky()
{
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
boolean v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v = v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements partitionMovements>;
v = specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor$PartitionMovements: boolean isSticky()>();
return v;
}
private boolean hasIdenticalListElements(java.util.Collection)
{
java.util.Iterator v;
java.util.Collection v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.lang.Object v, v;
boolean v, v, v, v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Collection;
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v != 0 goto label;
return 1;
label:
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
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.List: boolean containsAll(java.util.Collection)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.util.List: boolean containsAll(java.util.Collection)>(v);
if v != 0 goto label;
label:
return 0;
label:
v = v;
goto label;
label:
return 1;
}
private void deepCopy(java.util.Map, java.util.Map)
{
java.util.Iterator v;
java.util.Set v;
java.util.ArrayList v;
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.Map v, v;
java.lang.Object v, v, v;
boolean v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
interfaceinvoke v.<java.util.Map: void clear()>();
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;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
return;
}
private java.util.Map deepCopy(java.util.Map)
{
org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor v;
java.util.HashMap v;
java.util.Map v;
v := @this: org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor;
v := @parameter: java.util.Map;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
specialinvoke v.<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: void deepCopy(java.util.Map,java.util.Map)>(v, v);
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
java.lang.Class v;
boolean v, v;
v = class "Lorg/apache/kafkaesque/clients/consumer/internals/AbstractStickyAssignor;";
v = virtualinvoke v.<java.lang.Class: boolean desiredAssertionStatus()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: boolean $assertionsDisabled> = v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/kafkaesque/clients/consumer/internals/AbstractStickyAssignor;");
<org.apache.kafkaesque.clients.consumer.internals.AbstractStickyAssignor: org.slf4j.Logger log> = v;
return;
}
}