class oadd.org.apache.drill.exec.rpc.RpcDecoder extends oadd.io.netty.handler.codec.MessageToMessageDecoder
{
final org.slf4j.Logger logger;
private final java.util.concurrent.atomic.AtomicLong messageCounter;
public void <init>(java.lang.String)
{
java.util.concurrent.atomic.AtomicLong v;
org.slf4j.Logger v;
oadd.org.apache.drill.exec.rpc.RpcDecoder v;
java.lang.Class v;
java.lang.String v, v, v;
v := @this: oadd.org.apache.drill.exec.rpc.RpcDecoder;
v := @parameter: java.lang.String;
specialinvoke v.<oadd.io.netty.handler.codec.MessageToMessageDecoder: void <init>()>();
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<oadd.org.apache.drill.exec.rpc.RpcDecoder: java.util.concurrent.atomic.AtomicLong messageCounter> = v;
v = class "Loadd/org/apache/drill/exec/rpc/RpcDecoder;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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-\u0001");
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.String)>(v);
v.<oadd.org.apache.drill.exec.rpc.RpcDecoder: org.slf4j.Logger logger> = v;
return;
}
protected void decode(oadd.io.netty.channel.ChannelHandlerContext, oadd.io.netty.buffer.ByteBuf, java.util.List) throws java.lang.Exception
{
java.lang.Object[] v;
oadd.io.netty.buffer.ByteBufInputStream v;
oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcHeader v;
java.lang.Integer v, v;
int v, v, v, v, v, v, v, v, v, v, v, v;
oadd.io.netty.channel.ChannelHandlerContext v;
java.lang.String v;
oadd.io.netty.buffer.ByteBuf v, v, v;
boolean v;
oadd.io.netty.channel.Channel v;
oadd.org.apache.drill.exec.rpc.RpcDecoder v;
oadd.org.apache.drill.exec.rpc.InboundRpcMessage v;
oadd.io.netty.handler.codec.CorruptedFrameException v;
java.util.concurrent.atomic.AtomicLong v;
java.util.List v;
oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcMode v;
v := @this: oadd.org.apache.drill.exec.rpc.RpcDecoder;
v := @parameter: oadd.io.netty.channel.ChannelHandlerContext;
v := @parameter: oadd.io.netty.buffer.ByteBuf;
v := @parameter: java.util.List;
v = interfaceinvoke v.<oadd.io.netty.channel.ChannelHandlerContext: oadd.io.netty.channel.Channel channel()>();
v = interfaceinvoke v.<oadd.io.netty.channel.Channel: boolean isOpen()>();
if v != 0 goto label;
return;
label:
v = new oadd.io.netty.buffer.ByteBufInputStream;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: int readableBytes()>();
specialinvoke v.<oadd.io.netty.buffer.ByteBufInputStream: void <init>(oadd.io.netty.buffer.ByteBuf,int)>(v, v);
v = <oadd.org.apache.drill.exec.rpc.RpcEncoder: int HEADER_TAG>;
specialinvoke v.<oadd.org.apache.drill.exec.rpc.RpcDecoder: void checkTag(oadd.io.netty.buffer.ByteBufInputStream,int)>(v, v);
v = staticinvoke <oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcHeader: oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcHeader parseDelimitedFrom(java.io.InputStream)>(v);
v = <oadd.org.apache.drill.exec.rpc.RpcEncoder: int PROTOBUF_BODY_TAG>;
specialinvoke v.<oadd.org.apache.drill.exec.rpc.RpcDecoder: void checkTag(oadd.io.netty.buffer.ByteBufInputStream,int)>(v, v);
v = staticinvoke <oadd.org.apache.drill.exec.rpc.RpcDecoder: int readRawVarint32(oadd.io.netty.buffer.ByteBufInputStream)>(v);
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: int readerIndex()>();
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: oadd.io.netty.buffer.ByteBuf slice(int,int)>(v, v);
virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: oadd.io.netty.buffer.ByteBuf skipBytes(int)>(v);
virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: oadd.io.netty.buffer.ByteBuf retain(int)>(1);
v = null;
v = 0;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: int readableBytes()>();
if v <= 0 goto label;
v = <oadd.org.apache.drill.exec.rpc.RpcEncoder: int RAW_BODY_TAG>;
specialinvoke v.<oadd.org.apache.drill.exec.rpc.RpcDecoder: void checkTag(oadd.io.netty.buffer.ByteBufInputStream,int)>(v, v);
v = staticinvoke <oadd.org.apache.drill.exec.rpc.RpcDecoder: int readRawVarint32(oadd.io.netty.buffer.ByteBufInputStream)>(v);
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: int readableBytes()>();
if v == v goto label;
v = new oadd.io.netty.handler.codec.CorruptedFrameException;
v = newarray (java.lang.Object)[2];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: int readableBytes()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Expected to receive a raw body of %d bytes but received a buffer with %d bytes.", v);
specialinvoke v.<oadd.io.netty.handler.codec.CorruptedFrameException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: oadd.io.netty.buffer.ByteBuf slice()>();
virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: oadd.io.netty.buffer.ByteBuf retain(int)>(1);
label:
v = new oadd.org.apache.drill.exec.rpc.InboundRpcMessage;
v = virtualinvoke v.<oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcHeader: oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcMode getMode()>();
v = virtualinvoke v.<oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcHeader: int getRpcType()>();
v = virtualinvoke v.<oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcHeader: int getCoordinationId()>();
specialinvoke v.<oadd.org.apache.drill.exec.rpc.InboundRpcMessage: void <init>(oadd.org.apache.drill.exec.proto.GeneralRPCProtos$RpcMode,int,int,oadd.io.netty.buffer.ByteBuf,oadd.io.netty.buffer.ByteBuf)>(v, v, v, v, v);
virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: oadd.io.netty.buffer.ByteBuf skipBytes(int)>(v);
v = v.<oadd.org.apache.drill.exec.rpc.RpcDecoder: java.util.concurrent.atomic.AtomicLong messageCounter>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long incrementAndGet()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
return;
}
private void checkTag(oadd.io.netty.buffer.ByteBufInputStream, int) throws java.io.IOException
{
java.lang.Object[] v;
oadd.io.netty.buffer.ByteBufInputStream v;
oadd.org.apache.drill.exec.rpc.RpcDecoder v;
long v;
java.lang.Integer v, v;
oadd.io.netty.handler.codec.CorruptedFrameException v;
java.util.concurrent.atomic.AtomicLong v;
java.lang.Long v;
int v, v;
java.lang.String v;
v := @this: oadd.org.apache.drill.exec.rpc.RpcDecoder;
v := @parameter: oadd.io.netty.buffer.ByteBufInputStream;
v := @parameter: int;
v = staticinvoke <oadd.org.apache.drill.exec.rpc.RpcDecoder: int readRawVarint32(oadd.io.netty.buffer.ByteBufInputStream)>(v);
if v == v goto label;
v = new oadd.io.netty.handler.codec.CorruptedFrameException;
v = newarray (java.lang.Object)[3];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = v.<oadd.org.apache.drill.exec.rpc.RpcDecoder: java.util.concurrent.atomic.AtomicLong messageCounter>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Expected to read a tag of %d but actually received a value of %d.  Happened after reading %d message.", v);
specialinvoke v.<oadd.io.netty.handler.codec.CorruptedFrameException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
}
public static int readRawVarint32(oadd.io.netty.buffer.ByteBufInputStream) throws java.io.IOException
{
oadd.io.netty.buffer.ByteBufInputStream v;
byte v, v, v, v, v, v, v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v;
oadd.io.netty.handler.codec.CorruptedFrameException v;
v := @parameter: oadd.io.netty.buffer.ByteBufInputStream;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBufInputStream: byte readByte()>();
if v < 0 goto label;
return v;
label:
v = v & 127;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBufInputStream: byte readByte()>();
if v < 0 goto label;
v = v << 7;
v = v | v;
goto label;
label:
v = v & 127;
v = v << 7;
v = v | v;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBufInputStream: byte readByte()>();
if v < 0 goto label;
v = v << 14;
v = v | v;
goto label;
label:
v = v & 127;
v = v << 14;
v = v | v;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBufInputStream: byte readByte()>();
if v < 0 goto label;
v = v << 21;
v = v | v;
goto label;
label:
v = v & 127;
v = v << 21;
v = v | v;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBufInputStream: byte readByte()>();
v = v << 28;
v = v | v;
if v >= 0 goto label;
v = 0;
label:
if v >= 5 goto label;
v = virtualinvoke v.<oadd.io.netty.buffer.ByteBufInputStream: byte readByte()>();
if v < 0 goto label;
return v;
label:
v = v + 1;
goto label;
label:
v = new oadd.io.netty.handler.codec.CorruptedFrameException;
specialinvoke v.<oadd.io.netty.handler.codec.CorruptedFrameException: void <init>(java.lang.String)>("Encountered a malformed varint.");
throw v;
label:
return v;
}
}