public abstract class io.netty.channel.ChannelHandlerAdapter extends java.lang.Object implements io.netty.channel.ChannelHandler
{
boolean added;
public void <init>()
{
io.netty.channel.ChannelHandlerAdapter v;
v := @this: io.netty.channel.ChannelHandlerAdapter;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
protected void ensureNotSharable()
{
java.lang.IllegalStateException v;
io.netty.channel.ChannelHandlerAdapter v;
java.lang.Class v;
java.lang.String v, v;
boolean v;
v := @this: io.netty.channel.ChannelHandlerAdapter;
v = virtualinvoke v.<io.netty.channel.ChannelHandlerAdapter: boolean isSharable()>();
if v == 0 goto label;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
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[])>("ChannelHandler \u is not allowed to be shared");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
}
public boolean isSharable()
{
io.netty.channel.ChannelHandlerAdapter v;
java.util.Map v;
io.netty.util.internal.InternalThreadLocalMap v;
java.lang.Class v;
java.lang.Object v;
boolean v, v;
v := @this: io.netty.channel.ChannelHandlerAdapter;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <io.netty.util.internal.InternalThreadLocalMap: io.netty.util.internal.InternalThreadLocalMap get()>();
v = virtualinvoke v.<io.netty.util.internal.InternalThreadLocalMap: java.util.Map handlerSharableCache()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = virtualinvoke v.<java.lang.Class: boolean isAnnotationPresent(java.lang.Class)>(class "Lio/netty/channel/ChannelHandler$Sharable;");
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
return v;
}
public void handlerAdded(io.netty.channel.ChannelHandlerContext) throws java.lang.Exception
{
io.netty.channel.ChannelHandlerContext v;
io.netty.channel.ChannelHandlerAdapter v;
v := @this: io.netty.channel.ChannelHandlerAdapter;
v := @parameter: io.netty.channel.ChannelHandlerContext;
return;
}
public void handlerRemoved(io.netty.channel.ChannelHandlerContext) throws java.lang.Exception
{
io.netty.channel.ChannelHandlerContext v;
io.netty.channel.ChannelHandlerAdapter v;
v := @this: io.netty.channel.ChannelHandlerAdapter;
v := @parameter: io.netty.channel.ChannelHandlerContext;
return;
}
public void exceptionCaught(io.netty.channel.ChannelHandlerContext, java.lang.Throwable) throws java.lang.Exception
{
java.lang.Throwable v;
io.netty.channel.ChannelHandlerContext v;
io.netty.channel.ChannelHandlerAdapter v;
v := @this: io.netty.channel.ChannelHandlerAdapter;
v := @parameter: io.netty.channel.ChannelHandlerContext;
v := @parameter: java.lang.Throwable;
interfaceinvoke v.<io.netty.channel.ChannelHandlerContext: io.netty.channel.ChannelHandlerContext fireExceptionCaught(java.lang.Throwable)>(v);
return;
}
}