public class org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult extends org.apache.dubbo.rpc.AppResponse implements org.apache.dubbo.remoting.Codec, org.apache.dubbo.remoting.Decodeable
{
private static final org.apache.dubbo.common.logger.Logger log;
private org.apache.dubbo.remoting.Channel channel;
private byte serializationType;
private java.io.InputStream inputStream;
private org.apache.dubbo.remoting.exchange.Response response;
private org.apache.dubbo.rpc.Invocation invocation;
private volatile boolean hasDecoded;
public void <init>(org.apache.dubbo.remoting.Channel, org.apache.dubbo.remoting.exchange.Response, java.io.InputStream, org.apache.dubbo.rpc.Invocation, byte)
{
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v;
byte v;
org.apache.dubbo.rpc.Invocation v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.remoting.exchange.Response v;
java.io.InputStream v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.remoting.exchange.Response;
v := @parameter: java.io.InputStream;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v := @parameter: byte;
specialinvoke v.<org.apache.dubbo.rpc.AppResponse: void <init>()>();
staticinvoke <org.apache.dubbo.common.utils.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "channel == null");
staticinvoke <org.apache.dubbo.common.utils.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "response == null");
staticinvoke <org.apache.dubbo.common.utils.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "inputStream == null");
v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.remoting.Channel channel> = v;
v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.remoting.exchange.Response response> = v;
v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: java.io.InputStream inputStream> = v;
v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.rpc.Invocation invocation> = v;
v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: byte serializationType> = v;
return;
}
public void encode(org.apache.dubbo.remoting.Channel, java.io.OutputStream, java.lang.Object) throws java.io.IOException
{
java.io.OutputStream v;
java.lang.UnsupportedOperationException v;
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v;
java.lang.Object v;
org.apache.dubbo.remoting.Channel v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: java.io.OutputStream;
v := @parameter: java.lang.Object;
v = new java.lang.UnsupportedOperationException;
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>()>();
throw v;
}
public java.lang.Object decode(org.apache.dubbo.remoting.Channel, java.io.InputStream) throws java.io.IOException
{
long v;
org.apache.dubbo.common.URL v, v;
byte v, v;
java.lang.Thread v;
java.lang.String v, v, v;
java.lang.Byte v;
boolean v, v;
org.apache.dubbo.common.logger.Logger v, v;
java.io.IOException v;
org.apache.dubbo.common.serialize.Serialization v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v;
org.apache.dubbo.common.serialize.ObjectInput v;
java.io.InputStream v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: java.io.InputStream;
v = <org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.common.logger.Logger log>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = <org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.common.logger.Logger log>;
v = virtualinvoke v.<java.lang.Thread: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.Thread: long getId()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long)>(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[])>("Decoding in thread -- [\u0001#\u]");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void debug(java.lang.String)>(v);
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: byte serializationType>;
v = staticinvoke <java.lang.Byte: java.lang.Byte valueOf(byte)>(v);
v = staticinvoke <org.apache.dubbo.remoting.transport.CodecSupport: org.apache.dubbo.common.serialize.Serialization getSerialization(org.apache.dubbo.common.URL,java.lang.Byte)>(v, v);
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.Serialization: org.apache.dubbo.common.serialize.ObjectInput deserialize(org.apache.dubbo.common.URL,java.io.InputStream)>(v, v);
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectInput: byte readByte()>();
tableswitch(v)
{
case 0: goto label;
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
case 5: goto label;
default: goto label;
};
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void handleValue(org.apache.dubbo.common.serialize.ObjectInput)>(v);
goto label;
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void handleException(org.apache.dubbo.common.serialize.ObjectInput)>(v);
goto label;
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void handleAttachment(org.apache.dubbo.common.serialize.ObjectInput)>(v);
goto label;
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void handleValue(org.apache.dubbo.common.serialize.ObjectInput)>(v);
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void handleAttachment(org.apache.dubbo.common.serialize.ObjectInput)>(v);
goto label;
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void handleException(org.apache.dubbo.common.serialize.ObjectInput)>(v);
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void handleAttachment(org.apache.dubbo.common.serialize.ObjectInput)>(v);
goto label;
label:
v = new java.io.IOException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (byte)>(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[])>("Unknown result flag, expect \'0\' \'1\' \'2\' \'3\' \'4\' \'5\', but received: \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v instanceof org.apache.dubbo.common.serialize.Cleanable;
if v == 0 goto label;
interfaceinvoke v.<org.apache.dubbo.common.serialize.Cleanable: void cleanup()>();
label:
return v;
}
public void decode() throws java.lang.Exception
{
java.lang.Throwable v, v;
org.apache.dubbo.rpc.Invocation v;
byte v, v, v;
java.lang.String v, v, v, v;
boolean v, v, v;
org.apache.dubbo.common.logger.Logger v, v;
org.apache.dubbo.common.config.Configuration v;
java.io.IOException v;
org.apache.dubbo.remoting.Channel v, v;
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v;
java.lang.Object v;
org.apache.dubbo.remoting.exchange.Response v, v;
java.io.InputStream v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: boolean hasDecoded>;
if v != 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.remoting.Channel channel>;
if v == null goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: java.io.InputStream inputStream>;
if v == null goto label;
label:
v = staticinvoke <org.apache.dubbo.common.config.ConfigurationUtils: org.apache.dubbo.common.config.Configuration getSystemConfiguration()>();
v = interfaceinvoke v.<org.apache.dubbo.common.config.Configuration: boolean getBoolean(java.lang.String,boolean)>("serialization.security.check", 0);
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.rpc.Invocation invocation>;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.lang.Object get(java.lang.Object)>("serialization_id");
if v == null goto label;
v = virtualinvoke v.<java.lang.Byte: byte byteValue()>();
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: byte serializationType>;
if v == v goto label;
v = new java.io.IOException;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: byte serializationType>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (byte)>(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[])>("Unexpected serialization id:\u received from network, please check if the peer send the right id.");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.remoting.Channel channel>;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: java.io.InputStream inputStream>;
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: java.lang.Object decode(org.apache.dubbo.remoting.Channel,java.io.InputStream)>(v, v);
label:
v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: boolean hasDecoded> = 1;
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: 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.DecodeableRpcResult: 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 rpc result failed: \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.remoting.exchange.Response response>;
virtualinvoke v.<org.apache.dubbo.remoting.exchange.Response: void setStatus(byte)>(90);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.remoting.exchange.Response response>;
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:
v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: boolean hasDecoded> = 1;
goto label;
label:
v := @caughtexception;
v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: boolean hasDecoded> = 1;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void handleValue(org.apache.dubbo.common.serialize.ObjectInput) throws java.io.IOException
{
org.apache.dubbo.rpc.Invocation v, v, v;
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v;
java.lang.reflect.Type v, v, v;
int v;
java.lang.reflect.Type[] v;
java.lang.ClassNotFoundException v;
java.lang.Object v;
org.apache.dubbo.common.serialize.ObjectInput v;
boolean v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v := @parameter: org.apache.dubbo.common.serialize.ObjectInput;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.rpc.Invocation invocation>;
v = v instanceof org.apache.dubbo.rpc.RpcInvocation;
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.rpc.Invocation invocation>;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.reflect.Type[] getReturnTypes()>();
goto label;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.rpc.Invocation invocation>;
v = staticinvoke <org.apache.dubbo.rpc.support.RpcUtils: java.lang.reflect.Type[] getReturnTypes(org.apache.dubbo.rpc.Invocation)>(v);
label:
v = staticinvoke <org.apache.dubbo.common.utils.ArrayUtils: boolean isEmpty(java.lang.Object[])>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectInput: java.lang.Object readObject()>();
goto label;
label:
v = lengthof v;
if v != 1 goto label;
v = v[0];
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectInput: java.lang.Object readObject(java.lang.Class)>(v);
goto label;
label:
v = v[0];
v = v[1];
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectInput: java.lang.Object readObject(java.lang.Class,java.lang.reflect.Type)>(v, v);
label:
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void setValue(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void rethrow(java.lang.Exception)>(v);
label:
return;
catch java.lang.ClassNotFoundException from label to label with label;
}
private void handleException(org.apache.dubbo.common.serialize.ObjectInput) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v;
java.lang.ClassNotFoundException v;
org.apache.dubbo.common.serialize.ObjectInput v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v := @parameter: org.apache.dubbo.common.serialize.ObjectInput;
label:
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectInput: java.lang.Throwable readThrowable()>();
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void setException(java.lang.Throwable)>(v);
label:
goto label;
label:
v := @caughtexception;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void rethrow(java.lang.Exception)>(v);
label:
return;
catch java.lang.ClassNotFoundException from label to label with label;
}
private void handleAttachment(org.apache.dubbo.common.serialize.ObjectInput) throws java.io.IOException
{
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v;
java.util.Map v;
java.lang.ClassNotFoundException v;
org.apache.dubbo.common.serialize.ObjectInput v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v := @parameter: org.apache.dubbo.common.serialize.ObjectInput;
label:
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.ObjectInput: java.util.Map readAttachments()>();
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void addObjectAttachments(java.util.Map)>(v);
label:
goto label;
label:
v := @caughtexception;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: void rethrow(java.lang.Exception)>(v);
label:
return;
catch java.lang.ClassNotFoundException from label to label with label;
}
private void rethrow(java.lang.Exception) throws java.io.IOException
{
org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult v;
java.io.IOException v;
java.lang.String v;
java.lang.Exception v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult;
v := @parameter: java.lang.Exception;
v = new java.io.IOException;
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: java.lang.String toString(java.lang.String,java.lang.Throwable)>("Read response data failed.", v);
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
}
static void <clinit>()
{
org.apache.dubbo.common.logger.Logger 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/DecodeableRpcResult;");
<org.apache.dubbo.rpc.protocol.dubbo.DecodeableRpcResult: org.apache.dubbo.common.logger.Logger log> = v;
return;
}
}