public class org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol extends org.apache.dubbo.rpc.protocol.AbstractProxyProtocol
{
public static final int DEFAULT_PORT;
public static final java.lang.String NAME;
public static final java.lang.String THRIFT_IFACE;
public static final java.lang.String THRIFT_PROCESSOR;
public static final java.lang.String THRIFT_CLIENT;
private static final java.util.Map SERVER_MAP;
private org.apache.thrift.TMultiplexedProcessor processor;
public void <init>()
{
java.lang.Class[] v;
org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol v;
org.apache.thrift.TMultiplexedProcessor v;
v := @this: org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol;
v = newarray (java.lang.Class)[2];
v[0] = class "Lorg/apache/thrift/TException;";
v[1] = class "Lorg/apache/dubbo/rpc/RpcException;";
specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractProxyProtocol: void <init>(java.lang.Class[])>(v);
v = new org.apache.thrift.TMultiplexedProcessor;
specialinvoke v.<org.apache.thrift.TMultiplexedProcessor: void <init>()>();
v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: org.apache.thrift.TMultiplexedProcessor processor> = v;
return;
}
public transient void <init>(java.lang.Class[])
{
java.lang.Class[] v;
org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol v;
org.apache.thrift.TMultiplexedProcessor v;
v := @this: org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol;
v := @parameter: java.lang.Class[];
specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractProxyProtocol: void <init>(java.lang.Class[])>(v);
v = new org.apache.thrift.TMultiplexedProcessor;
specialinvoke v.<org.apache.thrift.TMultiplexedProcessor: void <init>()>();
v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: org.apache.thrift.TMultiplexedProcessor processor> = v;
return;
}
public int getDefaultPort()
{
int v;
org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol v;
v := @this: org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol;
v = (int) 40880;
return v;
}
protected java.lang.Runnable doExport(java.lang.Object, java.lang.Class, org.apache.dubbo.common.URL) throws org.apache.dubbo.rpc.RpcException
{
org.apache.dubbo.common.URL v;
java.lang.Class v;
java.lang.Object v;
org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol v;
java.lang.Runnable v;
v := @this: org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: java.lang.Runnable exportThreadedSelectorServer(java.lang.Object,java.lang.Class,org.apache.dubbo.common.URL)>(v, v, v);
return v;
}
protected java.lang.Object doRefer(java.lang.Class, org.apache.dubbo.common.URL) throws org.apache.dubbo.rpc.RpcException
{
org.apache.dubbo.common.URL v;
java.lang.Class v;
java.lang.Object v;
org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol v;
v := @this: org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: java.lang.Object doReferFrameAndCompact(java.lang.Class,org.apache.dubbo.common.URL)>(v, v);
return v;
}
private java.lang.Runnable exportThreadedSelectorServer(java.lang.Object, java.lang.Class, org.apache.dubbo.common.URL) throws org.apache.dubbo.rpc.RpcException
{
org.apache.thrift.server.TThreadedSelectorServer v;
org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol v;
java.lang.Runnable v, v;
org.apache.dubbo.common.URL v;
org.apache.thrift.transport.TFramedTransport$Factory v;
org.apache.thrift.transport.TNonblockingServerSocket$NonblockingAbstractServerSocketArgs v;
java.lang.Thread v;
java.util.Map v, v;
boolean v, v;
org.apache.thrift.protocol.TCompactProtocol$Factory v;
org.apache.dubbo.rpc.RpcException v, v, v;
java.net.InetSocketAddress v;
java.lang.Exception v, v;
org.apache.thrift.server.TThreadedSelectorServer$Args v, v;
java.lang.Object[] v;
org.apache.thrift.TMultiplexedProcessor v, v;
java.lang.reflect.Constructor v;
org.apache.thrift.transport.TNonblockingServerSocket v;
int v, v, 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, v;
java.lang.Class[] v;
java.lang.Class v, v;
java.lang.Object v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
v = null;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>("$Iface");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int indexOf(java.lang.String)>("$Iface");
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, 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[])>("\u0001$Processor");
label:
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String)>(v);
v = newarray (java.lang.Class)[1];
v[0] = v;
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Constructor getConstructor(java.lang.Class[])>(v);
label:
v = newarray (java.lang.Object)[1];
v[0] = v;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Object newInstance(java.lang.Object[])>(v);
v = v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: org.apache.thrift.TMultiplexedProcessor processor>;
virtualinvoke v.<org.apache.thrift.TMultiplexedProcessor: void registerProcessor(java.lang.String,org.apache.thrift.TProcessor)>(v, v);
v = <org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: java.util.Map SERVER_MAP>;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getAddress()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = new org.apache.thrift.transport.TNonblockingServerSocket$NonblockingAbstractServerSocketArgs;
specialinvoke v.<org.apache.thrift.transport.TNonblockingServerSocket$NonblockingAbstractServerSocketArgs: void <init>()>();
virtualinvoke v.<org.apache.thrift.transport.TNonblockingServerSocket$NonblockingAbstractServerSocketArgs: org.apache.thrift.transport.TServerTransport$AbstractServerTransportArgs backlog(int)>(1000);
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getHost()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String,java.lang.String)>("bind.ip", v);
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("anyhost", 0);
if v == 0 goto label;
v = "0.0.0.0";
label:
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getPort()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getParameter(java.lang.String,int)>("bind.port", v);
v = new java.net.InetSocketAddress;
specialinvoke v.<java.net.InetSocketAddress: void <init>(java.lang.String,int)>(v, v);
virtualinvoke v.<org.apache.thrift.transport.TNonblockingServerSocket$NonblockingAbstractServerSocketArgs: org.apache.thrift.transport.TServerTransport$AbstractServerTransportArgs bindAddr(java.net.InetSocketAddress)>(v);
virtualinvoke v.<org.apache.thrift.transport.TNonblockingServerSocket$NonblockingAbstractServerSocketArgs: org.apache.thrift.transport.TServerTransport$AbstractServerTransportArgs clientTimeout(int)>(10000);
v = new org.apache.thrift.transport.TNonblockingServerSocket;
specialinvoke v.<org.apache.thrift.transport.TNonblockingServerSocket: void <init>(org.apache.thrift.transport.TNonblockingServerSocket$NonblockingAbstractServerSocketArgs)>(v);
v = new org.apache.thrift.server.TThreadedSelectorServer$Args;
specialinvoke v.<org.apache.thrift.server.TThreadedSelectorServer$Args: void <init>(org.apache.thrift.transport.TNonblockingServerTransport)>(v);
v = v;
virtualinvoke v.<org.apache.thrift.server.TThreadedSelectorServer$Args: org.apache.thrift.server.TThreadedSelectorServer$Args workerThreads(int)>(200);
virtualinvoke v.<org.apache.thrift.server.TThreadedSelectorServer$Args: org.apache.thrift.server.TThreadedSelectorServer$Args selectorThreads(int)>(4);
virtualinvoke v.<org.apache.thrift.server.TThreadedSelectorServer$Args: org.apache.thrift.server.TThreadedSelectorServer$Args acceptQueueSizePerThread(int)>(256);
v = v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: org.apache.thrift.TMultiplexedProcessor processor>;
virtualinvoke v.<org.apache.thrift.server.TThreadedSelectorServer$Args: org.apache.thrift.server.TServer$AbstractServerArgs processor(org.apache.thrift.TProcessor)>(v);
v = new org.apache.thrift.transport.TFramedTransport$Factory;
specialinvoke v.<org.apache.thrift.transport.TFramedTransport$Factory: void <init>()>();
virtualinvoke v.<org.apache.thrift.server.TThreadedSelectorServer$Args: org.apache.thrift.server.TServer$AbstractServerArgs transportFactory(org.apache.thrift.transport.TTransportFactory)>(v);
v = new org.apache.thrift.protocol.TCompactProtocol$Factory;
specialinvoke v.<org.apache.thrift.protocol.TCompactProtocol$Factory: void <init>()>();
virtualinvoke v.<org.apache.thrift.server.TThreadedSelectorServer$Args: org.apache.thrift.server.TServer$AbstractServerArgs protocolFactory(org.apache.thrift.protocol.TProtocolFactory)>(v);
goto label;
label:
return null;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: 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 org.apache.dubbo.rpc.RpcException;
v = virtualinvoke v.<java.lang.Exception: 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 nativethrift server(\u) : \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: 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 org.apache.dubbo.rpc.RpcException;
v = virtualinvoke v.<java.lang.Exception: 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 nativethrift server(\u) : \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
if v != null goto label;
v = v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.dubbo.common.URL)>(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 nativethrift server(\u) due to null args");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void error(java.lang.String)>(v);
v = new org.apache.dubbo.rpc.RpcException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.dubbo.common.URL)>(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 nativethrift server(\u) due to null args");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new org.apache.thrift.server.TThreadedSelectorServer;
specialinvoke v.<org.apache.thrift.server.TThreadedSelectorServer: void <init>(org.apache.thrift.server.TThreadedSelectorServer$Args)>(v);
v = <org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: java.util.Map SERVER_MAP>;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getAddress()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = new java.lang.Thread;
v = staticinvoke <org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol$lambda_exportThreadedSelectorServer_0__422: java.lang.Runnable bootstrap$(org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol,org.apache.thrift.server.TServer)>(v, v);
specialinvoke v.<java.lang.Thread: void <init>(java.lang.Runnable)>(v);
virtualinvoke v.<java.lang.Thread: void start()>();
v = staticinvoke <org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol$lambda_exportThreadedSelectorServer_1__423: java.lang.Runnable bootstrap$(org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol,org.apache.thrift.server.TServer)>(v, v);
return v;
catch java.lang.Exception 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;
}
private java.lang.Object doReferFrameAndCompact(java.lang.Class, org.apache.dubbo.common.URL) throws org.apache.dubbo.rpc.RpcException
{
org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol v;
org.apache.thrift.transport.TFramedTransport v;
org.apache.dubbo.common.URL v;
org.apache.thrift.protocol.TCompactProtocol v;
boolean v;
org.apache.dubbo.rpc.RpcException v, v;
java.lang.Exception v, v;
java.lang.Object[] v;
java.lang.reflect.Constructor v;
int v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v;
org.apache.thrift.transport.TSocket v;
org.apache.dubbo.common.logger.Logger v, v, v;
java.lang.Class[] v;
java.lang.Class v, v;
java.lang.Object v;
org.apache.thrift.protocol.TMultiplexedProtocol v;
v := @this: org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
label:
v = null;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>("$Iface");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int indexOf(java.lang.String)>("$Iface");
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, 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[])>("\u0001$Client");
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String)>(v);
v = newarray (java.lang.Class)[1];
v[0] = class "Lorg/apache/thrift/protocol/TProtocol;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Constructor getConstructor(java.lang.Class[])>(v);
label:
v = new org.apache.thrift.transport.TSocket;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getHost()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getPort()>();
specialinvoke v.<org.apache.thrift.transport.TSocket: void <init>(java.lang.String,int)>(v, v);
v = new org.apache.thrift.transport.TFramedTransport;
specialinvoke v.<org.apache.thrift.transport.TFramedTransport: void <init>(org.apache.thrift.transport.TTransport)>(v);
v = new org.apache.thrift.protocol.TCompactProtocol;
specialinvoke v.<org.apache.thrift.protocol.TCompactProtocol: void <init>(org.apache.thrift.transport.TTransport)>(v);
v = new org.apache.thrift.protocol.TMultiplexedProtocol;
specialinvoke v.<org.apache.thrift.protocol.TMultiplexedProtocol: void <init>(org.apache.thrift.protocol.TProtocol,java.lang.String)>(v, v);
v = newarray (java.lang.Object)[1];
v[0] = v;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Object newInstance(java.lang.Object[])>(v);
virtualinvoke v.<org.apache.thrift.transport.TTransport: void open()>();
v = v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: org.apache.dubbo.common.logger.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.dubbo.common.URL)>(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[])>("nativethrift client opened for service(\u)");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: 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 org.apache.dubbo.rpc.RpcException;
v = virtualinvoke v.<java.lang.Exception: 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[])>("Fail to create remote client:\u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return v;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: 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 org.apache.dubbo.rpc.RpcException;
v = virtualinvoke v.<java.lang.Exception: 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 remote client for service(\u): \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void <clinit>()
{
java.util.HashMap v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
<org.apache.dubbo.rpc.protocol.nativethrift.ThriftProtocol: java.util.Map SERVER_MAP> = v;
return;
}
}