public class io.netty.example.spdy.client.SpdyFrameLogger extends io.netty.channel.ChannelDuplexHandler
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: io.netty.example.spdy.client.SpdyFrameLogger
super_class: io.netty.channel.ChannelDuplexHandler
{
protected final io.netty.util.internal.logging.InternalLogger logger;
descriptor: Lio/netty/util/internal/logging/InternalLogger;
flags: (0x0014) ACC_PROTECTED, ACC_FINAL
private final io.netty.util.internal.logging.InternalLogLevel level;
descriptor: Lio/netty/util/internal/logging/InternalLogLevel;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
public void <init>(io.netty.util.internal.logging.InternalLogLevel);
descriptor: (Lio/netty/util/internal/logging/InternalLogLevel;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial io.netty.channel.ChannelDuplexHandler.<init>:()V
1: aload 1
ifnonnull 3
2: new java.lang.NullPointerException
dup
ldc "level"
invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: io.netty.example.spdy.client.SpdyFrameLogger io.netty.util.internal.logging.InternalLogLevel
StackMap stack:
aload 0
aload 0
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokestatic io.netty.util.internal.logging.InternalLoggerFactory.getInstance:(Ljava/lang/Class;)Lio/netty/util/internal/logging/InternalLogger;
putfield io.netty.example.spdy.client.SpdyFrameLogger.logger:Lio/netty/util/internal/logging/InternalLogger;
4: aload 0
aload 1
putfield io.netty.example.spdy.client.SpdyFrameLogger.level:Lio/netty/util/internal/logging/InternalLogLevel;
5: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lio/netty/example/spdy/client/SpdyFrameLogger;
0 6 1 level Lio/netty/util/internal/logging/InternalLogLevel;
MethodParameters:
Name Flags
level
public void channelRead(io.netty.channel.ChannelHandlerContext, java.lang.Object);
descriptor: (Lio/netty/channel/ChannelHandlerContext;Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 2
invokestatic io.netty.example.spdy.client.SpdyFrameLogger.acceptMessage:(Ljava/lang/Object;)Z
ifeq 2
1: aload 0
aload 2
checkcast io.netty.handler.codec.spdy.SpdyFrame
getstatic io.netty.example.spdy.client.SpdyFrameLogger$Direction.INBOUND:Lio/netty/example/spdy/client/SpdyFrameLogger$Direction;
invokevirtual io.netty.example.spdy.client.SpdyFrameLogger.log:(Lio/netty/handler/codec/spdy/SpdyFrame;Lio/netty/example/spdy/client/SpdyFrameLogger$Direction;)V
2: StackMap locals:
StackMap stack:
aload 1
aload 2
invokeinterface io.netty.channel.ChannelHandlerContext.fireChannelRead:(Ljava/lang/Object;)Lio/netty/channel/ChannelHandlerContext;
pop
3: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/netty/example/spdy/client/SpdyFrameLogger;
0 4 1 ctx Lio/netty/channel/ChannelHandlerContext;
0 4 2 msg Ljava/lang/Object;
MethodParameters:
Name Flags
ctx
msg
public void write(io.netty.channel.ChannelHandlerContext, java.lang.Object, io.netty.channel.ChannelPromise);
descriptor: (Lio/netty/channel/ChannelHandlerContext;Ljava/lang/Object;Lio/netty/channel/ChannelPromise;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 2
invokestatic io.netty.example.spdy.client.SpdyFrameLogger.acceptMessage:(Ljava/lang/Object;)Z
ifeq 2
1: aload 0
aload 2
checkcast io.netty.handler.codec.spdy.SpdyFrame
getstatic io.netty.example.spdy.client.SpdyFrameLogger$Direction.OUTBOUND:Lio/netty/example/spdy/client/SpdyFrameLogger$Direction;
invokevirtual io.netty.example.spdy.client.SpdyFrameLogger.log:(Lio/netty/handler/codec/spdy/SpdyFrame;Lio/netty/example/spdy/client/SpdyFrameLogger$Direction;)V
2: StackMap locals:
StackMap stack:
aload 1
aload 2
aload 3
invokeinterface io.netty.channel.ChannelHandlerContext.write:(Ljava/lang/Object;Lio/netty/channel/ChannelPromise;)Lio/netty/channel/ChannelFuture;
pop
3: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/netty/example/spdy/client/SpdyFrameLogger;
0 4 1 ctx Lio/netty/channel/ChannelHandlerContext;
0 4 2 msg Ljava/lang/Object;
0 4 3 promise Lio/netty/channel/ChannelPromise;
MethodParameters:
Name Flags
ctx
msg
promise
private static boolean acceptMessage(java.lang.Object);
descriptor: (Ljava/lang/Object;)Z
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
instanceof io.netty.handler.codec.spdy.SpdyFrame
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 msg Ljava/lang/Object;
MethodParameters:
Name Flags
msg
private void log(io.netty.handler.codec.spdy.SpdyFrame, io.netty.example.spdy.client.SpdyFrameLogger$Direction);
descriptor: (Lio/netty/handler/codec/spdy/SpdyFrame;Lio/netty/example/spdy/client/SpdyFrameLogger$Direction;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield io.netty.example.spdy.client.SpdyFrameLogger.logger:Lio/netty/util/internal/logging/InternalLogger;
aload 0
getfield io.netty.example.spdy.client.SpdyFrameLogger.level:Lio/netty/util/internal/logging/InternalLogLevel;
invokeinterface io.netty.util.internal.logging.InternalLogger.isEnabled:(Lio/netty/util/internal/logging/InternalLogLevel;)Z
ifeq 9
1: new java.lang.StringBuilder
dup
sipush 200
invokespecial java.lang.StringBuilder.<init>:(I)V
2: ldc "\n----------------"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
3: aload 2
invokevirtual io.netty.example.spdy.client.SpdyFrameLogger$Direction.name:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
4: ldc "--------------------\n"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
5: aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
6: ldc "\n------------------------------------"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
7: astore 3
start local 3 8: aload 0
getfield io.netty.example.spdy.client.SpdyFrameLogger.logger:Lio/netty/util/internal/logging/InternalLogger;
aload 0
getfield io.netty.example.spdy.client.SpdyFrameLogger.level:Lio/netty/util/internal/logging/InternalLogLevel;
aload 3
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokeinterface io.netty.util.internal.logging.InternalLogger.log:(Lio/netty/util/internal/logging/InternalLogLevel;Ljava/lang/String;)V
end local 3 9: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lio/netty/example/spdy/client/SpdyFrameLogger;
0 10 1 msg Lio/netty/handler/codec/spdy/SpdyFrame;
0 10 2 d Lio/netty/example/spdy/client/SpdyFrameLogger$Direction;
8 9 3 b Ljava/lang/StringBuilder;
MethodParameters:
Name Flags
msg
d
}
SourceFile: "SpdyFrameLogger.java"
NestMembers:
io.netty.example.spdy.client.SpdyFrameLogger$Direction
InnerClasses:
private final Direction = io.netty.example.spdy.client.SpdyFrameLogger$Direction of io.netty.example.spdy.client.SpdyFrameLogger