public class io.fabric.kubernetes.client.dsl.internal.LogWatchCallback extends java.lang.Object implements io.fabric.kubernetes.client.dsl.LogWatch, okhttp.Callback, java.lang.AutoCloseable
{
private static final org.slf4j.Logger LOGGER;
private final io.fabric.kubernetes.client.Config config;
private final java.io.OutputStream out;
private final java.io.PipedInputStream output;
private final java.util.Set toClose;
private final java.util.concurrent.atomic.AtomicBoolean started;
private final java.util.concurrent.ArrayBlockingQueue queue;
private final java.util.concurrent.ExecutorService executorService;
private final java.util.concurrent.atomic.AtomicBoolean closed;
private io.fabric.kubernetes.client.utils.InputStreamPumper pumper;
public void <init>(java.io.OutputStream)
{
java.io.OutputStream v;
io.fabric.kubernetes.client.Config v;
io.fabric.kubernetes.client.dsl.internal.LogWatchCallback v;
v := @this: io.fabric.kubernetes.client.dsl.internal.LogWatchCallback;
v := @parameter: java.io.OutputStream;
v = new io.fabric.kubernetes.client.Config;
specialinvoke v.<io.fabric.kubernetes.client.Config: void <init>()>();
specialinvoke v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: void <init>(io.fabric.kubernetes.client.Config,java.io.OutputStream)>(v, v);
return;
}
public void <init>(io.fabric.kubernetes.client.Config, java.io.OutputStream)
{
java.util.concurrent.atomic.AtomicBoolean v, v;
java.io.PipedInputStream v, v, v, v;
java.util.LinkedHashSet v;
java.util.concurrent.ExecutorService v;
boolean v;
java.io.OutputStream v, v, v, v;
java.util.Set v, v;
java.io.IOException v;
java.io.PipedOutputStream v;
java.lang.RuntimeException v;
io.fabric.kubernetes.client.Config v;
java.util.concurrent.ArrayBlockingQueue v;
io.fabric.kubernetes.client.dsl.internal.LogWatchCallback v;
v := @this: io.fabric.kubernetes.client.dsl.internal.LogWatchCallback;
v := @parameter: io.fabric.kubernetes.client.Config;
v := @parameter: java.io.OutputStream;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.Set toClose> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.atomic.AtomicBoolean started> = v;
v = new java.util.concurrent.ArrayBlockingQueue;
specialinvoke v.<java.util.concurrent.ArrayBlockingQueue: void <init>(int)>(1);
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.ArrayBlockingQueue queue> = v;
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ExecutorService newSingleThreadExecutor()>();
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.ExecutorService executorService> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.atomic.AtomicBoolean closed> = v;
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: io.fabric.kubernetes.client.Config config> = v;
if v != null goto label;
v = new java.io.PipedOutputStream;
specialinvoke v.<java.io.PipedOutputStream: void <init>()>();
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.OutputStream out> = v;
v = new java.io.PipedInputStream;
specialinvoke v.<java.io.PipedInputStream: void <init>()>();
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.PipedInputStream output> = v;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.Set toClose>;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.OutputStream out>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.Set toClose>;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.PipedInputStream output>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.OutputStream out> = v;
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.PipedInputStream output> = null;
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.OutputStream out>;
v = v instanceof java.io.PipedOutputStream;
if v == 0 goto label;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.PipedInputStream output>;
if v == null goto label;
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.PipedInputStream output>;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.OutputStream out>;
virtualinvoke v.<java.io.PipedInputStream: void connect(java.io.PipedOutputStream)>(v);
label:
goto label;
label:
v := @caughtexception;
v = staticinvoke <io.fabric.kubernetes.client.KubernetesClientException: java.lang.RuntimeException launderThrowable(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.io.IOException from label to label with label;
}
public void close()
{
io.fabric.kubernetes.client.dsl.internal.LogWatchCallback v;
v := @this: io.fabric.kubernetes.client.dsl.internal.LogWatchCallback;
specialinvoke v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: void cleanUp()>();
return;
}
private void cleanUp()
{
java.lang.Throwable v;
io.fabric.kubernetes.client.utils.InputStreamPumper v;
java.util.Set v, v, v;
java.util.concurrent.atomic.AtomicBoolean v;
java.io.Closeable[] v;
io.fabric.kubernetes.client.dsl.internal.LogWatchCallback v;
java.util.concurrent.ExecutorService v;
boolean v;
v := @this: io.fabric.kubernetes.client.dsl.internal.LogWatchCallback;
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.atomic.AtomicBoolean closed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(0, 1);
if v != 0 goto label;
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.Set toClose>;
staticinvoke <io.fabric.kubernetes.client.utils.Utils: void closeQuietly(java.lang.Iterable)>(v);
return;
label:
v = newarray (java.io.Closeable)[1];
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: io.fabric.kubernetes.client.utils.InputStreamPumper pumper>;
v[0] = v;
staticinvoke <io.fabric.kubernetes.client.utils.Utils: void closeQuietly(java.io.Closeable[])>(v);
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.ExecutorService executorService>;
staticinvoke <io.fabric.kubernetes.client.utils.Utils: boolean shutdownExecutorService(java.util.concurrent.ExecutorService)>(v);
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.Set toClose>;
staticinvoke <io.fabric.kubernetes.client.utils.Utils: void closeQuietly(java.lang.Iterable)>(v);
goto label;
label:
v := @caughtexception;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.Set toClose>;
staticinvoke <io.fabric.kubernetes.client.utils.Utils: void closeQuietly(java.lang.Iterable)>(v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void waitUntilReady()
{
org.slf4j.Logger v, v;
java.util.concurrent.TimeUnit v;
io.fabric.kubernetes.client.Config v, v;
java.util.concurrent.ArrayBlockingQueue v;
int v, v;
io.fabric.kubernetes.client.dsl.internal.LogWatchCallback v;
java.lang.String v;
boolean v, v;
v := @this: io.fabric.kubernetes.client.dsl.internal.LogWatchCallback;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.ArrayBlockingQueue queue>;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: io.fabric.kubernetes.client.Config config>;
v = virtualinvoke v.<io.fabric.kubernetes.client.Config: int getRequestTimeout()>();
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = staticinvoke <io.fabric.kubernetes.client.utils.Utils: boolean waitUntilReady(java.util.concurrent.BlockingQueue,long,java.util.concurrent.TimeUnit)>(v, v, v);
if v != 0 goto label;
v = <io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: org.slf4j.Logger LOGGER>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: org.slf4j.Logger LOGGER>;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: io.fabric.kubernetes.client.Config config>;
v = virtualinvoke v.<io.fabric.kubernetes.client.Config: int getRequestTimeout()>();
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[])>("Log watch request has not been opened within: \u millis.");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
label:
return;
}
public java.io.InputStream getOutput()
{
io.fabric.kubernetes.client.dsl.internal.LogWatchCallback v;
java.io.PipedInputStream v;
v := @this: io.fabric.kubernetes.client.dsl.internal.LogWatchCallback;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.io.PipedInputStream output>;
return v;
}
public void onFailure(okhttp.Call, java.io.IOException)
{
org.slf4j.Logger v;
java.util.concurrent.atomic.AtomicBoolean v, v;
java.io.IOException v;
java.util.concurrent.ArrayBlockingQueue v;
okhttp.Call v;
io.fabric.kubernetes.client.dsl.internal.LogWatchCallback v;
boolean v, v;
v := @this: io.fabric.kubernetes.client.dsl.internal.LogWatchCallback;
v := @parameter: okhttp.Call;
v := @parameter: java.io.IOException;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.atomic.AtomicBoolean closed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
return;
label:
v = <io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Log Callback Failure.", v);
specialinvoke v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: void cleanUp()>();
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v != 0 goto label;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.ArrayBlockingQueue queue>;
virtualinvoke v.<java.util.concurrent.ArrayBlockingQueue: boolean add(java.lang.Object)>(v);
label:
return;
}
public void onResponse(okhttp.Call, okhttp.Response) throws java.io.IOException
{
io.fabric.kubernetes.client.Callback v;
io.fabric.kubernetes.client.utils.BlockingInputStreamPumper v;
io.fabric.kubernetes.client.utils.InputStreamPumper v;
java.util.concurrent.atomic.AtomicBoolean v;
java.lang.Runnable v;
java.util.concurrent.ArrayBlockingQueue v;
java.lang.Boolean v;
okhttp.Response v;
okhttp.Call v;
io.fabric.kubernetes.client.dsl.internal.LogWatchCallback v;
java.util.concurrent.ExecutorService v, v;
okhttp.ResponseBody v;
boolean v;
java.io.InputStream v;
v := @this: io.fabric.kubernetes.client.dsl.internal.LogWatchCallback;
v := @parameter: okhttp.Call;
v := @parameter: okhttp.Response;
v = new io.fabric.kubernetes.client.utils.BlockingInputStreamPumper;
v = virtualinvoke v.<okhttp.Response: okhttp.ResponseBody body()>();
v = virtualinvoke v.<okhttp.ResponseBody: java.io.InputStream byteStream()>();
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.LogWatchCallback$lambda_onResponse_0__43: io.fabric.kubernetes.client.Callback bootstrap$(io.fabric.kubernetes.client.dsl.internal.LogWatchCallback)>(v);
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.LogWatchCallback$lambda_onResponse_1__44: java.lang.Runnable bootstrap$(io.fabric.kubernetes.client.dsl.internal.LogWatchCallback,okhttp.Response)>(v, v);
specialinvoke v.<io.fabric.kubernetes.client.utils.BlockingInputStreamPumper: void <init>(java.io.InputStream,io.fabric.kubernetes.client.Callback,java.lang.Runnable)>(v, v, v);
v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: io.fabric.kubernetes.client.utils.InputStreamPumper pumper> = v;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.ExecutorService executorService>;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isShutdown()>();
if v != 0 goto label;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.ExecutorService executorService>;
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: io.fabric.kubernetes.client.utils.InputStreamPumper pumper>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: java.util.concurrent.Future submit(java.lang.Runnable)>(v);
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.atomic.AtomicBoolean started>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(1);
v = v.<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: java.util.concurrent.ArrayBlockingQueue queue>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(1);
virtualinvoke v.<java.util.concurrent.ArrayBlockingQueue: boolean add(java.lang.Object)>(v);
label:
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lio/fabric8/kubernetes/client/dsl/internal/LogWatchCallback;");
<io.fabric.kubernetes.client.dsl.internal.LogWatchCallback: org.slf4j.Logger LOGGER> = v;
return;
}
}