public class org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol extends org.apache.dubbo.rpc.protocol.AbstractProtocol
{
public static final java.lang.String NAME;
public static final int DEFAULT_PORT;
private static final java.lang.String IS_CALLBACK_SERVICE_INVOKE;
private static org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol INSTANCE;
private final java.util.Map referenceClientMap;
private final java.util.concurrent.ConcurrentMap locks;
private final java.util.Set optimizers;
private org.apache.dubbo.remoting.exchange.ExchangeHandler requestHandler;
public void <init>()
{
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.concurrent.ConcurrentHashMap v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol$1 v;
org.apache.dubbo.common.utils.ConcurrentHashSet v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractProtocol: void <init>()>();
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map referenceClientMap> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.concurrent.ConcurrentMap locks> = v;
v = new org.apache.dubbo.common.utils.ConcurrentHashSet;
specialinvoke v.<org.apache.dubbo.common.utils.ConcurrentHashSet: void <init>()>();
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Set optimizers> = v;
v = new org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol$1;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol$1: void <init>(org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol)>(v);
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.remoting.exchange.ExchangeHandler requestHandler> = v;
<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol INSTANCE> = v;
return;
}
public static org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol getDubboProtocol()
{
org.apache.dubbo.common.extension.ExtensionLoader v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v, v;
v = <org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol INSTANCE>;
if v != null goto label;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/rpc/Protocol;");
virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: java.lang.Object getExtension(java.lang.String)>("dubbo");
label:
v = <org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol INSTANCE>;
return v;
}
public java.util.Collection getExporters()
{
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.Collection v, v;
java.util.Map v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map exporterMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = staticinvoke <java.util.Collections: java.util.Collection unmodifiableCollection(java.util.Collection)>(v);
return v;
}
private boolean isClientSide(org.apache.dubbo.remoting.Channel)
{
java.net.InetSocketAddress v;
org.apache.dubbo.remoting.Channel v;
java.net.InetAddress v;
org.apache.dubbo.common.URL v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v, v;
java.lang.String v, v, v, v;
boolean v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.remoting.Channel;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getRemoteAddress()>();
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getPort()>();
v = virtualinvoke v.<java.net.InetSocketAddress: int getPort()>();
if v != v goto label;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getIp()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String filterLocalHost(java.lang.String)>(v);
v = virtualinvoke v.<java.net.InetSocketAddress: java.net.InetAddress getAddress()>();
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getHostAddress()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String filterLocalHost(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
org.apache.dubbo.rpc.Invoker getInvoker(org.apache.dubbo.remoting.Channel, org.apache.dubbo.rpc.Invocation) throws org.apache.dubbo.remoting.RemotingException
{
org.apache.dubbo.remoting.RemotingException v;
java.util.Map v, v, v, v, v, v, v, v;
boolean v, v, v;
java.util.Set v;
java.net.InetSocketAddress v, v, v, v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.rpc.Invocation v, v;
org.apache.dubbo.rpc.Invoker v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v;
java.lang.Boolean v, v;
java.lang.String v, v, v, v;
java.lang.Object v, v, v, v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getLocalAddress()>();
v = virtualinvoke v.<java.net.InetSocketAddress: int getPort()>();
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.util.Map getObjectAttachments()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("path");
v = <java.lang.Boolean: java.lang.Boolean TRUE>;
v = virtualinvoke v.<java.lang.Boolean: java.lang.String toString()>();
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.util.Map getObjectAttachments()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("dubbo.stub.event");
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.net.InetSocketAddress: int getPort()>();
label:
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: boolean isClientSide(org.apache.dubbo.remoting.Channel)>(v);
if v == 0 goto label;
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.util.Map getObjectAttachments()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("callback.service.instid");
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.Object)>(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[])>("\u.\u0001");
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.util.Map getObjectAttachments()>();
v = <java.lang.Boolean: java.lang.Boolean TRUE>;
v = virtualinvoke v.<java.lang.Boolean: java.lang.String toString()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("_isCallBackServiceInvoke", v);
label:
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.util.Map getObjectAttachments()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("version");
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.util.Map getObjectAttachments()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("group");
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.lang.String serviceKey(int,java.lang.String,java.lang.String,java.lang.String)>(v, v, v, v);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map exporterMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = new org.apache.dubbo.remoting.RemotingException;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map exporterMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getRemoteAddress()>();
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getLocalAddress()>();
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.Invocation getInvocationWithoutData(org.apache.dubbo.rpc.Invocation)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.util.Set,java.net.InetSocketAddress,java.net.InetSocketAddress,org.apache.dubbo.rpc.Invocation)>(v, v, v, 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[])>("Not found exported service: \u in \u, may be version or group mismatch , channel: consumer: \u --> provider: \u, message:\u0001");
specialinvoke v.<org.apache.dubbo.remoting.RemotingException: void <init>(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
throw v;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboExporter: org.apache.dubbo.rpc.Invoker getInvoker()>();
return v;
}
public java.util.Collection getInvokers()
{
java.util.Set v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.Collection v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Set invokers>;
v = staticinvoke <java.util.Collections: java.util.Collection unmodifiableCollection(java.util.Collection)>(v);
return v;
}
public int getDefaultPort()
{
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
return 20880;
}
public org.apache.dubbo.rpc.Exporter export(org.apache.dubbo.rpc.Invoker) throws org.apache.dubbo.rpc.RpcException
{
java.lang.IllegalStateException v;
org.apache.dubbo.rpc.Invoker v;
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.Map v, v;
int v;
java.lang.Boolean v, v;
java.lang.String v, v, v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboExporter v;
boolean v, v, v, v, v;
org.apache.dubbo.common.logger.Logger v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.rpc.Invoker;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: org.apache.dubbo.common.URL getUrl()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.lang.String serviceKey(org.apache.dubbo.common.URL)>(v);
v = new org.apache.dubbo.rpc.protocol.dubbo.DubboExporter;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map exporterMap>;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboExporter: void <init>(org.apache.dubbo.rpc.Invoker,java.lang.String,java.util.Map)>(v, v, v);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map exporterMap>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("dubbo.stub.event", 0);
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("is_callback_service", 0);
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String)>("dubbo.stub.event.methods");
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v != 0 goto label;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isWarnEnabled()>();
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String)>("interface");
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[])>("consumer [\u], has set stubproxy support event ,but no stub methods founded.");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.Throwable)>(v);
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: void openServer(org.apache.dubbo.common.URL)>(v);
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: void optimizeSerialization(org.apache.dubbo.common.URL)>(v);
return v;
}
private void openServer(org.apache.dubbo.common.URL)
{
java.lang.Throwable v;
org.apache.dubbo.rpc.ProtocolServer v;
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.Map v, v, v;
java.lang.Object v, v;
java.lang.String v;
boolean v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.common.URL;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getAddress()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("isserver", 1);
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map serverMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
entermonitor v;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map serverMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map serverMap>;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.ProtocolServer createServer(org.apache.dubbo.common.URL)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
interfaceinvoke v.<org.apache.dubbo.rpc.ProtocolServer: void reset(org.apache.dubbo.common.URL)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
private org.apache.dubbo.rpc.ProtocolServer createServer(org.apache.dubbo.common.URL)
{
java.lang.Throwable v;
org.apache.dubbo.remoting.exchange.ExchangeServer v;
org.apache.dubbo.common.extension.ExtensionLoader v, v;
org.apache.dubbo.common.URLBuilder v, v, v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocolServer v;
org.apache.dubbo.common.URL v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v, v, v;
java.lang.Boolean v;
java.lang.String v, v, v, v, v, v, v, v;
boolean v, v;
java.util.Set v;
org.apache.dubbo.rpc.RpcException v, v, v;
org.apache.dubbo.remoting.exchange.ExchangeHandler v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.common.URL;
v = staticinvoke <org.apache.dubbo.common.URLBuilder: org.apache.dubbo.common.URLBuilder 'from'(org.apache.dubbo.common.URL)>(v);
v = <java.lang.Boolean: java.lang.Boolean TRUE>;
v = virtualinvoke v.<java.lang.Boolean: java.lang.String toString()>();
v = virtualinvoke v.<org.apache.dubbo.common.URLBuilder: org.apache.dubbo.common.URLBuilder addParameterIfAbsent(java.lang.String,java.lang.String)>("channel.readonly.sent", v);
v = (int) 60000;
v = staticinvoke <java.lang.String: java.lang.String valueOf(int)>(v);
v = virtualinvoke v.<org.apache.dubbo.common.URLBuilder: org.apache.dubbo.common.URLBuilder addParameterIfAbsent(java.lang.String,java.lang.String)>("heartbeat", v);
v = virtualinvoke v.<org.apache.dubbo.common.URLBuilder: org.apache.dubbo.common.URLBuilder addParameter(java.lang.String,java.lang.String)>("codec", "dubbo");
v = virtualinvoke v.<org.apache.dubbo.common.URLBuilder: org.apache.dubbo.common.URL build()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String,java.lang.String)>("server", "netty");
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/remoting/Transporter;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: boolean hasExtension(java.lang.String)>(v);
if v != 0 goto label;
v = new org.apache.dubbo.rpc.RpcException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,org.apache.dubbo.common.URL)>(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[])>("Unsupported server type: \u, url: \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.remoting.exchange.ExchangeHandler requestHandler>;
v = staticinvoke <org.apache.dubbo.remoting.exchange.Exchangers: org.apache.dubbo.remoting.exchange.ExchangeServer bind(org.apache.dubbo.common.URL,org.apache.dubbo.remoting.exchange.ExchangeHandler)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.dubbo.rpc.RpcException;
v = virtualinvoke v.<org.apache.dubbo.remoting.RemotingException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.dubbo.common.URL,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[])>("Fail to start server(url: \u) \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String)>("client");
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/remoting/Transporter;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: java.util.Set getSupportedExtensions()>();
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = new org.apache.dubbo.rpc.RpcException;
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[])>("Unsupported client type: \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new org.apache.dubbo.rpc.protocol.dubbo.DubboProtocolServer;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocolServer: void <init>(org.apache.dubbo.remoting.RemotingServer)>(v);
return v;
catch org.apache.dubbo.remoting.RemotingException from label to label with label;
}
private void optimizeSerialization(org.apache.dubbo.common.URL) throws org.apache.dubbo.rpc.RpcException
{
java.lang.ReflectiveOperationException v;
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.lang.Thread v;
java.lang.String v, v, v, v, v;
boolean v, v, v, v;
java.util.Iterator v;
org.apache.dubbo.common.logger.Logger v;
java.util.Collection v, v;
java.util.Set v, v;
org.apache.dubbo.rpc.RpcException v, v, v;
java.lang.Class v, v, v;
java.lang.ClassNotFoundException v;
java.lang.Object v, v;
java.lang.ClassLoader v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.common.URL;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String,java.lang.String)>("optimizer", "");
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: boolean isEmpty(java.lang.String)>(v);
if v != 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Set optimizers>;
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
label:
return;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>("Optimizing the serialization process for Kryo, FST, etc...");
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.Class loadClass(java.lang.String)>(v);
v = class "Lorg/apache/dubbo/common/serialize/support/SerializationOptimizer;";
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
if v != 0 goto label;
v = new org.apache.dubbo.rpc.RpcException;
v = class "Lorg/apache/dubbo/common/serialize/support/SerializationOptimizer;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
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[])>("The serialization optimizer \u isn\'t an instance of \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.Object newInstance()>();
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.support.SerializationOptimizer: java.util.Collection getSerializableClasses()>();
if v != null goto label;
label:
return;
label:
v = interfaceinvoke v.<org.apache.dubbo.common.serialize.support.SerializationOptimizer: java.util.Collection getSerializableClasses()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
staticinvoke <org.apache.dubbo.common.serialize.support.SerializableClassRegistry: void registerClass(java.lang.Class)>(v);
goto label;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Set optimizers>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.dubbo.rpc.RpcException;
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[])>("Cannot find the serialization optimizer class: \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v := @caughtexception;
v = new org.apache.dubbo.rpc.RpcException;
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[])>("Cannot instantiate the serialization optimizer class: \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.ClassNotFoundException from label to label with label;
catch java.lang.ClassNotFoundException from label to label with label;
catch java.lang.InstantiationException from label to label with label;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.InstantiationException from label to label with label;
catch java.lang.IllegalAccessException from label to label with label;
}
public org.apache.dubbo.rpc.Invoker protocolBindingRefer(java.lang.Class, org.apache.dubbo.common.URL) throws org.apache.dubbo.rpc.RpcException
{
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.Set v, v;
java.lang.Class v;
org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker v;
org.apache.dubbo.remoting.exchange.ExchangeClient[] v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: void optimizeSerialization(org.apache.dubbo.common.URL)>(v);
v = new org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.remoting.exchange.ExchangeClient[] getClients(org.apache.dubbo.common.URL)>(v);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Set invokers>;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: void <init>(java.lang.Class,org.apache.dubbo.common.URL,org.apache.dubbo.remoting.exchange.ExchangeClient[],java.util.Set)>(v, v, v, v);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Set invokers>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
return v;
}
private org.apache.dubbo.remoting.exchange.ExchangeClient[] getClients(org.apache.dubbo.common.URL)
{
org.apache.dubbo.remoting.exchange.ExchangeClient v;
java.util.List v;
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v, v, v;
java.lang.Object v;
java.lang.String v, v, v;
org.apache.dubbo.remoting.exchange.ExchangeClient[] v;
boolean v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.common.URL;
v = 0;
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getParameter(java.lang.String,int)>("connections", 0);
v = null;
if v != 0 goto label;
v = 1;
v = null;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String,java.lang.String)>("shareconnections", v);
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: boolean isBlank(java.lang.CharSequence)>(v);
if v == 0 goto label;
v = staticinvoke <org.apache.dubbo.common.utils.ConfigUtils: java.lang.String getProperty(java.lang.String,java.lang.String)>("shareconnections", "1");
goto label;
label:
v = v;
label:
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.List getSharedClient(org.apache.dubbo.common.URL,int)>(v, v);
label:
v = newarray (org.apache.dubbo.remoting.exchange.ExchangeClient)[v];
v = 0;
label:
v = lengthof v;
if v >= v goto label;
if v == 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v[v] = v;
goto label;
label:
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.remoting.exchange.ExchangeClient initClient(org.apache.dubbo.common.URL)>(v);
v[v] = v;
label:
v = v + 1;
goto label;
label:
return v;
}
private java.util.List getSharedClient(org.apache.dubbo.common.URL, int)
{
java.lang.Throwable v;
java.util.concurrent.ConcurrentMap v, v;
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.Map v, v, v;
int v, v, v, v;
java.lang.String v;
boolean v, v, v, v;
java.lang.Object v, v, v, v, v;
org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: int;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getAddress()>();
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map referenceClientMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: boolean checkClientCanUse(java.util.List)>(v);
if v == 0 goto label;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: void batchClientRefIncr(java.util.List)>(v);
return v;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.concurrent.ConcurrentMap locks>;
v = new java.lang.Object;
specialinvoke v.<java.lang.Object: void <init>()>();
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object putIfAbsent(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.concurrent.ConcurrentMap locks>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
entermonitor v;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map referenceClientMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: boolean checkClientCanUse(java.util.List)>(v);
if v == 0 goto label;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: void batchClientRefIncr(java.util.List)>(v);
exitmonitor v;
label:
return v;
label:
v = staticinvoke <java.lang.Math: int max(int,int)>(v, 1);
v = staticinvoke <org.apache.dubbo.common.utils.CollectionUtils: boolean isEmpty(java.util.Collection)>(v);
if v == 0 goto label;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.List buildReferenceCountExchangeClientList(org.apache.dubbo.common.URL,int)>(v, v);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map referenceClientMap>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = 0;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
if v == null goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: boolean isClosed()>();
if v == 0 goto label;
label:
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient buildReferenceCountExchangeClient(org.apache.dubbo.common.URL)>(v);
interfaceinvoke v.<java.util.List: java.lang.Object set(int,java.lang.Object)>(v, v);
goto label;
label:
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: void incrementAndGetCount()>();
label:
v = v + 1;
goto label;
label:
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private boolean checkClientCanUse(java.util.List)
{
java.util.Iterator v;
java.util.List v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v;
java.lang.Object v;
boolean v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: java.util.List;
v = staticinvoke <org.apache.dubbo.common.utils.CollectionUtils: boolean isEmpty(java.util.Collection)>(v);
if v == 0 goto label;
return 0;
label:
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: int getCount()>();
if v <= 0 goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: boolean isClosed()>();
if v == 0 goto label;
label:
return 0;
label:
return 1;
}
private void batchClientRefIncr(java.util.List)
{
java.util.List v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.Iterator v;
java.lang.Object v;
boolean v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: java.util.List;
v = staticinvoke <org.apache.dubbo.common.utils.CollectionUtils: boolean isEmpty(java.util.Collection)>(v);
if v == 0 goto label;
return;
label:
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
if v == null goto label;
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: void incrementAndGetCount()>();
goto label;
label:
return;
}
private java.util.List buildReferenceCountExchangeClientList(org.apache.dubbo.common.URL, int)
{
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v, v;
org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient v;
java.util.ArrayList v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: int;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = 0;
label:
if v >= v goto label;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient buildReferenceCountExchangeClient(org.apache.dubbo.common.URL)>(v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
return v;
}
private org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient buildReferenceCountExchangeClient(org.apache.dubbo.common.URL)
{
org.apache.dubbo.common.URL v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
org.apache.dubbo.remoting.exchange.ExchangeClient v;
org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.common.URL;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.remoting.exchange.ExchangeClient initClient(org.apache.dubbo.common.URL)>(v);
v = new org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: void <init>(org.apache.dubbo.remoting.exchange.ExchangeClient)>(v);
return v;
}
private org.apache.dubbo.remoting.exchange.ExchangeClient initClient(org.apache.dubbo.common.URL)
{
java.lang.Throwable v;
org.apache.dubbo.common.extension.ExtensionLoader v, v;
org.apache.dubbo.rpc.protocol.dubbo.LazyConnectExchangeClient v;
org.apache.dubbo.common.URL v, v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v, v;
java.lang.String v, v, v, v, v, v, v;
boolean v, v;
java.util.Set v;
org.apache.dubbo.rpc.RpcException v, v;
org.apache.dubbo.remoting.exchange.ExchangeHandler v, v;
java.lang.Object v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.common.URL;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String,java.lang.String)>("server", "netty");
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String,java.lang.String)>("client", v);
v = virtualinvoke v.<org.apache.dubbo.common.URL: org.apache.dubbo.common.URL addParameter(java.lang.String,java.lang.String)>("codec", "dubbo");
v = (int) 60000;
v = staticinvoke <java.lang.String: java.lang.String valueOf(int)>(v);
v = virtualinvoke v.<org.apache.dubbo.common.URL: org.apache.dubbo.common.URL addParameterIfAbsent(java.lang.String,java.lang.String)>("heartbeat", v);
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/remoting/Transporter;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: boolean hasExtension(java.lang.String)>(v);
if v != 0 goto label;
v = new org.apache.dubbo.rpc.RpcException;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/remoting/Transporter;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: java.util.Set getSupportedExtensions()>();
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: java.lang.String join(java.util.Collection,java.lang.String)>(v, " ");
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[])>("Unsupported client type: \u, supported client type is \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("lazy", 0);
if v == 0 goto label;
v = new org.apache.dubbo.rpc.protocol.dubbo.LazyConnectExchangeClient;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.remoting.exchange.ExchangeHandler requestHandler>;
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.LazyConnectExchangeClient: void <init>(org.apache.dubbo.common.URL,org.apache.dubbo.remoting.exchange.ExchangeHandler)>(v, v);
v = v;
goto label;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.remoting.exchange.ExchangeHandler requestHandler>;
v = staticinvoke <org.apache.dubbo.remoting.exchange.Exchangers: org.apache.dubbo.remoting.exchange.ExchangeClient connect(org.apache.dubbo.common.URL,org.apache.dubbo.remoting.exchange.ExchangeHandler)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.dubbo.rpc.RpcException;
v = virtualinvoke v.<org.apache.dubbo.remoting.RemotingException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.dubbo.common.URL,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[])>("Fail to create remoting client for service(\u): \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return v;
catch org.apache.dubbo.remoting.RemotingException from label to label with label;
}
public void destroy()
{
java.lang.Throwable v;
java.util.ArrayList v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
java.util.Map v, v, v, v;
int v;
java.lang.String v, v;
boolean v, v, v, v, v;
java.util.Iterator v, v, v;
org.apache.dubbo.common.logger.Logger v, v, v;
org.apache.dubbo.remoting.RemotingServer v;
java.util.Set v, v;
java.net.InetSocketAddress v;
java.lang.Object v, v, v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v = new java.util.ArrayList;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map serverMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = virtualinvoke v.<java.util.ArrayList: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map serverMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
if v == null goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.ProtocolServer: org.apache.dubbo.remoting.RemotingServer getRemotingServer()>();
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.remoting.RemotingServer: java.net.InetSocketAddress getLocalAddress()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.InetSocketAddress)>(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[])>("Close dubbo server: \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
label:
v = staticinvoke <org.apache.dubbo.common.config.ConfigurationUtils: int getServerShutdownTimeout()>();
interfaceinvoke v.<org.apache.dubbo.remoting.RemotingServer: void close(int)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
label:
v = new java.util.ArrayList;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map referenceClientMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = virtualinvoke v.<java.util.ArrayList: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: java.util.Map referenceClientMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
v = staticinvoke <org.apache.dubbo.common.utils.CollectionUtils: boolean isEmpty(java.util.Collection)>(v);
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: void closeReferenceCountExchangeClient(org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient)>(v);
goto label;
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractProtocol: void destroy()>();
return;
catch java.lang.Throwable from label to label with label;
}
private void closeReferenceCountExchangeClient(org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient)
{
java.lang.Throwable v;
org.apache.dubbo.common.logger.Logger v, v, v;
java.net.InetSocketAddress v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v;
java.lang.String v, v;
org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient v;
boolean v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient;
if v != null goto label;
return;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: java.net.InetSocketAddress getLocalAddress()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: java.net.InetSocketAddress getRemoteAddress()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.InetSocketAddress,java.net.InetSocketAddress)>(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[])>("Close dubbo connect: \u0001-->\u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
label:
v = staticinvoke <org.apache.dubbo.common.config.ConfigurationUtils: int getServerShutdownTimeout()>();
virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ReferenceCountExchangeClient: void close(int)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
private org.apache.dubbo.rpc.Invocation getInvocationWithoutData(org.apache.dubbo.rpc.Invocation)
{
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
org.apache.dubbo.common.logger.Logger v;
org.apache.dubbo.rpc.Invocation v;
org.apache.dubbo.rpc.RpcInvocation v;
boolean v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
return v;
label:
v = v instanceof org.apache.dubbo.rpc.RpcInvocation;
if v == 0 goto label;
virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: void setArguments(java.lang.Object[])>(null);
return v;
label:
return v;
}
}