public class oadd.io.netty.channel.group.DefaultChannelGroup extends java.util.AbstractSet implements oadd.io.netty.channel.group.ChannelGroup
{
private static final java.util.concurrent.atomic.AtomicInteger nextId;
private final java.lang.String name;
private final oadd.io.netty.util.concurrent.EventExecutor executor;
private final java.util.concurrent.ConcurrentMap serverChannels;
private final java.util.concurrent.ConcurrentMap nonServerChannels;
private final oadd.io.netty.channel.ChannelFutureListener remover;
private final oadd.io.netty.channel.group.VoidChannelGroupFuture voidFuture;
private final boolean stayClosed;
private volatile boolean closed;
public void <init>(oadd.io.netty.util.concurrent.EventExecutor)
{
oadd.io.netty.channel.group.DefaultChannelGroup v;
oadd.io.netty.util.concurrent.EventExecutor v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.util.concurrent.EventExecutor;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: void <init>(oadd.io.netty.util.concurrent.EventExecutor,boolean)>(v, 0);
return;
}
public void <init>(java.lang.String, oadd.io.netty.util.concurrent.EventExecutor)
{
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.String v;
oadd.io.netty.util.concurrent.EventExecutor v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.String;
v := @parameter: oadd.io.netty.util.concurrent.EventExecutor;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: void <init>(java.lang.String,oadd.io.netty.util.concurrent.EventExecutor,boolean)>(v, v, 0);
return;
}
public void <init>(oadd.io.netty.util.concurrent.EventExecutor, boolean)
{
java.util.concurrent.atomic.AtomicInteger v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.String v, v;
boolean v;
oadd.io.netty.util.concurrent.EventExecutor v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.util.concurrent.EventExecutor;
v := @parameter: boolean;
v = <oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.atomic.AtomicInteger nextId>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = staticinvoke <java.lang.Integer: java.lang.String toHexString(int)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("group-0x\u0001");
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: void <init>(java.lang.String,oadd.io.netty.util.concurrent.EventExecutor,boolean)>(v, v, v);
return;
}
public void <init>(java.lang.String, oadd.io.netty.util.concurrent.EventExecutor, boolean)
{
oadd.io.netty.channel.group.VoidChannelGroupFuture v;
oadd.io.netty.channel.group.DefaultChannelGroup$1 v;
java.util.concurrent.ConcurrentMap v, v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.String v;
boolean v;
oadd.io.netty.util.concurrent.EventExecutor v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.String;
v := @parameter: oadd.io.netty.util.concurrent.EventExecutor;
v := @parameter: boolean;
specialinvoke v.<java.util.AbstractSet: void <init>()>();
v = staticinvoke <oadd.io.netty.util.internal.PlatformDependent: java.util.concurrent.ConcurrentMap newConcurrentHashMap()>();
v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels> = v;
v = staticinvoke <oadd.io.netty.util.internal.PlatformDependent: java.util.concurrent.ConcurrentMap newConcurrentHashMap()>();
v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels> = v;
v = new oadd.io.netty.channel.group.DefaultChannelGroup$1;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup$1: void <init>(oadd.io.netty.channel.group.DefaultChannelGroup)>(v);
v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.ChannelFutureListener remover> = v;
v = new oadd.io.netty.channel.group.VoidChannelGroupFuture;
specialinvoke v.<oadd.io.netty.channel.group.VoidChannelGroupFuture: void <init>(oadd.io.netty.channel.group.ChannelGroup)>(v);
v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.VoidChannelGroupFuture voidFuture> = v;
staticinvoke <oadd.io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "name");
v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.lang.String name> = v;
v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.util.concurrent.EventExecutor executor> = v;
v.<oadd.io.netty.channel.group.DefaultChannelGroup: boolean stayClosed> = v;
return;
}
public java.lang.String name()
{
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.String v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.lang.String name>;
return v;
}
public oadd.io.netty.channel.Channel find(oadd.io.netty.channel.ChannelId)
{
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v, v;
oadd.io.netty.channel.ChannelId v;
java.util.concurrent.ConcurrentMap v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.channel.ChannelId;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
return v;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
return v;
}
public boolean isEmpty()
{
oadd.io.netty.channel.group.DefaultChannelGroup v;
boolean v, v, v;
java.util.concurrent.ConcurrentMap v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: boolean isEmpty()>();
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: boolean isEmpty()>();
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public int size()
{
int v, v, v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.util.concurrent.ConcurrentMap v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: int size()>();
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: int size()>();
v = v + v;
return v;
}
public boolean contains(java.lang.Object)
{
java.util.concurrent.ConcurrentMap v, v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
boolean v, v, v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v = v instanceof oadd.io.netty.channel.ServerChannel;
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: boolean containsValue(java.lang.Object)>(v);
return v;
label:
v = v instanceof oadd.io.netty.channel.Channel;
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: boolean containsValue(java.lang.Object)>(v);
return v;
label:
return 0;
}
public boolean add(oadd.io.netty.channel.Channel)
{
oadd.io.netty.channel.ChannelFutureListener v;
oadd.io.netty.channel.Channel v;
java.util.concurrent.ConcurrentMap v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
oadd.io.netty.channel.ChannelId v;
oadd.io.netty.channel.ChannelFuture v;
boolean v, v, v, v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.channel.Channel;
v = v instanceof oadd.io.netty.channel.ServerChannel;
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
goto label;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
label:
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelId id()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object putIfAbsent(java.lang.Object,java.lang.Object)>(v, v);
if v != null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture closeFuture()>();
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.ChannelFutureListener remover>;
interfaceinvoke v.<oadd.io.netty.channel.ChannelFuture: oadd.io.netty.channel.ChannelFuture addListener(oadd.io.netty.util.concurrent.GenericFutureListener)>(v);
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: boolean stayClosed>;
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: boolean closed>;
if v == 0 goto label;
interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture close()>();
label:
return v;
}
public boolean remove(java.lang.Object)
{
oadd.io.netty.channel.ChannelFutureListener v;
java.util.concurrent.ConcurrentMap v, v, v, v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v, v;
oadd.io.netty.channel.ChannelId v, v;
oadd.io.netty.channel.ChannelFuture v;
boolean v, v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v = v instanceof oadd.io.netty.channel.ChannelId;
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
if v != null goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
goto label;
label:
v = v instanceof oadd.io.netty.channel.Channel;
if v == 0 goto label;
v = v instanceof oadd.io.netty.channel.ServerChannel;
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelId id()>();
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
goto label;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelId id()>();
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
label:
if v != null goto label;
return 0;
label:
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture closeFuture()>();
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.ChannelFutureListener remover>;
interfaceinvoke v.<oadd.io.netty.channel.ChannelFuture: oadd.io.netty.channel.ChannelFuture removeListener(oadd.io.netty.util.concurrent.GenericFutureListener)>(v);
return 1;
}
public void clear()
{
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.util.concurrent.ConcurrentMap v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: void clear()>();
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: void clear()>();
return;
}
public java.util.Iterator iterator()
{
oadd.io.netty.channel.group.CombinedIterator v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.util.concurrent.ConcurrentMap v, v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = new oadd.io.netty.channel.group.CombinedIterator;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
specialinvoke v.<oadd.io.netty.channel.group.CombinedIterator: void <init>(java.util.Iterator,java.util.Iterator)>(v, v);
return v;
}
public java.lang.Object[] toArray()
{
java.lang.Object[] v;
java.util.Collection v, v;
java.util.ArrayList v;
java.util.concurrent.ConcurrentMap v, v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = new java.util.ArrayList;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: int size()>();
specialinvoke v.<java.util.ArrayList: void <init>(int)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
interfaceinvoke v.<java.util.Collection: boolean addAll(java.util.Collection)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
interfaceinvoke v.<java.util.Collection: boolean addAll(java.util.Collection)>(v);
v = interfaceinvoke v.<java.util.Collection: java.lang.Object[] toArray()>();
return v;
}
public java.lang.Object[] toArray(java.lang.Object[])
{
java.lang.Object[] v, v;
java.util.Collection v, v;
java.util.ArrayList v;
java.util.concurrent.ConcurrentMap v, v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object[];
v = new java.util.ArrayList;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: int size()>();
specialinvoke v.<java.util.ArrayList: void <init>(int)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
interfaceinvoke v.<java.util.Collection: boolean addAll(java.util.Collection)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
interfaceinvoke v.<java.util.Collection: boolean addAll(java.util.Collection)>(v);
v = interfaceinvoke v.<java.util.Collection: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture close()
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = staticinvoke <oadd.io.netty.channel.group.ChannelMatchers: oadd.io.netty.channel.group.ChannelMatcher all()>();
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture close(oadd.io.netty.channel.group.ChannelMatcher)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture disconnect()
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = staticinvoke <oadd.io.netty.channel.group.ChannelMatchers: oadd.io.netty.channel.group.ChannelMatcher all()>();
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture disconnect(oadd.io.netty.channel.group.ChannelMatcher)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture deregister()
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = staticinvoke <oadd.io.netty.channel.group.ChannelMatchers: oadd.io.netty.channel.group.ChannelMatcher all()>();
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture deregister(oadd.io.netty.channel.group.ChannelMatcher)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture write(java.lang.Object)
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v = staticinvoke <oadd.io.netty.channel.group.ChannelMatchers: oadd.io.netty.channel.group.ChannelMatcher all()>();
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture write(java.lang.Object,oadd.io.netty.channel.group.ChannelMatcher)>(v, v);
return v;
}
private static java.lang.Object safeDuplicate(java.lang.Object)
{
oadd.io.netty.buffer.ByteBufHolder v;
java.lang.Object v, v;
oadd.io.netty.buffer.ByteBuf v;
boolean v, v;
v := @parameter: java.lang.Object;
v = v instanceof oadd.io.netty.buffer.ByteBuf;
if v == 0 goto label;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: oadd.io.netty.buffer.ByteBuf retainedDuplicate()>();
return v;
label:
v = v instanceof oadd.io.netty.buffer.ByteBufHolder;
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.buffer.ByteBufHolder: oadd.io.netty.buffer.ByteBufHolder retainedDuplicate()>();
return v;
label:
v = staticinvoke <oadd.io.netty.util.ReferenceCountUtil: java.lang.Object retain(java.lang.Object)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture write(java.lang.Object, oadd.io.netty.channel.group.ChannelMatcher)
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture write(java.lang.Object,oadd.io.netty.channel.group.ChannelMatcher,boolean)>(v, v, 0);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture write(java.lang.Object, oadd.io.netty.channel.group.ChannelMatcher, boolean)
{
oadd.io.netty.channel.group.ChannelMatcher v;
java.util.concurrent.ConcurrentMap v, v, v;
java.util.LinkedHashMap v;
oadd.io.netty.channel.group.DefaultChannelGroupFuture v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
oadd.io.netty.channel.ChannelPromise v;
boolean v, v, v, v, v;
oadd.io.netty.util.concurrent.EventExecutor v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.lang.Object v, v, v, v, v;
oadd.io.netty.channel.ChannelFuture v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
v := @parameter: boolean;
staticinvoke <oadd.io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "message");
staticinvoke <oadd.io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "matcher");
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = staticinvoke <oadd.io.netty.channel.group.DefaultChannelGroup: java.lang.Object safeDuplicate(java.lang.Object)>(v);
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelPromise voidPromise()>();
interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture write(java.lang.Object,oadd.io.netty.channel.ChannelPromise)>(v, v);
goto label;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.VoidChannelGroupFuture voidFuture>;
goto label;
label:
v = new java.util.LinkedHashMap;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: int size()>();
specialinvoke v.<java.util.LinkedHashMap: void <init>(int)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = staticinvoke <oadd.io.netty.channel.group.DefaultChannelGroup: java.lang.Object safeDuplicate(java.lang.Object)>(v);
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture write(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 oadd.io.netty.channel.group.DefaultChannelGroupFuture;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.util.concurrent.EventExecutor executor>;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroupFuture: void <init>(oadd.io.netty.channel.group.ChannelGroup,java.util.Map,oadd.io.netty.util.concurrent.EventExecutor)>(v, v, v);
v = v;
label:
staticinvoke <oadd.io.netty.util.ReferenceCountUtil: boolean release(java.lang.Object)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroup flush()
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
oadd.io.netty.channel.group.ChannelGroup v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = staticinvoke <oadd.io.netty.channel.group.ChannelMatchers: oadd.io.netty.channel.group.ChannelMatcher all()>();
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroup flush(oadd.io.netty.channel.group.ChannelMatcher)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture flushAndWrite(java.lang.Object)
{
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture writeAndFlush(java.lang.Object)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture writeAndFlush(java.lang.Object)
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v = staticinvoke <oadd.io.netty.channel.group.ChannelMatchers: oadd.io.netty.channel.group.ChannelMatcher all()>();
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture writeAndFlush(java.lang.Object,oadd.io.netty.channel.group.ChannelMatcher)>(v, v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture disconnect(oadd.io.netty.channel.group.ChannelMatcher)
{
oadd.io.netty.channel.group.ChannelMatcher v;
java.util.concurrent.ConcurrentMap v, v;
java.util.LinkedHashMap v;
oadd.io.netty.channel.group.DefaultChannelGroupFuture v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
boolean v, v, v, v;
oadd.io.netty.util.concurrent.EventExecutor v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.lang.Object v, v;
oadd.io.netty.channel.ChannelFuture v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
staticinvoke <oadd.io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "matcher");
v = new java.util.LinkedHashMap;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: int size()>();
specialinvoke v.<java.util.LinkedHashMap: void <init>(int)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture disconnect()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture disconnect()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new oadd.io.netty.channel.group.DefaultChannelGroupFuture;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.util.concurrent.EventExecutor executor>;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroupFuture: void <init>(oadd.io.netty.channel.group.ChannelGroup,java.util.Map,oadd.io.netty.util.concurrent.EventExecutor)>(v, v, v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture close(oadd.io.netty.channel.group.ChannelMatcher)
{
oadd.io.netty.channel.group.ChannelMatcher v;
java.util.concurrent.ConcurrentMap v, v;
java.util.LinkedHashMap v;
oadd.io.netty.channel.group.DefaultChannelGroupFuture v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
boolean v, v, v, v, v;
oadd.io.netty.util.concurrent.EventExecutor v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.lang.Object v, v;
oadd.io.netty.channel.ChannelFuture v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
staticinvoke <oadd.io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "matcher");
v = new java.util.LinkedHashMap;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: int size()>();
specialinvoke v.<java.util.LinkedHashMap: void <init>(int)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: boolean stayClosed>;
if v == 0 goto label;
v.<oadd.io.netty.channel.group.DefaultChannelGroup: boolean closed> = 1;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture close()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture close()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new oadd.io.netty.channel.group.DefaultChannelGroupFuture;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.util.concurrent.EventExecutor executor>;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroupFuture: void <init>(oadd.io.netty.channel.group.ChannelGroup,java.util.Map,oadd.io.netty.util.concurrent.EventExecutor)>(v, v, v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture deregister(oadd.io.netty.channel.group.ChannelMatcher)
{
oadd.io.netty.channel.group.ChannelMatcher v;
java.util.concurrent.ConcurrentMap v, v;
java.util.LinkedHashMap v;
oadd.io.netty.channel.group.DefaultChannelGroupFuture v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
boolean v, v, v, v;
oadd.io.netty.util.concurrent.EventExecutor v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.lang.Object v, v;
oadd.io.netty.channel.ChannelFuture v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
staticinvoke <oadd.io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "matcher");
v = new java.util.LinkedHashMap;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: int size()>();
specialinvoke v.<java.util.LinkedHashMap: void <init>(int)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture deregister()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture deregister()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new oadd.io.netty.channel.group.DefaultChannelGroupFuture;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.util.concurrent.EventExecutor executor>;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroupFuture: void <init>(oadd.io.netty.channel.group.ChannelGroup,java.util.Map,oadd.io.netty.util.concurrent.EventExecutor)>(v, v, v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroup flush(oadd.io.netty.channel.group.ChannelMatcher)
{
oadd.io.netty.channel.group.ChannelMatcher v;
java.util.Iterator v;
java.util.Collection v;
java.util.concurrent.ConcurrentMap v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
boolean v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.Channel flush()>();
goto label;
label:
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture flushAndWrite(java.lang.Object, oadd.io.netty.channel.group.ChannelMatcher)
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture writeAndFlush(java.lang.Object,oadd.io.netty.channel.group.ChannelMatcher)>(v, v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture writeAndFlush(java.lang.Object, oadd.io.netty.channel.group.ChannelMatcher)
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture writeAndFlush(java.lang.Object,oadd.io.netty.channel.group.ChannelMatcher,boolean)>(v, v, 0);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture writeAndFlush(java.lang.Object, oadd.io.netty.channel.group.ChannelMatcher, boolean)
{
oadd.io.netty.channel.group.ChannelMatcher v;
java.util.concurrent.ConcurrentMap v, v, v;
java.util.LinkedHashMap v;
oadd.io.netty.channel.group.DefaultChannelGroupFuture v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
oadd.io.netty.channel.ChannelPromise v;
boolean v, v, v, v, v;
oadd.io.netty.util.concurrent.EventExecutor v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.lang.Object v, v, v, v, v;
oadd.io.netty.channel.ChannelFuture v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
v := @parameter: boolean;
staticinvoke <oadd.io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "message");
if v == 0 goto label;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = staticinvoke <oadd.io.netty.channel.group.DefaultChannelGroup: java.lang.Object safeDuplicate(java.lang.Object)>(v);
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelPromise voidPromise()>();
interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture writeAndFlush(java.lang.Object,oadd.io.netty.channel.ChannelPromise)>(v, v);
goto label;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.VoidChannelGroupFuture voidFuture>;
goto label;
label:
v = new java.util.LinkedHashMap;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: int size()>();
specialinvoke v.<java.util.LinkedHashMap: void <init>(int)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = staticinvoke <oadd.io.netty.channel.group.DefaultChannelGroup: java.lang.Object safeDuplicate(java.lang.Object)>(v);
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture writeAndFlush(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 oadd.io.netty.channel.group.DefaultChannelGroupFuture;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.util.concurrent.EventExecutor executor>;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroupFuture: void <init>(oadd.io.netty.channel.group.ChannelGroup,java.util.Map,oadd.io.netty.util.concurrent.EventExecutor)>(v, v, v);
v = v;
label:
staticinvoke <oadd.io.netty.util.ReferenceCountUtil: boolean release(java.lang.Object)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture newCloseFuture()
{
oadd.io.netty.channel.group.ChannelMatcher v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
oadd.io.netty.channel.group.ChannelGroupFuture v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = staticinvoke <oadd.io.netty.channel.group.ChannelMatchers: oadd.io.netty.channel.group.ChannelMatcher all()>();
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.channel.group.ChannelGroupFuture newCloseFuture(oadd.io.netty.channel.group.ChannelMatcher)>(v);
return v;
}
public oadd.io.netty.channel.group.ChannelGroupFuture newCloseFuture(oadd.io.netty.channel.group.ChannelMatcher)
{
oadd.io.netty.channel.group.ChannelMatcher v;
java.util.concurrent.ConcurrentMap v, v;
java.util.LinkedHashMap v;
oadd.io.netty.channel.group.DefaultChannelGroupFuture v;
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
boolean v, v, v, v;
oadd.io.netty.util.concurrent.EventExecutor v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.lang.Object v, v;
oadd.io.netty.channel.ChannelFuture v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.channel.group.ChannelMatcher;
v = new java.util.LinkedHashMap;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: int size()>();
specialinvoke v.<java.util.LinkedHashMap: void <init>(int)>(v);
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap serverChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture closeFuture()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.ConcurrentMap nonServerChannels>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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 = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelMatcher: boolean matches(oadd.io.netty.channel.Channel)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: oadd.io.netty.channel.ChannelFuture closeFuture()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new oadd.io.netty.channel.group.DefaultChannelGroupFuture;
v = v.<oadd.io.netty.channel.group.DefaultChannelGroup: oadd.io.netty.util.concurrent.EventExecutor executor>;
specialinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroupFuture: void <init>(oadd.io.netty.channel.group.ChannelGroup,java.util.Map,oadd.io.netty.util.concurrent.EventExecutor)>(v, v, v);
return v;
}
public int hashCode()
{
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
return v;
}
public boolean equals(java.lang.Object)
{
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.Object v;
boolean v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: java.lang.Object;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public int compareTo(oadd.io.netty.channel.group.ChannelGroup)
{
int v, v, v, v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.String v, v;
oadd.io.netty.channel.group.ChannelGroup v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v := @parameter: oadd.io.netty.channel.group.ChannelGroup;
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.lang.String name()>();
v = interfaceinvoke v.<oadd.io.netty.channel.group.ChannelGroup: java.lang.String name()>();
v = virtualinvoke v.<java.lang.String: int compareTo(java.lang.String)>(v);
if v == 0 goto label;
return v;
label:
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
v = v - v;
return v;
}
public java.lang.String toString()
{
int v;
oadd.io.netty.channel.group.DefaultChannelGroup v;
java.lang.String v, v, v;
v := @this: oadd.io.netty.channel.group.DefaultChannelGroup;
v = staticinvoke <oadd.io.netty.util.internal.StringUtil: java.lang.String simpleClassName(java.lang.Object)>(v);
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: java.lang.String name()>();
v = virtualinvoke v.<oadd.io.netty.channel.group.DefaultChannelGroup: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,int)>(v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001(name: \u, size: \u)");
return v;
}
static void <clinit>()
{
java.util.concurrent.atomic.AtomicInteger v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
<oadd.io.netty.channel.group.DefaultChannelGroup: java.util.concurrent.atomic.AtomicInteger nextId> = v;
return;
}
}