class org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec extends java.lang.Object
{
private static final org.apache.dubbo.common.logger.Logger logger;
private static final org.apache.dubbo.rpc.ProxyFactory PROXY_FACTORY;
private static final org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol PROTOCOL;
private static final byte CALLBACK_NONE;
private static final byte CALLBACK_CREATE;
private static final byte CALLBACK_DESTROY;
private static final java.lang.String INV_ATT_CALLBACK_KEY;
void <init>()
{
org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
private static byte isCallBack(org.apache.dubbo.common.URL, java.lang.String, java.lang.String, int)
{
org.apache.dubbo.common.URL v;
byte v;
int v;
java.lang.String v, v, v, v, v, v;
boolean v, v, v;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: int;
v = 0;
if v == null goto label;
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean hasServiceMethodParameter(java.lang.String,java.lang.String)>(v, v);
if v == 0 goto label;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(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.\u.callback");
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getServiceParameter(java.lang.String,java.lang.String)>(v, v);
if v == null goto label;
v = "true";
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = "false";
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v == 0 goto label;
v = 2;
label:
return v;
}
private static java.lang.String exportOrUnexportCallbackService(org.apache.dubbo.remoting.Channel, org.apache.dubbo.common.URL, java.lang.Class, java.lang.Object, java.lang.Boolean) throws java.io.IOException
{
java.net.InetAddress v;
org.apache.dubbo.common.URL v, v;
java.util.Map v;
boolean v, v, v, v, v;
java.net.InetSocketAddress v, v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.rpc.ProxyFactory v;
org.apache.dubbo.common.bytecode.Wrapper v;
java.lang.String[] v;
java.util.HashMap v, v;
org.apache.dubbo.rpc.Invoker v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v, v, v;
java.lang.Boolean v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.dubbo.rpc.Exporter v;
org.apache.dubbo.common.logger.Logger v;
org.apache.dubbo.rpc.model.ServiceRepository v;
java.lang.Class v;
java.lang.Object v, v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Boolean;
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>(int)>(3);
v = <java.lang.Boolean: java.lang.Boolean FALSE>;
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)>("isserver", v);
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)>("is_callback_service", v);
if v != null goto label;
v = null;
goto label;
label:
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String)>("group");
label:
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("group", v);
label:
v = staticinvoke <org.apache.dubbo.common.bytecode.Wrapper: org.apache.dubbo.common.bytecode.Wrapper getWrapper(java.lang.Class)>(v);
v = virtualinvoke v.<org.apache.dubbo.common.bytecode.Wrapper: java.lang.String[] getDeclaredMethodNames()>();
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: java.lang.String join(java.lang.String[],java.lang.String)>(v, ",");
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("methods", v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.util.Map getParameters()>();
if v == null goto label;
v = interfaceinvoke v.<java.util.Map: boolean isEmpty()>();
if v != 0 goto label;
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
label:
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>("version");
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>("bind.port");
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("interface", v);
v = new org.apache.dubbo.common.URL;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getLocalAddress()>();
v = virtualinvoke v.<java.net.InetSocketAddress: java.net.InetAddress getAddress()>();
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getHostAddress()>();
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getLocalAddress()>();
v = virtualinvoke v.<java.net.InetSocketAddress: int getPort()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(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");
specialinvoke v.<org.apache.dubbo.common.URL: void <init>(java.lang.String,java.lang.String,int,java.lang.String,java.util.Map)>("dubbo", v, v, v, v);
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String getClientSideCallbackServiceCacheKey(int)>(v);
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String getClientSideCountKey(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: boolean hasAttribute(java.lang.String)>(v);
if v != 0 goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: boolean isInstancesOverLimit(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.URL,java.lang.String,int,boolean)>(v, v, v, v, 0);
if v != 0 goto label;
v = staticinvoke <org.apache.dubbo.rpc.model.ApplicationModel: org.apache.dubbo.rpc.model.ServiceRepository getServiceRepository()>();
virtualinvoke v.<org.apache.dubbo.rpc.model.ServiceRepository: org.apache.dubbo.rpc.model.ServiceDescriptor registerService(java.lang.Class)>(v);
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.rpc.ProxyFactory PROXY_FACTORY>;
v = interfaceinvoke v.<org.apache.dubbo.rpc.ProxyFactory: org.apache.dubbo.rpc.Invoker getInvoker(java.lang.Object,java.lang.Class,org.apache.dubbo.common.URL)>(v, v, v);
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol PROTOCOL>;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.Exporter export(org.apache.dubbo.rpc.Invoker)>(v);
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void setAttribute(java.lang.String,java.lang.Object)>(v, v);
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.dubbo.common.URL,org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.URL)>(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[])>("Export a callback service :\u, on \u, url is: \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: void increaseInstanceCount(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
goto label;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: boolean hasAttribute(java.lang.String)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>(v);
interfaceinvoke v.<org.apache.dubbo.rpc.Exporter: void unexport()>();
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void removeAttribute(java.lang.String)>(v);
staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: void decreaseInstanceCount(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
label:
v = staticinvoke <java.lang.String: java.lang.String valueOf(int)>(v);
return v;
}
private static java.lang.Object referOrDestroyCallbackService(org.apache.dubbo.remoting.Channel, org.apache.dubbo.common.URL, java.lang.Class, org.apache.dubbo.rpc.Invocation, int, boolean)
{
org.apache.dubbo.rpc.protocol.AsyncToSyncInvoker v;
org.apache.dubbo.common.URL v, v, v, v, v;
java.util.Map v;
boolean v, v;
org.apache.dubbo.remoting.Channel v;
java.lang.Exception v;
org.apache.dubbo.common.utils.ConcurrentHashSet v;
org.apache.dubbo.rpc.ProxyFactory v;
org.apache.dubbo.rpc.Invocation v;
int v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.dubbo.common.logger.Logger v, v;
org.apache.dubbo.rpc.model.ServiceRepository v;
java.lang.Class v;
java.lang.Object v, v, v, v, v;
org.apache.dubbo.rpc.protocol.dubbo.ChannelWrappedInvoker v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v := @parameter: int;
v := @parameter: boolean;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String getServerSideCallbackInvokerCacheKey(org.apache.dubbo.remoting.Channel,java.lang.String,int)>(v, v, v);
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String getServerSideCallbackServiceCacheKey(org.apache.dubbo.remoting.Channel,java.lang.String,int)>(v, v, v);
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String getServerSideCountKey(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
if v == 0 goto label;
if v != null goto label;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getAddress()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.String)>(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[])>("callback://\u0001/\u0001?interface=\u0001");
v = staticinvoke <org.apache.dubbo.common.URL: org.apache.dubbo.common.URL valueOf(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.util.Map getParameters()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: org.apache.dubbo.common.URL addParametersIfAbsent(java.util.Map)>(v);
v = virtualinvoke v.<org.apache.dubbo.common.URL: org.apache.dubbo.common.URL removeParameter(java.lang.String)>("methods");
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: boolean isInstancesOverLimit(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.URL,java.lang.String,int,boolean)>(v, v, v, v, 1);
if v != 0 goto label;
v = staticinvoke <org.apache.dubbo.rpc.model.ApplicationModel: org.apache.dubbo.rpc.model.ServiceRepository getServiceRepository()>();
virtualinvoke v.<org.apache.dubbo.rpc.model.ServiceRepository: org.apache.dubbo.rpc.model.ServiceDescriptor registerService(java.lang.Class)>(v);
v = new org.apache.dubbo.rpc.protocol.dubbo.ChannelWrappedInvoker;
v = staticinvoke <java.lang.String: java.lang.String valueOf(int)>(v);
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.ChannelWrappedInvoker: void <init>(java.lang.Class,org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.URL,java.lang.String)>(v, v, v, v);
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.rpc.ProxyFactory PROXY_FACTORY>;
v = new org.apache.dubbo.rpc.protocol.AsyncToSyncInvoker;
specialinvoke v.<org.apache.dubbo.rpc.protocol.AsyncToSyncInvoker: void <init>(org.apache.dubbo.rpc.Invoker)>(v);
v = interfaceinvoke v.<org.apache.dubbo.rpc.ProxyFactory: java.lang.Object getProxy(org.apache.dubbo.rpc.Invoker)>(v);
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void setAttribute(java.lang.String,java.lang.Object)>(v, v);
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void setAttribute(java.lang.String,java.lang.Object)>(v, v);
staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: void increaseInstanceCount(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>("channel.callback.invokers.key");
if v != null goto label;
v = new org.apache.dubbo.common.utils.ConcurrentHashSet;
specialinvoke v.<org.apache.dubbo.common.utils.ConcurrentHashSet: void <init>(int)>(1);
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void setAttribute(java.lang.String,java.lang.Object)>("channel.callback.invokers.key", v);
label:
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.lang.String getMethodName()>();
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: org.apache.dubbo.common.URL getUrl()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,org.apache.dubbo.common.URL,org.apache.dubbo.rpc.protocol.dubbo.ChannelWrappedInvoker)>(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[])>("method \u include a callback service :\u, a proxy :\u has been created.");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
goto label;
label:
if v == null goto label;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>(v);
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>("channel.callback.invokers.key");
if v == null goto label;
interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
label:
interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: void destroy()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void removeAttribute(java.lang.String)>(v);
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void removeAttribute(java.lang.String)>(v);
staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: void decreaseInstanceCount(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
label:
return v;
catch java.lang.Exception from label to label with label;
}
private static java.lang.String getClientSideCallbackServiceCacheKey(int)
{
int v;
java.lang.String v;
v := @parameter: int;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("callback.service.instid.\u0001");
return v;
}
private static java.lang.String getServerSideCallbackServiceCacheKey(org.apache.dubbo.remoting.Channel, java.lang.String, int)
{
int v, v;
java.lang.String v, v;
org.apache.dubbo.remoting.Channel v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: java.lang.String;
v := @parameter: int;
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,java.lang.String,int)>(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[])>("callback.service.proxy.\u.\u.\u0001");
return v;
}
private static java.lang.String getServerSideCallbackInvokerCacheKey(org.apache.dubbo.remoting.Channel, java.lang.String, int)
{
int v;
java.lang.String v, v, v;
org.apache.dubbo.remoting.Channel v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: java.lang.String;
v := @parameter: int;
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String getServerSideCallbackServiceCacheKey(org.apache.dubbo.remoting.Channel,java.lang.String,int)>(v, v, v);
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[])>("\u.invoker");
return v;
}
private static java.lang.String getClientSideCountKey(java.lang.String)
{
java.lang.String v, v;
v := @parameter: java.lang.String;
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[])>("callback.service.instid.\u.COUNT");
return v;
}
private static java.lang.String getServerSideCountKey(org.apache.dubbo.remoting.Channel, java.lang.String)
{
int v;
java.lang.String v, v;
org.apache.dubbo.remoting.Channel v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: java.lang.String;
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,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[])>("callback.service.proxy.\u.\u.COUNT");
return v;
}
private static boolean isInstancesOverLimit(org.apache.dubbo.remoting.Channel, org.apache.dubbo.common.URL, java.lang.String, int, boolean)
{
java.lang.IllegalStateException v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.common.URL v;
int v, v, v, v, v;
java.lang.Object v;
java.lang.String v, v, v;
boolean v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.String;
v := @parameter: int;
v := @parameter: boolean;
if v == 0 goto label;
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String getServerSideCountKey(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
goto label;
label:
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String getClientSideCountKey(java.lang.String)>(v);
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getParameter(java.lang.String,int)>("callbacks", 1);
if v == null goto label;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v < v goto label;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = v + 1;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int,int,org.apache.dubbo.remoting.Channel)>(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[])>("interface \u `s callback instances num exceed providers limit :\u ,current num: \u. The new callback service will not work !!! you can cancle the callback service which exported before. channel :\u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
return 0;
}
private static void increaseInstanceCount(org.apache.dubbo.remoting.Channel, java.lang.String)
{
org.apache.dubbo.common.logger.Logger v;
java.lang.Integer v, v;
org.apache.dubbo.remoting.Channel v;
java.lang.Exception v;
int v, v;
java.lang.Object v;
java.lang.String v, v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: java.lang.String;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>(v);
if v != null goto label;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(1);
goto label;
label:
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = v + 1;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = v;
label:
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void setAttribute(java.lang.String,java.lang.Object)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Exception from label to label with label;
}
private static void decreaseInstanceCount(org.apache.dubbo.remoting.Channel, java.lang.String)
{
org.apache.dubbo.common.logger.Logger v;
java.lang.Integer v;
org.apache.dubbo.remoting.Channel v;
java.lang.Exception v;
int v, v, v;
java.lang.Object v;
java.lang.String v, v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: java.lang.String;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>(v);
if v == null goto label;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v > 0 goto label;
label:
return;
label:
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = v - 1;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void setAttribute(java.lang.String,java.lang.Object)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
public static java.lang.Object encodeInvocationArgument(org.apache.dubbo.remoting.Channel, org.apache.dubbo.rpc.RpcInvocation, int) throws java.io.IOException
{
java.lang.Object[] v;
org.apache.dubbo.rpc.Invoker v, v;
org.apache.dubbo.common.URL v;
byte v;
int v;
java.lang.Boolean v, v;
java.lang.String v, v, v, v, v, v;
org.apache.dubbo.rpc.RpcInvocation v;
java.lang.Class[] v;
org.apache.dubbo.remoting.Channel v;
java.lang.Class v, v;
java.lang.Object v, v, v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.rpc.RpcInvocation;
v := @parameter: int;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: org.apache.dubbo.rpc.Invoker getInvoker()>();
if v != null goto label;
v = null;
goto label;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: org.apache.dubbo.rpc.Invoker getInvoker()>();
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: org.apache.dubbo.common.URL getUrl()>();
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getProtocolServiceKey()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getMethodName()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: byte isCallBack(org.apache.dubbo.common.URL,java.lang.String,java.lang.String,int)>(v, v, v, v);
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.Object[] getArguments()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.Class[] getParameterTypes()>();
lookupswitch(v)
{
case 1: goto label;
case 2: goto label;
default: goto label;
};
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("sys_callback_arg-\u0001");
v = v[v];
v = v[v];
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(1);
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String exportOrUnexportCallbackService(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.URL,java.lang.Class,java.lang.Object,java.lang.Boolean)>(v, v, v, v, v);
virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: void setAttachment(java.lang.String,java.lang.String)>(v, v);
return null;
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("sys_callback_arg-\u0001");
v = v[v];
v = v[v];
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(0);
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.String exportOrUnexportCallbackService(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.URL,java.lang.Class,java.lang.Object,java.lang.Boolean)>(v, v, v, v, v);
virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: void setAttachment(java.lang.String,java.lang.String)>(v, v);
return null;
label:
v = v[v];
return v;
}
public static java.lang.Object decodeInvocationArgument(org.apache.dubbo.remoting.Channel, org.apache.dubbo.rpc.RpcInvocation, java.lang.Class[], int, java.lang.Object) throws java.io.IOException
{
org.apache.dubbo.common.URL v;
byte v;
boolean v;
org.apache.dubbo.remoting.Channel v;
java.lang.Exception v, v;
java.lang.Throwable v;
org.apache.dubbo.rpc.Invoker v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
int v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
org.apache.dubbo.rpc.RpcInvocation v;
org.apache.dubbo.common.logger.Logger v, v, v;
java.lang.Class[] v;
java.io.IOException v, v;
java.lang.Class v, v;
java.lang.Object v, v, v;
v := @parameter: org.apache.dubbo.remoting.Channel;
v := @parameter: org.apache.dubbo.rpc.RpcInvocation;
v := @parameter: java.lang.Class[];
v := @parameter: int;
v := @parameter: java.lang.Object;
label:
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol getDubboProtocol()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.Invoker getInvoker(org.apache.dubbo.remoting.Channel,org.apache.dubbo.rpc.Invocation)>(v, v);
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: org.apache.dubbo.common.URL getUrl()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<org.apache.dubbo.remoting.RemotingException: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String,java.lang.Throwable)>(v, v);
label:
return v;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getProtocolServiceKey()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getMethodName()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: byte isCallBack(org.apache.dubbo.common.URL,java.lang.String,java.lang.String,int)>(v, v, v, v);
lookupswitch(v)
{
case 1: goto label;
case 2: goto label;
default: goto label;
};
label:
v = v[v];
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("sys_callback_arg-\u0001");
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getAttachment(java.lang.String)>(v);
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.Object referOrDestroyCallbackService(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.URL,java.lang.Class,org.apache.dubbo.rpc.Invocation,int,boolean)>(v, v, v, v, v, 1);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
v = new java.io.IOException;
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: java.lang.String toString(java.lang.Throwable)>(v);
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v[v];
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("sys_callback_arg-\u0001");
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: java.lang.String getAttachment(java.lang.String)>(v);
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: java.lang.Object referOrDestroyCallbackService(org.apache.dubbo.remoting.Channel,org.apache.dubbo.common.URL,java.lang.Class,org.apache.dubbo.rpc.Invocation,int,boolean)>(v, v, v, v, v, 0);
label:
return v;
label:
v := @caughtexception;
v = new java.io.IOException;
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: java.lang.String toString(java.lang.Throwable)>(v);
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
catch org.apache.dubbo.remoting.RemotingException from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void <clinit>()
{
org.apache.dubbo.common.extension.ExtensionLoader v;
org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol v;
org.apache.dubbo.common.logger.Logger v;
java.lang.Object 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/CallbackServiceCodec;");
<org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.common.logger.Logger logger> = v;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/rpc/ProxyFactory;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: java.lang.Object getAdaptiveExtension()>();
<org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.rpc.ProxyFactory PROXY_FACTORY> = v;
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol getDubboProtocol()>();
<org.apache.dubbo.rpc.protocol.dubbo.CallbackServiceCodec: org.apache.dubbo.rpc.protocol.dubbo.DubboProtocol PROTOCOL> = v;
return;
}
}