public abstract class org.apache.logging.log4j.core.appender.rolling.action.AbstractAction extends java.lang.Object implements org.apache.logging.log4j.core.appender.rolling.action.Action
{
protected static final org.apache.logging.log4j.Logger LOGGER;
private boolean complete;
private boolean interrupted;
protected void <init>()
{
org.apache.logging.log4j.core.appender.rolling.action.AbstractAction v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.AbstractAction;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean complete> = 0;
v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean interrupted> = 0;
return;
}
public abstract boolean execute() throws java.io.IOException;
public synchronized void run()
{
org.apache.logging.log4j.core.appender.rolling.action.AbstractAction v;
java.lang.Error v;
java.lang.RuntimeException v;
java.lang.Exception v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.AbstractAction;
v = v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean interrupted>;
if v != 0 goto label;
label:
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean execute()>();
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: void reportException(java.lang.Exception)>(v);
goto label;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: void reportException(java.lang.Exception)>(v);
label:
v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean complete> = 1;
v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean interrupted> = 1;
label:
return;
catch java.lang.RuntimeException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.Error from label to label with label;
}
public synchronized void close()
{
org.apache.logging.log4j.core.appender.rolling.action.AbstractAction v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.AbstractAction;
v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean interrupted> = 1;
return;
}
public boolean isComplete()
{
org.apache.logging.log4j.core.appender.rolling.action.AbstractAction v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.AbstractAction;
v = v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean complete>;
return v;
}
public boolean isInterrupted()
{
org.apache.logging.log4j.core.appender.rolling.action.AbstractAction v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.AbstractAction;
v = v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: boolean interrupted>;
return v;
}
protected void reportException(java.lang.Exception)
{
org.apache.logging.log4j.Logger v;
org.apache.logging.log4j.core.appender.rolling.action.AbstractAction v;
java.lang.Class v;
java.lang.Exception v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.AbstractAction;
v := @parameter: java.lang.Exception;
v = <org.apache.logging.log4j.core.appender.rolling.action.AbstractAction: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Exception reported by action \'{}\'", v, v);
return;
}
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.appender.rolling.action.AbstractAction: org.apache.logging.log4j.Logger LOGGER> = v;
return;
}
}