public class org.apache.log4j.NDC extends java.lang.Object
{
static java.util.Hashtable ht;
static int pushCounter;
static final int REAP_THRESHOLD;
private void <init>()
{
org.apache.log4j.NDC v;
v := @this: org.apache.log4j.NDC;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
private static java.util.Stack getCurrentStack()
{
java.lang.Thread v;
java.lang.Object v;
java.util.Hashtable v, v;
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
if v == null goto label;
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.util.Hashtable: java.lang.Object get(java.lang.Object)>(v);
return v;
label:
return null;
}
public static void clear()
{
java.util.Stack v;
v = staticinvoke <org.apache.log4j.NDC: java.util.Stack getCurrentStack()>();
if v == null goto label;
virtualinvoke v.<java.util.Stack: void setSize(int)>(0);
label:
return;
}
public static java.util.Stack cloneStack()
{
java.lang.Object v;
java.util.Stack v;
v = staticinvoke <org.apache.log4j.NDC: java.util.Stack getCurrentStack()>();
if v != null goto label;
return null;
label:
v = virtualinvoke v.<java.util.Stack: java.lang.Object clone()>();
return v;
}
public static void inherit(java.util.Stack)
{
java.util.Hashtable v;
java.util.Stack v;
java.lang.Thread v;
v := @parameter: java.util.Stack;
if v == null goto label;
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
return;
}
public static java.lang.String get()
{
java.lang.Object v;
java.lang.String v;
java.util.Stack v;
boolean v;
v = staticinvoke <org.apache.log4j.NDC: java.util.Stack getCurrentStack()>();
if v == null goto label;
v = virtualinvoke v.<java.util.Stack: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.Stack: java.lang.Object peek()>();
v = v.<org.apache.log4j.NDC$DiagnosticContext: java.lang.String fullMessage>;
return v;
label:
return null;
}
public static int getDepth()
{
int v;
java.util.Stack v;
v = staticinvoke <org.apache.log4j.NDC: java.util.Stack getCurrentStack()>();
if v != null goto label;
return 0;
label:
v = virtualinvoke v.<java.util.Stack: int size()>();
return v;
}
private static void lazyRemove()
{
java.lang.Throwable v;
java.util.Enumeration v;
java.util.Vector v;
int v, v, v, v, v, v;
java.lang.String v, v;
java.util.Hashtable v, v, v, v, v;
boolean v, v;
java.lang.Object v, v;
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
if v != null goto label;
return;
label:
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
entermonitor v;
label:
v = <org.apache.log4j.NDC: int pushCounter>;
v = v + 1;
<org.apache.log4j.NDC: int pushCounter> = v;
if v > 5 goto label;
exitmonitor v;
label:
return;
label:
<org.apache.log4j.NDC: int pushCounter> = 0;
v = 0;
v = new java.util.Vector;
specialinvoke v.<java.util.Vector: void <init>()>();
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
v = virtualinvoke v.<java.util.Hashtable: java.util.Enumeration keys()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
if v > 4 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
v = virtualinvoke v.<java.lang.Thread: boolean isAlive()>();
if v == 0 goto label;
v = v + 1;
goto label;
label:
v = 0;
virtualinvoke v.<java.util.Vector: void addElement(java.lang.Object)>(v);
goto label;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = virtualinvoke v.<java.util.Vector: int size()>();
v = 0;
label:
if v >= v goto label;
v = virtualinvoke v.<java.util.Vector: java.lang.Object elementAt(int)>(v);
v = virtualinvoke v.<java.lang.Thread: java.lang.String getName()>();
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
v = virtualinvoke v.<java.util.Hashtable: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(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[])>("Lazy NDC removal for thread [\u] (\u).");
staticinvoke <org.apache.log4j.helpers.LogLog: void debug(java.lang.String)>(v);
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
virtualinvoke v.<java.util.Hashtable: java.lang.Object remove(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public static java.lang.String pop()
{
java.lang.Object v;
java.lang.String v;
java.util.Stack v;
boolean v;
v = staticinvoke <org.apache.log4j.NDC: java.util.Stack getCurrentStack()>();
if v == null goto label;
v = virtualinvoke v.<java.util.Stack: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.Stack: java.lang.Object pop()>();
v = v.<org.apache.log4j.NDC$DiagnosticContext: java.lang.String message>;
return v;
label:
return "";
}
public static java.lang.String peek()
{
java.lang.Object v;
java.lang.String v;
java.util.Stack v;
boolean v;
v = staticinvoke <org.apache.log4j.NDC: java.util.Stack getCurrentStack()>();
if v == null goto label;
v = virtualinvoke v.<java.util.Stack: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.Stack: java.lang.Object peek()>();
v = v.<org.apache.log4j.NDC$DiagnosticContext: java.lang.String message>;
return v;
label:
return "";
}
public static void push(java.lang.String)
{
java.util.Stack v, v;
org.apache.log4j.NDC$DiagnosticContext v, v, v;
java.lang.Thread v;
java.lang.Object v;
java.lang.String v;
java.util.Hashtable v;
boolean v;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.log4j.NDC: java.util.Stack getCurrentStack()>();
if v != null goto label;
v = new org.apache.log4j.NDC$DiagnosticContext;
specialinvoke v.<org.apache.log4j.NDC$DiagnosticContext: void <init>(java.lang.String,org.apache.log4j.NDC$DiagnosticContext)>(v, null);
v = new java.util.Stack;
specialinvoke v.<java.util.Stack: void <init>()>();
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
virtualinvoke v.<java.util.Stack: java.lang.Object push(java.lang.Object)>(v);
goto label;
label:
v = virtualinvoke v.<java.util.Stack: boolean isEmpty()>();
if v == 0 goto label;
v = new org.apache.log4j.NDC$DiagnosticContext;
specialinvoke v.<org.apache.log4j.NDC$DiagnosticContext: void <init>(java.lang.String,org.apache.log4j.NDC$DiagnosticContext)>(v, null);
virtualinvoke v.<java.util.Stack: java.lang.Object push(java.lang.Object)>(v);
goto label;
label:
v = virtualinvoke v.<java.util.Stack: java.lang.Object peek()>();
v = new org.apache.log4j.NDC$DiagnosticContext;
specialinvoke v.<org.apache.log4j.NDC$DiagnosticContext: void <init>(java.lang.String,org.apache.log4j.NDC$DiagnosticContext)>(v, v);
virtualinvoke v.<java.util.Stack: java.lang.Object push(java.lang.Object)>(v);
label:
return;
}
public static void remove()
{
java.util.Hashtable v, v;
java.lang.Thread v;
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
if v == null goto label;
v = <org.apache.log4j.NDC: java.util.Hashtable ht>;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.util.Hashtable: java.lang.Object remove(java.lang.Object)>(v);
staticinvoke <org.apache.log4j.NDC: void lazyRemove()>();
label:
return;
}
public static void setMaxDepth(int)
{
int v, v;
java.util.Stack v;
v := @parameter: int;
v = staticinvoke <org.apache.log4j.NDC: java.util.Stack getCurrentStack()>();
if v == null goto label;
v = virtualinvoke v.<java.util.Stack: int size()>();
if v >= v goto label;
virtualinvoke v.<java.util.Stack: void setSize(int)>(v);
label:
return;
}
static void <clinit>()
{
java.util.Hashtable v;
v = new java.util.Hashtable;
specialinvoke v.<java.util.Hashtable: void <init>()>();
<org.apache.log4j.NDC: java.util.Hashtable ht> = v;
<org.apache.log4j.NDC: int pushCounter> = 0;
return;
}
}