public class org.apache.logging.log4j.core.appender.DefaultErrorHandler extends java.lang.Object implements org.apache.logging.log4j.core.ErrorHandler
{
private static final org.apache.logging.log4j.Logger LOGGER;
private static final int MAX_EXCEPTION_COUNT;
private static final long EXCEPTION_INTERVAL_NANOS;
private int exceptionCount;
private long lastExceptionInstantNanos;
private final org.apache.logging.log4j.core.Appender appender;
public void <init>(org.apache.logging.log4j.core.Appender)
{
org.apache.logging.log4j.core.Appender v;
java.lang.Object v;
long v, v, v, v;
org.apache.logging.log4j.core.appender.DefaultErrorHandler v;
v := @this: org.apache.logging.log4j.core.appender.DefaultErrorHandler;
v := @parameter: org.apache.logging.log4j.core.Appender;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: int exceptionCount> = 0;
v = staticinvoke <java.lang.System: long nanoTime()>();
v = <org.apache.logging.log4j.core.appender.DefaultErrorHandler: long EXCEPTION_INTERVAL_NANOS>;
v = v - v;
v = v - 1L;
v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: long lastExceptionInstantNanos> = v;
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object,java.lang.String)>(v, "appender");
v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: org.apache.logging.log4j.core.Appender appender> = v;
return;
}
public void error(java.lang.String)
{
org.apache.logging.log4j.Logger v;
org.apache.logging.log4j.core.appender.DefaultErrorHandler v;
java.lang.String v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.DefaultErrorHandler;
v := @parameter: java.lang.String;
v = specialinvoke v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: boolean acquirePermit()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.DefaultErrorHandler: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>(v);
label:
return;
}
public void error(java.lang.String, java.lang.Throwable)
{
java.lang.Throwable v;
org.apache.logging.log4j.core.Appender v;
org.apache.logging.log4j.core.appender.DefaultErrorHandler v;
org.apache.logging.log4j.core.appender.AppenderLoggingException v;
org.apache.logging.log4j.Logger v;
java.lang.String v;
boolean v, v, v;
v := @this: org.apache.logging.log4j.core.appender.DefaultErrorHandler;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Throwable;
v = specialinvoke v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: boolean acquirePermit()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.DefaultErrorHandler: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: org.apache.logging.log4j.core.Appender appender>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.Appender: boolean ignoreExceptions()>();
if v != 0 goto label;
if v == null goto label;
v = v instanceof org.apache.logging.log4j.core.appender.AppenderLoggingException;
if v != 0 goto label;
v = new org.apache.logging.log4j.core.appender.AppenderLoggingException;
specialinvoke v.<org.apache.logging.log4j.core.appender.AppenderLoggingException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
}
public void error(java.lang.String, org.apache.logging.log4j.core.LogEvent, java.lang.Throwable)
{
java.lang.Throwable v;
org.apache.logging.log4j.core.Appender v;
org.apache.logging.log4j.core.appender.DefaultErrorHandler v;
org.apache.logging.log4j.core.LogEvent v;
org.apache.logging.log4j.core.appender.AppenderLoggingException v;
org.apache.logging.log4j.Logger v;
java.lang.String v;
boolean v, v, v;
v := @this: org.apache.logging.log4j.core.appender.DefaultErrorHandler;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v := @parameter: java.lang.Throwable;
v = specialinvoke v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: boolean acquirePermit()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.DefaultErrorHandler: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: org.apache.logging.log4j.core.Appender appender>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.Appender: boolean ignoreExceptions()>();
if v != 0 goto label;
if v == null goto label;
v = v instanceof org.apache.logging.log4j.core.appender.AppenderLoggingException;
if v != 0 goto label;
v = new org.apache.logging.log4j.core.appender.AppenderLoggingException;
specialinvoke v.<org.apache.logging.log4j.core.appender.AppenderLoggingException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
}
private boolean acquirePermit()
{
java.lang.Throwable v;
long v, v, v, v;
org.apache.logging.log4j.core.appender.DefaultErrorHandler v;
byte v;
int v, v, v;
v := @this: org.apache.logging.log4j.core.appender.DefaultErrorHandler;
v = staticinvoke <java.lang.System: long nanoTime()>();
entermonitor v;
label:
v = v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: long lastExceptionInstantNanos>;
v = v - v;
v = <org.apache.logging.log4j.core.appender.DefaultErrorHandler: long EXCEPTION_INTERVAL_NANOS>;
v = v cmp v;
if v <= 0 goto label;
v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: long lastExceptionInstantNanos> = v;
exitmonitor v;
label:
return 1;
label:
v = v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: int exceptionCount>;
if v >= 3 goto label;
v = v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: int exceptionCount>;
v = v + 1;
v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: int exceptionCount> = v;
v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: long lastExceptionInstantNanos> = v;
exitmonitor v;
label:
return 1;
label:
exitmonitor v;
label:
return 0;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
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.Appender getAppender()
{
org.apache.logging.log4j.core.Appender v;
org.apache.logging.log4j.core.appender.DefaultErrorHandler v;
v := @this: org.apache.logging.log4j.core.appender.DefaultErrorHandler;
v = v.<org.apache.logging.log4j.core.appender.DefaultErrorHandler: org.apache.logging.log4j.core.Appender appender>;
return v;
}
static void <clinit>()
{
java.util.concurrent.TimeUnit v;
org.apache.logging.log4j.status.StatusLogger v;
long v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.core.appender.DefaultErrorHandler: org.apache.logging.log4j.Logger LOGGER> = v;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MINUTES>;
v = virtualinvoke v.<java.util.concurrent.TimeUnit: long toNanos(long)>(5L);
<org.apache.logging.log4j.core.appender.DefaultErrorHandler: long EXCEPTION_INTERVAL_NANOS> = v;
return;
}
}