public class io.fabric.kubernetes.clnt.v.informers.cache.Controller extends java.lang.Object
{
private static final org.slf4j.Logger log;
private final long fullResyncPeriod;
private final io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO queue;
private final io.fabric.kubernetes.clnt.v.informers.ListerWatcher listerWatcher;
private io.fabric.kubernetes.clnt.v.informers.cache.Reflector reflector;
private final java.util.function.Supplier resyncFunc;
private final java.util.function.Consumer processFunc;
private final java.util.concurrent.ScheduledExecutorService reflectExecutor;
private final java.util.concurrent.ScheduledExecutorService resyncExecutor;
private java.util.concurrent.ScheduledFuture resyncFuture;
private final io.fabric.kubernetes.clnt.v.dsl.base.OperationContext operationContext;
private final java.util.concurrent.ConcurrentLinkedQueue eventListeners;
private final java.lang.Class apiTypeClass;
public void <init>(java.lang.Class, io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO, io.fabric.kubernetes.clnt.v.informers.ListerWatcher, java.util.function.Consumer, java.util.function.Supplier, long, io.fabric.kubernetes.clnt.v.dsl.base.OperationContext, java.util.concurrent.ConcurrentLinkedQueue)
{
io.fabric.kubernetes.clnt.v.informers.cache.Controller v;
long v;
io.fabric.kubernetes.clnt.v.dsl.base.OperationContext v;
java.lang.IllegalArgumentException v;
java.util.function.Supplier v;
java.util.function.Consumer v;
io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO v;
byte v;
java.util.concurrent.ScheduledExecutorService v, v;
java.lang.Class v;
io.fabric.kubernetes.clnt.v.informers.ListerWatcher v;
java.util.concurrent.ConcurrentLinkedQueue v;
v := @this: io.fabric.kubernetes.clnt.v.informers.cache.Controller;
v := @parameter: java.lang.Class;
v := @parameter: io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO;
v := @parameter: io.fabric.kubernetes.clnt.v.informers.ListerWatcher;
v := @parameter: java.util.function.Consumer;
v := @parameter: java.util.function.Supplier;
v := @parameter: long;
v := @parameter: io.fabric.kubernetes.clnt.v.dsl.base.OperationContext;
v := @parameter: java.util.concurrent.ConcurrentLinkedQueue;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO queue> = v;
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.ListerWatcher listerWatcher> = v;
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.lang.Class apiTypeClass> = v;
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.function.Consumer processFunc> = v;
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.function.Supplier resyncFunc> = v;
v = v cmp 0L;
if v >= 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Invalid resync period provided, It should be a non-negative value");
throw v;
label:
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: long fullResyncPeriod> = v;
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.dsl.base.OperationContext operationContext> = v;
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.concurrent.ConcurrentLinkedQueue eventListeners> = v;
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ScheduledExecutorService newSingleThreadScheduledExecutor()>();
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.concurrent.ScheduledExecutorService reflectExecutor> = v;
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ScheduledExecutorService newSingleThreadScheduledExecutor()>();
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.concurrent.ScheduledExecutorService resyncExecutor> = v;
specialinvoke v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: void initReflector()>();
return;
}
public void run()
{
java.util.concurrent.ScheduledFuture v;
io.fabric.kubernetes.clnt.v.informers.cache.Controller v;
io.fabric.kubernetes.clnt.v.informers.ResyncRunnable v;
long v, v, v;
java.util.function.Supplier v;
io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO v;
byte v;
java.util.concurrent.ScheduledExecutorService v;
org.slf4j.Logger v, v, v;
java.lang.Exception v;
io.fabric.kubernetes.clnt.v.informers.cache.Reflector v;
java.util.concurrent.TimeUnit v;
java.util.function.Consumer v;
java.util.concurrent.ConcurrentLinkedQueue v;
v := @this: io.fabric.kubernetes.clnt.v.informers.cache.Controller;
v = <io.fabric.kubernetes.clnt.v.informers.cache.Controller: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("informer#Controller: ready to run resync and reflector runnable");
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: long fullResyncPeriod>;
v = v cmp 0L;
if v <= 0 goto label;
v = new io.fabric.kubernetes.clnt.v.informers.ResyncRunnable;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO queue>;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.function.Supplier resyncFunc>;
specialinvoke v.<io.fabric.kubernetes.clnt.v.informers.ResyncRunnable: void <init>(io.fabric.kubernetes.clnt.v.informers.cache.Store,java.util.function.Supplier)>(v, v);
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.concurrent.ScheduledExecutorService resyncExecutor>;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: long fullResyncPeriod>;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: long fullResyncPeriod>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture scheduleAtFixedRate(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, v, v, v);
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.concurrent.ScheduledFuture resyncFuture> = v;
goto label;
label:
v = <io.fabric.kubernetes.clnt.v.informers.cache.Controller: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("informer#Controller: resync skipped due to 0 full resync period");
label:
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.Reflector reflector>;
virtualinvoke v.<io.fabric.kubernetes.clnt.v.informers.cache.Reflector: void listAndWatch()>();
specialinvoke v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: void processLoop()>();
label:
goto label;
label:
v := @caughtexception;
v = <io.fabric.kubernetes.clnt.v.informers.cache.Controller: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Reflector list-watching job exiting because the thread-pool is shutting down", v);
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.concurrent.ConcurrentLinkedQueue eventListeners>;
v = staticinvoke <io.fabric.kubernetes.clnt.v.informers.cache.Controller$lambda_run_0__101: java.util.function.Consumer bootstrap$(java.lang.Exception)>(v);
virtualinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: void forEach(java.util.function.Consumer)>(v);
label:
return;
catch java.lang.Exception from label to label with label;
}
public void stop()
{
java.lang.Throwable v;
io.fabric.kubernetes.clnt.v.informers.cache.Controller v;
java.util.concurrent.ScheduledExecutorService v;
io.fabric.kubernetes.clnt.v.informers.cache.Reflector v;
v := @this: io.fabric.kubernetes.clnt.v.informers.cache.Controller;
entermonitor v;
label:
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.Reflector reflector>;
virtualinvoke v.<io.fabric.kubernetes.clnt.v.informers.cache.Reflector: void stop()>();
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.concurrent.ScheduledExecutorService reflectExecutor>;
interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: void shutdown()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public boolean hasSynced()
{
io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO v;
io.fabric.kubernetes.clnt.v.informers.cache.Controller v;
boolean v;
v := @this: io.fabric.kubernetes.clnt.v.informers.cache.Controller;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO queue>;
v = virtualinvoke v.<io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO: boolean hasSynced()>();
return v;
}
public java.lang.String lastSyncResourceVersion()
{
io.fabric.kubernetes.clnt.v.informers.cache.Controller v;
java.lang.String v;
io.fabric.kubernetes.clnt.v.informers.cache.Reflector v, v;
v := @this: io.fabric.kubernetes.clnt.v.informers.cache.Controller;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.Reflector reflector>;
if v != null goto label;
return "";
label:
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.Reflector reflector>;
v = virtualinvoke v.<io.fabric.kubernetes.clnt.v.informers.cache.Reflector: java.lang.String getLastSyncResourceVersion()>();
return v;
}
io.fabric.kubernetes.clnt.v.informers.cache.Reflector getReflector()
{
io.fabric.kubernetes.clnt.v.informers.cache.Controller v;
io.fabric.kubernetes.clnt.v.informers.cache.Reflector v;
v := @this: io.fabric.kubernetes.clnt.v.informers.cache.Controller;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.Reflector reflector>;
return v;
}
private void processLoop() throws java.lang.Exception
{
org.slf4j.Logger v, v;
io.fabric.kubernetes.clnt.v.informers.cache.Controller v;
java.lang.Exception v;
java.util.function.Consumer v;
io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO v;
java.lang.InterruptedException v;
java.lang.Thread v, v;
java.lang.String v, v;
boolean v;
v := @this: io.fabric.kubernetes.clnt.v.informers.cache.Controller;
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: boolean isInterrupted()>();
if v != 0 goto label;
label:
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO queue>;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.util.function.Consumer processFunc>;
virtualinvoke v.<io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO: java.util.Deque pop(java.util.function.Consumer)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <io.fabric.kubernetes.clnt.v.informers.cache.Controller: org.slf4j.Logger log>;
v = virtualinvoke v.<java.lang.InterruptedException: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("DefaultController#processLoop got interrupted {}", v, v);
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
return;
label:
v := @caughtexception;
v = <io.fabric.kubernetes.clnt.v.informers.cache.Controller: org.slf4j.Logger log>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("DefaultController#processLoop recovered from crashing {} ", v, v);
throw v;
label:
return;
catch java.lang.InterruptedException from label to label with label;
catch java.lang.Exception from label to label with label;
}
private void initReflector()
{
io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO v;
io.fabric.kubernetes.clnt.v.informers.cache.Controller v;
java.lang.Class v;
long v;
io.fabric.kubernetes.clnt.v.dsl.base.OperationContext v;
io.fabric.kubernetes.clnt.v.informers.ListerWatcher v;
io.fabric.kubernetes.clnt.v.informers.cache.Reflector v;
v := @this: io.fabric.kubernetes.clnt.v.informers.cache.Controller;
v = new io.fabric.kubernetes.clnt.v.informers.cache.Reflector;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: java.lang.Class apiTypeClass>;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.ListerWatcher listerWatcher>;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.DeltaFIFO queue>;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.dsl.base.OperationContext operationContext>;
v = v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: long fullResyncPeriod>;
specialinvoke v.<io.fabric.kubernetes.clnt.v.informers.cache.Reflector: void <init>(java.lang.Class,io.fabric.kubernetes.clnt.v.informers.ListerWatcher,io.fabric.kubernetes.clnt.v.informers.cache.Store,io.fabric.kubernetes.clnt.v.dsl.base.OperationContext,long)>(v, v, v, v, v);
v.<io.fabric.kubernetes.clnt.v.informers.cache.Controller: io.fabric.kubernetes.clnt.v.informers.cache.Reflector reflector> = v;
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lio/fabric8/kubernetes/clnt/v5_1/informers/cache/Controller;");
<io.fabric.kubernetes.clnt.v.informers.cache.Controller: org.slf4j.Logger log> = v;
return;
}
}