public class org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry extends java.lang.Object implements org.apache.logging.log4j.core.util.ShutdownCallbackRegistry, org.apache.logging.log4j.core.LifeCycle, java.lang.Runnable
{
protected static final org.apache.logging.log4j.Logger LOGGER;
private final java.util.concurrent.atomic.AtomicReference state;
private final java.util.concurrent.ThreadFactory threadFactory;
private final java.util.Collection hooks;
private java.lang.ref.Reference shutdownHookRef;
public void <init>()
{
java.util.concurrent.ThreadFactory v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ThreadFactory defaultThreadFactory()>();
specialinvoke v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: void <init>(java.util.concurrent.ThreadFactory)>(v);
return;
}
protected void <init>(java.util.concurrent.ThreadFactory)
{
java.util.concurrent.ThreadFactory v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
java.util.concurrent.CopyOnWriteArrayList v;
org.apache.logging.log4j.core.LifeCycle$State v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v := @parameter: java.util.concurrent.ThreadFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.atomic.AtomicReference;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State INITIALIZED>;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>(java.lang.Object)>(v);
v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state> = v;
v = new java.util.concurrent.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.Collection hooks> = v;
v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.ThreadFactory threadFactory> = v;
return;
}
public void run()
{
java.lang.Throwable v, v;
java.util.concurrent.atomic.AtomicReference v, v;
java.lang.String v;
org.apache.logging.log4j.Marker v;
boolean v, v;
java.io.PrintStream v;
java.util.Iterator v;
java.util.Collection v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
org.apache.logging.log4j.core.LifeCycle$State v, v, v;
org.apache.logging.log4j.Logger v;
java.lang.Class v, v;
java.lang.Object v, v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STARTED>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STOPPING>;
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.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.Collection hooks>;
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.ref.Reference: java.lang.Object get()>();
if v == null goto label;
label:
interfaceinvoke v.<org.apache.logging.log4j.core.util.Cancellable: void run()>();
label:
goto label;
label:
v := @caughtexception;
label:
v = <org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: org.apache.logging.log4j.Logger LOGGER>;
v = <org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: org.apache.logging.log4j.Marker SHUTDOWN_HOOK_MARKER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(org.apache.logging.log4j.Marker,java.lang.String,java.lang.Object,java.lang.Object)>(v, "Caught exception executing shutdown hook {}", v, v);
label:
goto label;
label:
v := @caughtexception;
v = <java.lang.System: java.io.PrintStream err>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Class,java.lang.Class)>(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[])>("Caught exception \u logging exception \u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
virtualinvoke v.<java.lang.Throwable: void printStackTrace()>();
goto label;
label:
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STOPPED>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public org.apache.logging.log4j.core.util.Cancellable addShutdownCallback(java.lang.Runnable)
{
java.lang.IllegalStateException v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry$RegisteredCancellable v;
java.util.Collection v, v;
java.lang.Runnable v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
java.lang.Object v;
java.lang.String v, v;
java.lang.ref.SoftReference v;
boolean v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v := @parameter: java.lang.Runnable;
v = virtualinvoke v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: boolean isStarted()>();
if v == 0 goto label;
v = new org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry$RegisteredCancellable;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.Collection hooks>;
specialinvoke v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry$RegisteredCancellable: void <init>(java.lang.Runnable,java.util.Collection)>(v, v);
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.Collection hooks>;
v = new java.lang.ref.SoftReference;
specialinvoke v.<java.lang.ref.SoftReference: void <init>(java.lang.Object)>(v);
interfaceinvoke v.<java.util.Collection: boolean add(java.lang.Object)>(v);
return v;
label:
v = new java.lang.IllegalStateException;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.LifeCycle$State: java.lang.String name()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("Cannot add new shutdown hook as this is not started. Current state: \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
}
public void initialize()
{
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
return;
}
public void start()
{
java.lang.IllegalStateException v;
java.util.concurrent.atomic.AtomicReference v, v, v, v;
java.lang.Thread v;
java.util.concurrent.ThreadFactory v;
boolean v;
java.lang.Exception v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
org.apache.logging.log4j.core.LifeCycle$State v, v, v, v, v;
org.apache.logging.log4j.Logger v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State INITIALIZED>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STARTING>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: boolean compareAndSet(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
label:
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.ThreadFactory threadFactory>;
v = interfaceinvoke v.<java.util.concurrent.ThreadFactory: java.lang.Thread newThread(java.lang.Runnable)>(v);
specialinvoke v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: void addShutdownHook(java.lang.Thread)>(v);
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STARTED>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STOPPED>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
throw v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void catching(java.lang.Throwable)>(v);
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STOPPED>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
label:
return;
catch java.lang.IllegalStateException from label to label with label;
catch java.lang.Exception from label to label with label;
}
private void addShutdownHook(java.lang.Thread)
{
java.lang.Runtime v;
java.lang.Thread v;
java.lang.ref.WeakReference v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v := @parameter: java.lang.Thread;
v = new java.lang.ref.WeakReference;
specialinvoke v.<java.lang.ref.WeakReference: void <init>(java.lang.Object)>(v);
v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.lang.ref.Reference shutdownHookRef> = v;
v = staticinvoke <java.lang.Runtime: java.lang.Runtime getRuntime()>();
virtualinvoke v.<java.lang.Runtime: void addShutdownHook(java.lang.Thread)>(v);
return;
}
public void stop()
{
java.util.concurrent.TimeUnit v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v = <org.apache.logging.log4j.core.AbstractLifeCycle: java.util.concurrent.TimeUnit DEFAULT_STOP_TIMEUNIT>;
virtualinvoke v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: boolean stop(long,java.util.concurrent.TimeUnit)>(0L, v);
return;
}
public boolean stop(long, java.util.concurrent.TimeUnit)
{
java.lang.Throwable v;
long v;
java.util.concurrent.atomic.AtomicReference v, v, v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
org.apache.logging.log4j.core.LifeCycle$State v, v, v, v;
java.util.concurrent.TimeUnit v;
boolean v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STARTED>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STOPPING>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: boolean compareAndSet(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
label:
specialinvoke v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: void removeShutdownHook()>();
label:
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STOPPED>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
goto label;
label:
v := @caughtexception;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STOPPED>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
throw v;
label:
return 1;
catch java.lang.Throwable from label to label with label;
}
private void removeShutdownHook()
{
java.lang.ref.Reference v, v;
java.lang.Runtime v;
java.lang.Object v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.lang.ref.Reference shutdownHookRef>;
v = virtualinvoke v.<java.lang.ref.Reference: java.lang.Object get()>();
if v == null goto label;
v = staticinvoke <java.lang.Runtime: java.lang.Runtime getRuntime()>();
virtualinvoke v.<java.lang.Runtime: boolean removeShutdownHook(java.lang.Thread)>(v);
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.lang.ref.Reference shutdownHookRef>;
virtualinvoke v.<java.lang.ref.Reference: boolean enqueue()>();
label:
return;
}
public org.apache.logging.log4j.core.LifeCycle$State getState()
{
java.lang.Object v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
return v;
}
public boolean isStarted()
{
java.lang.Object v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
boolean v;
org.apache.logging.log4j.core.LifeCycle$State v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STARTED>;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public boolean isStopped()
{
java.lang.Object v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry v;
boolean v;
org.apache.logging.log4j.core.LifeCycle$State v;
v := @this: org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry;
v = v.<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: java.util.concurrent.atomic.AtomicReference state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = <org.apache.logging.log4j.core.LifeCycle$State: org.apache.logging.log4j.core.LifeCycle$State STOPPED>;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
static void <clinit>()
{
org.apache.logging.log4j.status.StatusLogger v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.core.util.DefaultShutdownCallbackRegistry: org.apache.logging.log4j.Logger LOGGER> = v;
return;
}
}