abstract class org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase extends org.apache.hc.client.http.impl.async.CloseableHttpAsyncClient
{
private static final org.slf4j.Logger LOG;
private final org.apache.hc.client.http.impl.async.AsyncPushConsumerRegistry pushConsumerRegistry;
private final org.apache.hc.core.reactor.DefaultConnectingIOReactor ioReactor;
private final java.util.concurrent.ExecutorService executorService;
private final java.util.concurrent.atomic.AtomicReference status;
void <init>(org.apache.hc.core.reactor.DefaultConnectingIOReactor, org.apache.hc.client.http.impl.async.AsyncPushConsumerRegistry, java.util.concurrent.ThreadFactory)
{
org.apache.hc.core.reactor.DefaultConnectingIOReactor v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status v;
org.apache.hc.client.http.impl.async.AsyncPushConsumerRegistry v;
java.util.concurrent.ThreadFactory v;
java.util.concurrent.atomic.AtomicReference v;
java.util.concurrent.ExecutorService v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v := @parameter: org.apache.hc.core.reactor.DefaultConnectingIOReactor;
v := @parameter: org.apache.hc.client.http.impl.async.AsyncPushConsumerRegistry;
v := @parameter: java.util.concurrent.ThreadFactory;
specialinvoke v.<org.apache.hc.client.http.impl.async.CloseableHttpAsyncClient: void <init>()>();
v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.core.reactor.DefaultConnectingIOReactor ioReactor> = v;
v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.client.http.impl.async.AsyncPushConsumerRegistry pushConsumerRegistry> = v;
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ExecutorService newSingleThreadExecutor(java.util.concurrent.ThreadFactory)>(v);
v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: java.util.concurrent.ExecutorService executorService> = v;
v = new java.util.concurrent.atomic.AtomicReference;
v = <org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status READY>;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>(java.lang.Object)>(v);
v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: java.util.concurrent.atomic.AtomicReference status> = v;
return;
}
public final void start()
{
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$1 v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status v, v;
java.util.concurrent.atomic.AtomicReference v;
java.util.concurrent.ExecutorService v;
boolean v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: java.util.concurrent.atomic.AtomicReference status>;
v = <org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status READY>;
v = <org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status RUNNING>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: boolean compareAndSet(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: java.util.concurrent.ExecutorService executorService>;
v = new org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$1;
specialinvoke v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$1: void <init>(org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase)>(v);
interfaceinvoke v.<java.util.concurrent.ExecutorService: void execute(java.lang.Runnable)>(v);
label:
return;
}
public void register(java.lang.String, java.lang.String, org.apache.hc.core.function.Supplier)
{
org.apache.hc.client.http.impl.async.AsyncPushConsumerRegistry v;
java.lang.String v, v;
org.apache.hc.core.function.Supplier v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.hc.core.function.Supplier;
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.client.http.impl.async.AsyncPushConsumerRegistry pushConsumerRegistry>;
virtualinvoke v.<org.apache.hc.client.http.impl.async.AsyncPushConsumerRegistry: void register(java.lang.String,java.lang.String,org.apache.hc.core.function.Supplier)>(v, v, v);
return;
}
boolean isRunning()
{
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status v;
java.lang.Object v;
java.util.concurrent.atomic.AtomicReference v;
boolean v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: java.util.concurrent.atomic.AtomicReference status>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = <org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase$Status RUNNING>;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
org.apache.hc.core.reactor.ConnectionInitiator getConnectionInitiator()
{
org.apache.hc.core.reactor.DefaultConnectingIOReactor v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.core.reactor.DefaultConnectingIOReactor ioReactor>;
return v;
}
public final org.apache.hc.core.reactor.IOReactorStatus getStatus()
{
org.apache.hc.core.reactor.IOReactorStatus v;
org.apache.hc.core.reactor.DefaultConnectingIOReactor v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.core.reactor.DefaultConnectingIOReactor ioReactor>;
v = virtualinvoke v.<org.apache.hc.core.reactor.DefaultConnectingIOReactor: org.apache.hc.core.reactor.IOReactorStatus getStatus()>();
return v;
}
public final void awaitShutdown(org.apache.hc.core.util.TimeValue) throws java.lang.InterruptedException
{
org.apache.hc.core.util.TimeValue v;
org.apache.hc.core.reactor.DefaultConnectingIOReactor v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v := @parameter: org.apache.hc.core.util.TimeValue;
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.core.reactor.DefaultConnectingIOReactor ioReactor>;
virtualinvoke v.<org.apache.hc.core.reactor.DefaultConnectingIOReactor: void awaitShutdown(org.apache.hc.core.util.TimeValue)>(v);
return;
}
public final void initiateShutdown()
{
org.slf4j.Logger v, v;
org.apache.hc.core.reactor.DefaultConnectingIOReactor v;
boolean v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v = <org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Initiating shutdown");
label:
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.core.reactor.DefaultConnectingIOReactor ioReactor>;
virtualinvoke v.<org.apache.hc.core.reactor.DefaultConnectingIOReactor: void initiateShutdown()>();
return;
}
void internalClose(org.apache.hc.core.io.CloseMode)
{
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
org.apache.hc.core.io.CloseMode v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v := @parameter: org.apache.hc.core.io.CloseMode;
return;
}
public final void close(org.apache.hc.core.io.CloseMode)
{
org.slf4j.Logger v, v;
org.apache.hc.core.reactor.DefaultConnectingIOReactor v, v;
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
org.apache.hc.core.io.CloseMode v;
java.util.concurrent.ExecutorService v;
boolean v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v := @parameter: org.apache.hc.core.io.CloseMode;
v = <org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Shutdown {}", v);
label:
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.core.reactor.DefaultConnectingIOReactor ioReactor>;
virtualinvoke v.<org.apache.hc.core.reactor.DefaultConnectingIOReactor: void initiateShutdown()>();
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.apache.hc.core.reactor.DefaultConnectingIOReactor ioReactor>;
virtualinvoke v.<org.apache.hc.core.reactor.DefaultConnectingIOReactor: void close(org.apache.hc.core.io.CloseMode)>(v);
v = v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: java.util.concurrent.ExecutorService executorService>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: java.util.List shutdownNow()>();
virtualinvoke v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: void internalClose(org.apache.hc.core.io.CloseMode)>(v);
return;
}
public void close()
{
org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase v;
org.apache.hc.core.io.CloseMode v;
v := @this: org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase;
v = <org.apache.hc.core.io.CloseMode: org.apache.hc.core.io.CloseMode GRACEFUL>;
virtualinvoke v.<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: void close(org.apache.hc.core.io.CloseMode)>(v);
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/hc/client5/http/impl/async/AbstractHttpAsyncClientBase;");
<org.apache.hc.client.http.impl.async.AbstractHttpAsyncClientBase: org.slf4j.Logger LOG> = v;
return;
}
}