public class org.apache.logging.log4j.core.impl.ReusableLogEventFactory extends java.lang.Object implements org.apache.logging.log4j.core.impl.LogEventFactory, org.apache.logging.log4j.core.impl.LocationAwareLogEventFactory
{
private static final org.apache.logging.log4j.core.async.ThreadNameCachingStrategy THREAD_NAME_CACHING_STRATEGY;
private static final org.apache.logging.log4j.core.util.Clock CLOCK;
private static final java.lang.ThreadLocal mutableLogEventThreadLocal;
private final org.apache.logging.log4j.core.ContextDataInjector injector;
public void <init>()
{
org.apache.logging.log4j.core.ContextDataInjector v;
org.apache.logging.log4j.core.impl.ReusableLogEventFactory v;
v := @this: org.apache.logging.log4j.core.impl.ReusableLogEventFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <org.apache.logging.log4j.core.impl.ContextDataInjectorFactory: org.apache.logging.log4j.core.ContextDataInjector createInjector()>();
v.<org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.ContextDataInjector injector> = v;
return;
}
public org.apache.logging.log4j.core.LogEvent createEvent(java.lang.String, org.apache.logging.log4j.Marker, java.lang.String, org.apache.logging.log4j.Level, org.apache.logging.log4j.message.Message, java.util.List, java.lang.Throwable)
{
java.lang.Throwable v;
org.apache.logging.log4j.Level v;
org.apache.logging.log4j.core.LogEvent v;
java.util.List v;
org.apache.logging.log4j.message.Message v;
org.apache.logging.log4j.core.impl.ReusableLogEventFactory v;
java.lang.String v, v;
org.apache.logging.log4j.Marker v;
v := @this: org.apache.logging.log4j.core.impl.ReusableLogEventFactory;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.Marker;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.Level;
v := @parameter: org.apache.logging.log4j.message.Message;
v := @parameter: java.util.List;
v := @parameter: java.lang.Throwable;
v = virtualinvoke v.<org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.LogEvent createEvent(java.lang.String,org.apache.logging.log4j.Marker,java.lang.String,java.lang.StackTraceElement,org.apache.logging.log4j.Level,org.apache.logging.log4j.message.Message,java.util.List,java.lang.Throwable)>(v, v, v, null, v, v, v, v);
return v;
}
public org.apache.logging.log4j.core.LogEvent createEvent(java.lang.String, org.apache.logging.log4j.Marker, java.lang.String, java.lang.StackTraceElement, org.apache.logging.log4j.Level, org.apache.logging.log4j.message.Message, java.util.List, java.lang.Throwable)
{
java.lang.Throwable v;
org.apache.logging.log4j.Level v, v;
org.apache.logging.log4j.message.Message v;
org.apache.logging.log4j.core.util.Clock v;
org.apache.logging.log4j.core.impl.ReusableLogEventFactory v;
java.lang.Thread v, v;
int v, v;
org.apache.logging.log4j.core.util.NanoClock v;
org.apache.logging.log4j.util.StringMap v;
java.lang.StackTraceElement v;
java.lang.String v, v, v;
org.apache.logging.log4j.Marker v;
org.apache.logging.log4j.core.ContextDataInjector v;
org.apache.logging.log4j.core.async.ThreadNameCachingStrategy v, v;
org.apache.logging.log4j.util.ReadOnlyStringMap v;
java.util.List v;
org.apache.logging.log4j.ThreadContext$ContextStack v;
org.apache.logging.log4j.core.impl.MutableLogEvent v;
v := @this: org.apache.logging.log4j.core.impl.ReusableLogEventFactory;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.Marker;
v := @parameter: java.lang.String;
v := @parameter: java.lang.StackTraceElement;
v := @parameter: org.apache.logging.log4j.Level;
v := @parameter: org.apache.logging.log4j.message.Message;
v := @parameter: java.util.List;
v := @parameter: java.lang.Throwable;
v = staticinvoke <org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.impl.MutableLogEvent getOrCreateMutableLogEvent()>();
v.<org.apache.logging.log4j.core.impl.MutableLogEvent: boolean reserved> = 1;
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setLoggerName(java.lang.String)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setMarker(org.apache.logging.log4j.Marker)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setLoggerFqcn(java.lang.String)>(v);
if v != null goto label;
v = <org.apache.logging.log4j.Level: org.apache.logging.log4j.Level OFF>;
goto label;
label:
v = v;
label:
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setLevel(org.apache.logging.log4j.Level)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setMessage(org.apache.logging.log4j.message.Message)>(v);
v = <org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.util.Clock CLOCK>;
v = staticinvoke <org.apache.logging.log4j.core.impl.Log4jLogEvent: org.apache.logging.log4j.core.util.NanoClock getNanoClock()>();
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void initTime(org.apache.logging.log4j.core.util.Clock,org.apache.logging.log4j.core.util.NanoClock)>(v, v);
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setThrown(java.lang.Throwable)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setSource(java.lang.StackTraceElement)>(v);
v = v.<org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.ContextDataInjector injector>;
v = virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: org.apache.logging.log4j.util.ReadOnlyStringMap getContextData()>();
v = interfaceinvoke v.<org.apache.logging.log4j.core.ContextDataInjector: org.apache.logging.log4j.util.StringMap injectContextData(java.util.List,org.apache.logging.log4j.util.StringMap)>(v, v);
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setContextData(org.apache.logging.log4j.util.StringMap)>(v);
v = staticinvoke <org.apache.logging.log4j.ThreadContext: int getDepth()>();
if v != 0 goto label;
v = <org.apache.logging.log4j.ThreadContext: org.apache.logging.log4j.spi.ThreadContextStack EMPTY_STACK>;
goto label;
label:
v = staticinvoke <org.apache.logging.log4j.ThreadContext: org.apache.logging.log4j.ThreadContext$ContextStack cloneStack()>();
label:
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setContextStack(org.apache.logging.log4j.ThreadContext$ContextStack)>(v);
v = <org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.async.ThreadNameCachingStrategy THREAD_NAME_CACHING_STRATEGY>;
v = <org.apache.logging.log4j.core.async.ThreadNameCachingStrategy: org.apache.logging.log4j.core.async.ThreadNameCachingStrategy UNCACHED>;
if v != v goto label;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.String getName()>();
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setThreadName(java.lang.String)>(v);
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: int getPriority()>();
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setThreadPriority(int)>(v);
label:
return v;
}
private static org.apache.logging.log4j.core.impl.MutableLogEvent getOrCreateMutableLogEvent()
{
java.lang.ThreadLocal v;
java.lang.Object v;
org.apache.logging.log4j.core.impl.MutableLogEvent v;
boolean v;
v = <org.apache.logging.log4j.core.impl.ReusableLogEventFactory: java.lang.ThreadLocal mutableLogEventThreadLocal>;
v = virtualinvoke v.<java.lang.ThreadLocal: java.lang.Object get()>();
if v == null goto label;
v = v.<org.apache.logging.log4j.core.impl.MutableLogEvent: boolean reserved>;
if v == 0 goto label;
label:
v = staticinvoke <org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.impl.MutableLogEvent createInstance(org.apache.logging.log4j.core.impl.MutableLogEvent)>(v);
goto label;
label:
v = v;
label:
return v;
}
private static org.apache.logging.log4j.core.impl.MutableLogEvent createInstance(org.apache.logging.log4j.core.impl.MutableLogEvent)
{
java.lang.ThreadLocal v;
long v;
java.lang.Thread v, v, v;
int v;
java.lang.String v;
org.apache.logging.log4j.core.impl.MutableLogEvent v, v;
v := @parameter: org.apache.logging.log4j.core.impl.MutableLogEvent;
v = new org.apache.logging.log4j.core.impl.MutableLogEvent;
specialinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void <init>()>();
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: long getId()>();
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setThreadId(long)>(v);
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.String getName()>();
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setThreadName(java.lang.String)>(v);
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: int getPriority()>();
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void setThreadPriority(int)>(v);
if v != null goto label;
v = <org.apache.logging.log4j.core.impl.ReusableLogEventFactory: java.lang.ThreadLocal mutableLogEventThreadLocal>;
virtualinvoke v.<java.lang.ThreadLocal: void set(java.lang.Object)>(v);
label:
return v;
}
public static void release(org.apache.logging.log4j.core.LogEvent)
{
org.apache.logging.log4j.core.LogEvent v;
boolean v;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = v instanceof org.apache.logging.log4j.core.impl.MutableLogEvent;
if v == 0 goto label;
virtualinvoke v.<org.apache.logging.log4j.core.impl.MutableLogEvent: void clear()>();
v.<org.apache.logging.log4j.core.impl.MutableLogEvent: boolean reserved> = 0;
label:
return;
}
static void <clinit>()
{
org.apache.logging.log4j.core.async.ThreadNameCachingStrategy v;
java.lang.ThreadLocal v;
org.apache.logging.log4j.core.util.Clock v;
v = staticinvoke <org.apache.logging.log4j.core.async.ThreadNameCachingStrategy: org.apache.logging.log4j.core.async.ThreadNameCachingStrategy create()>();
<org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.async.ThreadNameCachingStrategy THREAD_NAME_CACHING_STRATEGY> = v;
v = staticinvoke <org.apache.logging.log4j.core.util.ClockFactory: org.apache.logging.log4j.core.util.Clock getClock()>();
<org.apache.logging.log4j.core.impl.ReusableLogEventFactory: org.apache.logging.log4j.core.util.Clock CLOCK> = v;
v = new java.lang.ThreadLocal;
specialinvoke v.<java.lang.ThreadLocal: void <init>()>();
<org.apache.logging.log4j.core.impl.ReusableLogEventFactory: java.lang.ThreadLocal mutableLogEventThreadLocal> = v;
return;
}
}