public class org.apache.dubbo.rpc.protocol.dubbo.DubboCodec extends org.apache.dubbo.remoting.exchange.codec.ExchangeCodec
{
public static final java.lang.String NAME;
public static final java.lang.String DUBBO_VERSION;
public static final byte RESPONSE_WITH_EXCEPTION;
public static final byte RESPONSE_VALUE;
public static final byte RESPONSE_NULL_VALUE;
public static final byte RESPONSE_WITH_EXCEPTION_WITH_ATTACHMENTS;
public static final byte RESPONSE_VALUE_WITH_ATTACHMENTS;
public static final byte RESPONSE_NULL_VALUE_WITH_ATTACHMENTS;
public static final java.lang.Object[] EMPTY_OBJECT_ARRAY;
public static final java.lang.Class[] EMPTY_CLASS_ARRAY;
private static final org.apache.dubbo.common.logger.Logger log;
public void <init>()
{
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
specialinvoke v.<org.apache.dubbo.remoting.exchange.codec.ExchangeCodec: void <init>()>();
return;
}
protected java.lang.Object decodeBody(org.apache.dubbo.remoting.Channel, java.io.InputStream, byte[]) throws java.io.IOException
{
byte[] v, v, v, v, v;
org.apache.dubbo.common.URL v, v, v, v, v;
byte v, v, v, v, v, v, v;
java.io.ByteArrayInputStream v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
boolean v, v, v, v, v, v, v, v, v;
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcInvocation v, v, v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v, v, v;
org.apache.dubbo.remoting.exchange.Response v;
java.lang.Throwable v, v;
org.apache.dubbo.remoting.exchange.Request v;
long v;
java.lang.String v, v, v, v, v, v, v;
org.apache.dubbo.common.logger.Logger v, v, v, v;
org.apache.dubbo.common.io.UnsafeByteArrayInputStream v, v;
java.lang.Object v, v, v, v;
org.apache.dubbo.common.serialize.ObjectInput v, v, v;
java.io.InputStream v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: java.io.InputStream;
v := @parameter: byte[];
v = v[2];
v = v & 31;
v = staticinvoke <org.apache.dubbo.common.io.Bytes: long bytes2long(byte[],int)>(v, 4);
v = v & -128;
if v != 0 goto label;
v = new org.apache.dubbo.remoting.exchange.Response;
specialinvoke v.<org.apache.dubbo.remoting.exchange.Response: void <init>(long)>(v);
v = v & 32;
if v == 0 goto label;
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: void setEvent(boolean)>(1);
label:
v = v[3];
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: void setStatus(byte)>(v);
label:
if v != 20 goto label;
v = virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: boolean isEvent()>();
if v == 0 goto label;
v = staticinvoke <org.apache.dubbo.remoting.transport.CodecSupport: byte[] getPayload(java.io.InputStream)>(v);
v = staticinvoke <org.apache.dubbo.remoting.transport.CodecSupport: boolean isHeartBeat(byte[],byte)>(v, v);
if v == 0 goto label;
v = null;
goto label;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = new java.io.ByteArrayInputStream;
specialinvoke v.<java.io.ByteArrayInputStream: void <init>(byte[])>(v);
v = staticinvoke <org.apache.dubbo.remoting.transport.CodecSupport: org.apache.dubbo.common.serialize.ObjectInput deserialize(org.apache.dubbo.common.URL,java.io.InputStream,byte)>(v, v, v);
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.Object decodeEventData(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.serialize.ObjectInput,byte[])>(v, v, v);
goto label;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("decode.in.io", 0);
if v == 0 goto label;
v = new org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.Object getRequestData(long)>(v);
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void <init>(org.apache.dubbo.remoting.Channel,org.apache.dubbo.remoting.exchange.Response,java.io.InputStream,org.apache.dubbo.rpc.Invocation,byte)>(v, v, v, v, v);
v = v;
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void decode()>();
goto label;
label:
v = new org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v = new org.apache.dubbo.common.io.UnsafeByteArrayInputStream;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: byte[] readMessageData(java.io.InputStream)>(v);
specialinvoke v.<org.apache.dubbo.common.io.UnsafeByteArrayInputStream: void <init>(byte[])>(v);
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.Object getRequestData(long)>(v);
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void <init>(org.apache.dubbo.remoting.Channel,org.apache.dubbo.remoting.exchange.Response,java.io.InputStream,org.apache.dubbo.rpc.Invocation,byte)>(v, v, v, v, v);
v = v;
label:
v = v;
label:
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: void setResult(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = staticinvoke <org.apache.dubbo.remoting.transport.CodecSupport: org.apache.dubbo.common.serialize.ObjectInput deserialize(org.apache.dubbo.common.URL,java.io.InputStream,byte)>(v, v, v);
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectInput: java.lang.String readUTF()>();
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: void setErrorMessage(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: org.apache.dubbo.common.logger.Logger log>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isWarnEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: org.apache.dubbo.common.logger.Logger log>;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
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[])>("Decode response failed: \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
label:
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: void setStatus(byte)>(90);
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: java.lang.String toString(java.lang.Throwable)>(v);
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: void setErrorMessage(java.lang.String)>(v);
label:
return v;
label:
v = new org.apache.dubbo.remoting.exchange.Request;
specialinvoke v.<org.apache.dubbo.remoting.exchange.Request: void <init>(long)>(v);
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getProtocolVersion()>();
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: void setVersion(java.lang.String)>(v);
v = v & 64;
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: void setTwoWay(boolean)>(v);
v = v & 32;
if v == 0 goto label;
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: void setEvent(boolean)>(1);
label:
v = virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: boolean isEvent()>();
if v == 0 goto label;
v = staticinvoke <org.apache.dubbo.remoting.transport.CodecSupport: byte[] getPayload(java.io.InputStream)>(v);
v = staticinvoke <org.apache.dubbo.remoting.transport.CodecSupport: boolean isHeartBeat(byte[],byte)>(v, v);
if v == 0 goto label;
v = null;
goto label;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = new java.io.ByteArrayInputStream;
specialinvoke v.<java.io.ByteArrayInputStream: void <init>(byte[])>(v);
v = staticinvoke <org.apache.dubbo.remoting.transport.CodecSupport: org.apache.dubbo.common.serialize.ObjectInput deserialize(org.apache.dubbo.common.URL,java.io.InputStream,byte)>(v, v, v);
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.Object decodeEventData(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.serialize.ObjectInput,byte[])>(v, v, v);
goto label;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("decode.in.io", 0);
if v == 0 goto label;
v = new org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcInvocation;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcInvocation: void <init>(org.apache.dubbo.remoting.Channel,org.apache.dubbo.remoting.exchange.Request,java.io.InputStream,byte)>(v, v, v, v);
v = v;
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcInvocation: void decode()>();
goto label;
label:
v = new org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcInvocation;
v = new org.apache.dubbo.common.io.UnsafeByteArrayInputStream;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: byte[] readMessageData(java.io.InputStream)>(v);
specialinvoke v.<org.apache.dubbo.common.io.UnsafeByteArrayInputStream: void <init>(byte[])>(v);
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcInvocation: void <init>(org.apache.dubbo.remoting.Channel,org.apache.dubbo.remoting.exchange.Request,java.io.InputStream,byte)>(v, v, v, v);
v = v;
label:
v = v;
label:
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: void setData(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: org.apache.dubbo.common.logger.Logger log>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isWarnEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: org.apache.dubbo.common.logger.Logger log>;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
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[])>("Decode request failed: \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
label:
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: void setBroken(boolean)>(1);
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: void setData(java.lang.Object)>(v);
label:
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private byte[] readMessageData(java.io.InputStream) throws java.io.IOException
{
byte[] v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
int v, v;
java.io.InputStream v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
v := @parameter: java.io.InputStream;
v = virtualinvoke v.<java.io.InputStream: int available()>();
if v <= 0 goto label;
v = virtualinvoke v.<java.io.InputStream: int available()>();
v = newarray (byte)[v];
virtualinvoke v.<java.io.InputStream: int read(byte[])>(v);
return v;
label:
v = newarray (byte)[0];
return v;
}
protected void encodeRequestData(org.apache.dubbo.remoting.Channel, org.apache.dubbo.common.serialize.ObjectOutput, java.lang.Object) throws java.io.IOException
{
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
java.lang.Object v;
java.lang.String v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.common.serialize.ObjectOutput v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.common.serialize.ObjectOutput;
v := @parameter: java.lang.Object;
v = <org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.String DUBBO_VERSION>;
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: void encodeRequestData(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.serialize.ObjectOutput,java.lang.Object,java.lang.String)>(v, v, v, v);
return;
}
protected void encodeResponseData(org.apache.dubbo.remoting.Channel, org.apache.dubbo.common.serialize.ObjectOutput, java.lang.Object) throws java.io.IOException
{
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
java.lang.Object v;
java.lang.String v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.common.serialize.ObjectOutput v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.common.serialize.ObjectOutput;
v := @parameter: java.lang.Object;
v = <org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.String DUBBO_VERSION>;
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: void encodeResponseData(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.serialize.ObjectOutput,java.lang.Object,java.lang.String)>(v, v, v, v);
return;
}
protected void encodeRequestData(org.apache.dubbo.remoting.Channel, org.apache.dubbo.common.serialize.ObjectOutput, java.lang.Object, java.lang.String) throws java.io.IOException
{
java.lang.Object[] v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.common.serialize.ObjectOutput v;
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
java.util.Map v;
int v, v;
java.lang.Object v, v;
java.lang.String v, v, v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.common.serialize.ObjectOutput;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.String;
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeUTF(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getAttachment(java.lang.String)>("interface");
if v != null goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getAttachment(java.lang.String)>("path");
label:
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeUTF(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getAttachment(java.lang.String)>("version");
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeUTF(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getMethodName()>();
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeUTF(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getParameterTypesDesc()>();
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeUTF(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.Object[] getArguments()>();
if v == null goto label;
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.Object encodeInvocationArgument(org.apache.dubbo.remoting.Channel,org.apache.dubbo.rpc.RpcInvocation,int)>(v, v, v);
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeObject(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.util.Map getObjectAttachments()>();
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeAttachments(java.util.Map)>(v);
return;
}
protected void encodeResponseData(org.apache.dubbo.remoting.Channel, org.apache.dubbo.common.serialize.ObjectOutput, java.lang.Object, java.lang.String) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.common.serialize.ObjectOutput v;
byte v, v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
java.util.Map v, v;
java.lang.Object v, v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.common.serialize.ObjectOutput;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.dubbo.common.Version: boolean isSupportResponseAttachment(java.lang.String)>(v);
v = interfaceinvoke v.<org.apache.dubbo.rpc.Result: java.lang.Throwable getException()>();
if v != null goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Result: java.lang.Object getValue()>();
if v != null goto label;
if v == 0 goto label;
v = 5;
goto label;
label:
v = 2;
label:
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeByte(byte)>(v);
goto label;
label:
if v == 0 goto label;
v = 4;
goto label;
label:
v = 1;
label:
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeByte(byte)>(v);
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeObject(java.lang.Object)>(v);
goto label;
label:
if v == 0 goto label;
v = 3;
goto label;
label:
v = 0;
label:
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeByte(byte)>(v);
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeThrowable(java.lang.Object)>(v);
label:
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Result: java.util.Map getObjectAttachments()>();
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getProtocolVersion()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("dubbo", v);
v = interfaceinvoke v.<org.apache.dubbo.rpc.Result: java.util.Map getObjectAttachments()>();
interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectOutput: void writeAttachments(java.util.Map)>(v);
label:
return;
}
protected org.apache.dubbo.common.serialize.Serialization getSerialization(org.apache.dubbo.remoting.Channel, org.apache.dubbo.remoting.exchange.Request)
{
org.apache.dubbo.remoting.exchange.Request v;
org.apache.dubbo.common.serialize.Serialization v, v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
java.lang.Object v, v;
boolean v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.remoting.exchange.Request;
v = virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: java.lang.Object getData()>();
v = v instanceof org.apache.dubbo.rpc.Invocation;
if v != 0 goto label;
v = specialinvoke v.<org.apache.dubbo.remoting.exchange.codec.ExchangeCodec: org.apache.dubbo.common.serialize.Serialization getSerialization(org.apache.dubbo.remoting.Channel,org.apache.dubbo.remoting.exchange.Request)>(v, v);
return v;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.exchange.Request: java.lang.Object getData()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.DubboCodecSupport: org.apache.dubbo.common.serialize.Serialization getRequestSerialization(org.apache.dubbo.common.URL,org.apache.dubbo.rpc.Invocation)>(v, v);
return v;
}
protected org.apache.dubbo.common.serialize.Serialization getSerialization(org.apache.dubbo.remoting.Channel, org.apache.dubbo.remoting.exchange.Response)
{
org.apache.dubbo.common.serialize.Serialization v, v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboCodec v;
java.lang.Object v, v;
org.apache.dubbo.remoting.exchange.Response v;
boolean v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboCodec;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.remoting.exchange.Response;
v = virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: java.lang.Object getResult()>();
v = v instanceof org.apache.dubbo.rpc.AppResponse;
if v != 0 goto label;
v = specialinvoke v.<org.apache.dubbo.remoting.exchange.codec.ExchangeCodec: org.apache.dubbo.common.serialize.Serialization getSerialization(org.apache.dubbo.remoting.Channel,org.apache.dubbo.remoting.exchange.Response)>(v, v);
return v;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: java.lang.Object getResult()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.DubboCodecSupport: org.apache.dubbo.common.serialize.Serialization getResponseSerialization(org.apache.dubbo.common.URL,org.apache.dubbo.rpc.AppResponse)>(v, v);
return v;
}
static void <clinit>()
{
java.lang.Object[] v;
org.apache.dubbo.common.logger.Logger v;
java.lang.Class[] v;
java.lang.String v;
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getProtocolVersion()>();
<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.String DUBBO_VERSION> = v;
v = newarray (java.lang.Object)[0];
<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.Object[] EMPTY_OBJECT_ARRAY> = v;
v = newarray (java.lang.Class)[0];
<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: java.lang.Class[] EMPTY_CLASS_ARRAY> = v;
v = staticinvoke <org.apache.dubbo.common.logger.LoggerFactory: org.apache.dubbo.common.logger.Logger getLogger(java.lang.Class)>(class "Lorg/apache/dubbo/rpc/protocol/dubbo/DubboCodec;");
<org.apache.dubbo.rpc.protocol.dubbo.DubboCodec: org.apache.dubbo.common.logger.Logger log> = v;
return;
}
}