public class org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor extends org.apache.kafkaesqueesque.clients.consumer.internals.AbstractStickyAssignor
{
public void <init>()
{
org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor v;
v := @this: org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor;
specialinvoke v.<org.apache.kafkaesqueesque.clients.consumer.internals.AbstractStickyAssignor: void <init>()>();
return;
}
public java.lang.String name()
{
org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor v;
v := @this: org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor;
return "cooperative-sticky";
}
public java.util.List supportedProtocols()
{
java.util.List v;
org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor v;
org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$RebalanceProtocol[] v;
org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$RebalanceProtocol v, v;
v := @this: org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor;
v = newarray (org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$RebalanceProtocol)[2];
v = <org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$RebalanceProtocol: org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$RebalanceProtocol COOPERATIVE>;
v[0] = v;
v = <org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$RebalanceProtocol: org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$RebalanceProtocol EAGER>;
v[1] = v;
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
return v;
}
protected org.apache.kafkaesqueesque.clients.consumer.internals.AbstractStickyAssignor$MemberData memberData(org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$Subscription)
{
java.util.List v;
org.apache.kafkaesqueesque.clients.consumer.internals.AbstractStickyAssignor$MemberData v;
java.util.Optional v;
org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$Subscription v;
org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor v;
v := @this: org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor;
v := @parameter: org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$Subscription;
v = new org.apache.kafkaesqueesque.clients.consumer.internals.AbstractStickyAssignor$MemberData;
v = virtualinvoke v.<org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$Subscription: java.util.List ownedPartitions()>();
v = staticinvoke <java.util.Optional: java.util.Optional empty()>();
specialinvoke v.<org.apache.kafkaesqueesque.clients.consumer.internals.AbstractStickyAssignor$MemberData: void <init>(java.util.List,java.util.Optional)>(v, v);
return v;
}
public java.util.Map assign(java.util.Map, java.util.Map)
{
java.util.Map v, v, v;
org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor v;
v := @this: org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = specialinvoke v.<org.apache.kafkaesqueesque.clients.consumer.internals.AbstractStickyAssignor: java.util.Map assign(java.util.Map,java.util.Map)>(v, v);
specialinvoke v.<org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor: void adjustAssignment(java.util.Map,java.util.Map)>(v, v);
return v;
}
private void adjustAssignment(java.util.Map, java.util.Map)
{
java.util.HashMap v;
java.util.ArrayList v;
java.util.HashSet v, v;
java.util.Map v, v;
boolean v, v, v, v;
java.util.Iterator v, v, v;
java.util.Set v;
org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor v;
java.util.List v;
java.lang.Object v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesqueesque.clients.consumer.CooperativeStickyAssignor;
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.HashSet;
specialinvoke v.<java.util.HashSet: 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: java.lang.Object get(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.kafkaesqueesque.clients.consumer.ConsumerPartitionAssignor$Subscription: java.util.List ownedPartitions()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
interfaceinvoke v.<java.util.List: boolean removeAll(java.util.Collection)>(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()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>(java.util.Collection)>(v);
interfaceinvoke v.<java.util.Set: boolean removeAll(java.util.Collection)>(v);
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
goto label;
label:
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: 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.Map: java.lang.Object get(java.lang.Object)>(v);
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
goto label;
label:
return;
}
}