public class org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker extends org.apache.dubbo.rpc.protocol.AbstractInvoker
{
private final java.util.concurrent.locks.ReentrantLock destroyLock;
private final org.apache.dubbo.rpc.Invoker target;
private org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel channel;
public void <init>(java.lang.Class, org.apache.dubbo.common.URL, org.apache.dubbo.rpc.Invoker, org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel)
{
org.apache.dubbo.common.URL v;
java.util.concurrent.locks.ReentrantLock v;
org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker v;
org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel v;
java.lang.Class v;
org.apache.dubbo.rpc.Invoker v;
v := @this: org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: org.apache.dubbo.rpc.Invoker;
v := @parameter: org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel;
specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: void <init>(java.lang.Class,org.apache.dubbo.common.URL)>(v, v);
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: java.util.concurrent.locks.ReentrantLock destroyLock> = v;
v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.Invoker target> = v;
v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel channel> = v;
return;
}
protected org.apache.dubbo.rpc.Result doInvoke(org.apache.dubbo.rpc.Invocation) throws java.lang.Throwable
{
java.lang.Throwable v, v, v;
org.apache.dubbo.rpc.Invocation v;
org.apache.dubbo.rpc.Invoker v;
org.apache.dubbo.common.URL v, v;
int v, v;
org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker v;
org.apache.dubbo.rpc.RpcException v, v, v;
org.apache.dubbo.rpc.Result v;
java.lang.Class v, v;
v := @this: org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker;
v := @parameter: org.apache.dubbo.rpc.Invocation;
label:
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.Invoker target>;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invocation)>(v);
v = interfaceinvoke v.<org.apache.dubbo.rpc.Result: java.lang.Throwable getException()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: java.lang.Class getInterface()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.common.URL getUrl()>();
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.RpcException getRpcException(java.lang.Class,org.apache.dubbo.common.URL,org.apache.dubbo.rpc.Invocation,java.lang.Throwable)>(v, v, v, v);
throw v;
label:
return v;
label:
v := @caughtexception;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcException: int getCode()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcException: java.lang.Throwable getCause()>();
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: int getErrorCode(java.lang.Throwable)>(v);
virtualinvoke v.<org.apache.dubbo.rpc.RpcException: void setCode(int)>(v);
label:
throw v;
label:
v := @caughtexception;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: java.lang.Class getInterface()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.common.URL getUrl()>();
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.RpcException getRpcException(java.lang.Class,org.apache.dubbo.common.URL,org.apache.dubbo.rpc.Invocation,java.lang.Throwable)>(v, v, v, v);
throw v;
catch org.apache.dubbo.rpc.RpcException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public boolean isAvailable()
{
org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker v;
org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel v, v;
boolean v, v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: boolean isAvailable()>();
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel channel>;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel: boolean isShutdown()>();
if v != 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel channel>;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel: boolean isTerminated()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public boolean isDestroyed()
{
org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker v;
org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel v, v;
boolean v, v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: boolean isDestroyed()>();
if v != 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel channel>;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel: boolean isShutdown()>();
if v != 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel channel>;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel: boolean isTerminated()>();
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void destroy()
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantLock v, v, v, v;
org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker v;
org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel v;
boolean v, v;
v := @this: org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: boolean isDestroyed()>();
if v != 0 goto label;
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: java.util.concurrent.locks.ReentrantLock destroyLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void lock()>();
label:
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: boolean isDestroyed()>();
if v == 0 goto label;
label:
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: java.util.concurrent.locks.ReentrantLock destroyLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
return;
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: void destroy()>();
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel channel>;
virtualinvoke v.<org.apache.dubbo.rpc.protocol.grpc.ReferenceCountManagedChannel: io.grpc.ManagedChannel shutdown()>();
label:
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: java.util.concurrent.locks.ReentrantLock destroyLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: java.util.concurrent.locks.ReentrantLock destroyLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private org.apache.dubbo.rpc.RpcException getRpcException(java.lang.Class, org.apache.dubbo.common.URL, org.apache.dubbo.rpc.Invocation, java.lang.Throwable)
{
java.lang.Throwable v;
org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker v;
org.apache.dubbo.rpc.Invocation v;
org.apache.dubbo.rpc.RpcException v;
org.apache.dubbo.common.URL v;
int v;
java.lang.Class v;
java.lang.String v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v := @parameter: java.lang.Throwable;
v = new org.apache.dubbo.rpc.RpcException;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.lang.String getMethodName()>();
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Class,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[])>("Failed to invoke remote service: \u, method: \u, cause: \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker: int getErrorCode(java.lang.Throwable)>(v);
virtualinvoke v.<org.apache.dubbo.rpc.RpcException: void setCode(int)>(v);
return v;
}
private int getErrorCode(java.lang.Throwable)
{
java.lang.Throwable v;
io.grpc.Status$Code v, v;
org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker v;
io.grpc.Status v;
boolean v;
v := @this: org.apache.dubbo.rpc.protocol.grpc.GrpcInvoker;
v := @parameter: java.lang.Throwable;
v = v instanceof io.grpc.StatusException;
if v == 0 goto label;
v = virtualinvoke v.<io.grpc.StatusException: io.grpc.Status getStatus()>();
v = virtualinvoke v.<io.grpc.Status: io.grpc.Status$Code getCode()>();
v = <io.grpc.Status$Code: io.grpc.Status$Code DEADLINE_EXCEEDED>;
if v != v goto label;
return 2;
label:
return 0;
}
}