public abstract class io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager extends java.lang.Object implements io.fabric.kubernetes.client.Watch
{
private static final org.slf4j.Logger logger;
final io.fabric.kubernetes.client.Watcher watcher;
final java.util.concurrent.atomic.AtomicReference resourceVersion;
final java.util.concurrent.atomic.AtomicBoolean forceClosed;
private final int reconnectLimit;
private final int reconnectInterval;
private final int maxIntervalExponent;
final java.util.concurrent.atomic.AtomicInteger currentReconnectAttempt;
private final java.util.concurrent.ScheduledExecutorService executorService;
private final io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$RequestBuilder requestBuilder;
protected io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner runner;
void <init>(io.fabric.kubernetes.client.Watcher, io.fabric.kubernetes.api.model.ListOptions, int, int, int, io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$RequestBuilder)
{
io.fabric.kubernetes.api.model.ListOptions v;
io.fabric.kubernetes.client.Watcher v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.util.concurrent.atomic.AtomicBoolean v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$RequestBuilder v;
java.util.concurrent.atomic.AtomicReference v;
java.util.concurrent.atomic.AtomicInteger v;
int v, v, v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
java.util.concurrent.ThreadFactory v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v := @parameter: io.fabric.kubernetes.client.Watcher;
v := @parameter: io.fabric.kubernetes.api.model.ListOptions;
v := @parameter: int;
v := @parameter: int;
v := @parameter: int;
v := @parameter: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$RequestBuilder;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.Watcher watcher> = v;
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: int reconnectLimit> = v;
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: int reconnectInterval> = v;
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: int maxIntervalExponent> = v;
v = new java.util.concurrent.atomic.AtomicReference;
v = virtualinvoke v.<io.fabric.kubernetes.api.model.ListOptions: java.lang.String getResourceVersion()>();
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>(java.lang.Object)>(v);
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicReference resourceVersion> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicInteger currentReconnectAttempt> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>()>();
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicBoolean forceClosed> = v;
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$lambda_new_0__41: java.util.concurrent.ThreadFactory bootstrap$(io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager)>(v);
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ScheduledExecutorService newSingleThreadScheduledExecutor(java.util.concurrent.ThreadFactory)>(v);
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService> = v;
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$RequestBuilder requestBuilder> = v;
return;
}
protected void initRunner(io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner)
{
java.lang.IllegalStateException v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner v, v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v := @parameter: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner runner>;
if v == null goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("ClientRunner has already been initialized");
throw v;
label:
v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner runner> = v;
return;
}
final void closeEvent(io.fabric.kubernetes.client.WatcherException)
{
io.fabric.kubernetes.client.WatcherException v;
org.slf4j.Logger v;
io.fabric.kubernetes.client.Watcher v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.util.concurrent.atomic.AtomicBoolean v;
boolean v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v := @parameter: io.fabric.kubernetes.client.WatcherException;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicBoolean forceClosed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean getAndSet(boolean)>(1);
if v == 0 goto label;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Ignoring duplicate firing of onClose event");
return;
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.Watcher watcher>;
interfaceinvoke v.<io.fabric.kubernetes.client.Watcher: void onClose(io.fabric.kubernetes.client.WatcherException)>(v);
return;
}
final void closeEvent()
{
org.slf4j.Logger v;
io.fabric.kubernetes.client.Watcher v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.util.concurrent.atomic.AtomicBoolean v;
boolean v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicBoolean forceClosed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean getAndSet(boolean)>(1);
if v == 0 goto label;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Ignoring duplicate firing of onClose event");
return;
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.Watcher watcher>;
interfaceinvoke v.<io.fabric.kubernetes.client.Watcher: void onClose()>();
return;
}
final void closeExecutorService()
{
org.slf4j.Logger v, v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.lang.RuntimeException v;
java.lang.Exception v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.ScheduledExecutorService v, v, v, v, v;
boolean v, v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
if v == null goto label;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: boolean isShutdown()>();
if v != 0 goto label;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Closing ExecutorService");
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: void shutdown()>();
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: boolean awaitTermination(long,java.util.concurrent.TimeUnit)>(1L, v);
if v != 0 goto label;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>("Executor didn\'t terminate in time after shutdown in close(), killing it.");
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.List shutdownNow()>();
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.lang.Exception from label to label with label;
}
void submit(java.lang.Runnable)
{
java.util.concurrent.ScheduledExecutorService v, v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.lang.Runnable v;
boolean v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v := @parameter: java.lang.Runnable;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: boolean isShutdown()>();
if v != 0 goto label;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.Future submit(java.lang.Runnable)>(v);
label:
return;
}
void schedule(java.lang.Runnable, long, java.util.concurrent.TimeUnit)
{
java.util.concurrent.TimeUnit v;
java.util.concurrent.ScheduledExecutorService v, v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
long v;
java.lang.Runnable v;
boolean v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v := @parameter: java.lang.Runnable;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: boolean isShutdown()>();
if v != 0 goto label;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.ScheduledExecutorService executorService>;
interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture schedule(java.lang.Runnable,long,java.util.concurrent.TimeUnit)>(v, v, v);
label:
return;
}
final boolean cannotReconnect()
{
java.util.concurrent.atomic.AtomicInteger v;
int v, v, v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
boolean v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicInteger currentReconnectAttempt>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: int reconnectLimit>;
if v < v goto label;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: int reconnectLimit>;
if v < 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
final long nextReconnectInterval()
{
org.slf4j.Logger v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
long v;
java.lang.Integer v;
java.lang.Long v;
java.util.concurrent.atomic.AtomicInteger v;
int v, v, v, v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicInteger currentReconnectAttempt>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int getAndIncrement()>();
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: int maxIntervalExponent>;
if v <= v goto label;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: int maxIntervalExponent>;
label:
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: int reconnectInterval>;
v = 1 << v;
v = v * v;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Current reconnect backoff is {} milliseconds (T{})", v, v);
return v;
}
void resetReconnectAttempts()
{
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicInteger currentReconnectAttempt>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
return;
}
boolean isForceClosed()
{
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.util.concurrent.atomic.AtomicBoolean v;
boolean v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicBoolean forceClosed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
return v;
}
void eventReceived(io.fabric.kubernetes.client.Watcher$Action, java.lang.Object)
{
io.fabric.kubernetes.client.Watcher$Action v;
io.fabric.kubernetes.client.Watcher v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.lang.Object v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v := @parameter: io.fabric.kubernetes.client.Watcher$Action;
v := @parameter: java.lang.Object;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.Watcher watcher>;
interfaceinvoke v.<io.fabric.kubernetes.client.Watcher: void eventReceived(io.fabric.kubernetes.client.Watcher$Action,java.lang.Object)>(v, v);
return;
}
void onClose(io.fabric.kubernetes.client.WatcherException)
{
io.fabric.kubernetes.client.Watcher v;
io.fabric.kubernetes.client.WatcherException v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v := @parameter: io.fabric.kubernetes.client.WatcherException;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.Watcher watcher>;
interfaceinvoke v.<io.fabric.kubernetes.client.Watcher: void onClose(io.fabric.kubernetes.client.WatcherException)>(v);
return;
}
void updateResourceVersion(java.lang.String)
{
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
java.lang.String v;
java.util.concurrent.atomic.AtomicReference v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v := @parameter: java.lang.String;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicReference resourceVersion>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
return;
}
protected void runWatch()
{
okhttp.Request v;
org.slf4j.Logger v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$RequestBuilder v;
java.util.concurrent.atomic.AtomicReference v;
java.lang.Object v;
okhttp.HttpUrl v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$RequestBuilder requestBuilder>;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: java.util.concurrent.atomic.AtomicReference resourceVersion>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = interfaceinvoke v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$RequestBuilder: okhttp.Request build(java.lang.String)>(v);
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
v = virtualinvoke v.<okhttp.Request: okhttp.HttpUrl url()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Watching {}...", v);
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner runner>;
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner: void run(okhttp.Request)>(v);
return;
}
public void waitUntilReady()
{
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner runner>;
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner: void waitUntilReady()>();
return;
}
static void closeWebSocket(okhttp.WebSocket)
{
java.lang.IllegalStateException v;
org.slf4j.Logger v, v, v;
okhttp.WebSocket v;
java.lang.Class v;
java.lang.String v;
boolean v;
v := @parameter: okhttp.WebSocket;
if v == null goto label;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Closing websocket {}", v);
label:
v = interfaceinvoke v.<okhttp.WebSocket: boolean close(int,java.lang.String)>(1000, null);
if v != 0 goto label;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>("Failed to close websocket");
label:
goto label;
label:
v := @caughtexception;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.IllegalStateException: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("Called close on already closed websocket: {} {}", v, v);
label:
return;
catch java.lang.IllegalStateException from label to label with label;
}
public void close()
{
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager v;
org.slf4j.Logger v;
io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner v;
v := @this: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager;
v = <io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Force closing the watch {}", v);
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: void closeEvent()>();
v = v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner runner>;
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager$ClientRunner: void close()>();
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: void closeExecutorService()>();
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/AbstractWatchManager;");
<io.fabric.kubernetes.client.dsl.internal.AbstractWatchManager: org.slf4j.Logger logger> = v;
return;
}
}