public class org.apache.logging.log4j.core.appender.rolling.action.DeleteAction extends org.apache.logging.log4j.core.appender.rolling.action.AbstractPathAction
{
private final org.apache.logging.log4j.core.appender.rolling.action.PathSorter pathSorter;
private final boolean testMode;
private final org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition scriptCondition;
void <init>(java.lang.String, boolean, int, boolean, org.apache.logging.log4j.core.appender.rolling.action.PathSorter, org.apache.logging.log4j.core.appender.rolling.action.PathCondition[], org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition, org.apache.logging.log4j.core.lookup.StrSubstitutor)
{
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition v;
java.lang.IllegalArgumentException v;
org.apache.logging.log4j.Logger v;
org.apache.logging.log4j.core.appender.rolling.action.PathCondition[] v;
org.apache.logging.log4j.core.appender.rolling.action.PathSorter v;
int v, v;
java.lang.Object v;
java.lang.String v;
boolean v, v;
org.apache.logging.log4j.core.lookup.StrSubstitutor v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: int;
v := @parameter: boolean;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.action.PathSorter;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.action.PathCondition[];
v := @parameter: org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition;
v := @parameter: org.apache.logging.log4j.core.lookup.StrSubstitutor;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractPathAction: void <init>(java.lang.String,boolean,int,org.apache.logging.log4j.core.appender.rolling.action.PathCondition[],org.apache.logging.log4j.core.lookup.StrSubstitutor)>(v, v, v, v, v);
v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: boolean testMode> = v;
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object,java.lang.String)>(v, "sorter");
v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.core.appender.rolling.action.PathSorter pathSorter> = v;
v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition scriptCondition> = v;
if v != null goto label;
if v == null goto label;
v = lengthof v;
if v != 0 goto label;
label:
v = <org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>("Missing Delete conditions: unconditional Delete not supported");
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Unconditional Delete not supported");
throw v;
label:
return;
}
public boolean execute() throws java.io.IOException
{
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v = v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition scriptCondition>;
if v == null goto label;
v = specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: boolean executeScript()>();
goto label;
label:
v = specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractPathAction: boolean execute()>();
label:
return v;
}
private boolean executeScript() throws java.io.IOException
{
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
java.util.List v;
org.apache.logging.log4j.Logger v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v = specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: java.util.List callScript()>();
if v != null goto label;
v = <org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String)>("Script returned null list (no files to delete)");
return 1;
label:
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: void deleteSelectedFiles(java.util.List)>(v);
return 1;
}
private java.util.List callScript() throws java.io.IOException
{
java.util.List v, v;
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition v;
java.nio.file.Path v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: java.util.List getSortedPaths()>();
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: void trace(java.lang.String,java.util.List)>("Sorted paths:", v);
v = v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition scriptCondition>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: java.nio.file.Path getBasePath()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition: java.util.List selectFilesToDelete(java.nio.file.Path,java.util.List)>(v, v);
return v;
}
private void deleteSelectedFiles(java.util.List) throws java.io.IOException
{
java.util.Iterator v;
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
java.util.List v;
org.apache.logging.log4j.Logger v;
java.lang.Object v;
java.nio.file.Path v;
boolean v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v := @parameter: java.util.List;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: void trace(java.lang.String,java.util.List)>("Paths the script selected for deletion:", v);
v = interfaceinvoke v.<java.util.List: 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()>();
if v != null goto label;
v = null;
goto label;
label:
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.PathWithAttributes: java.nio.file.Path getPath()>();
label:
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: boolean isTestMode()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String,java.lang.Object)>("Deleting {} (TEST MODE: file not actually deleted)", v);
goto label;
label:
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: void delete(java.nio.file.Path)>(v);
goto label;
label:
return;
}
protected void delete(java.nio.file.Path) throws java.io.IOException
{
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
org.apache.logging.log4j.Logger v;
java.nio.file.Path v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v := @parameter: java.nio.file.Path;
v = <org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("Deleting {}", v);
staticinvoke <java.nio.file.Files: boolean deleteIfExists(java.nio.file.Path)>(v);
return;
}
public boolean execute(java.nio.file.FileVisitor) throws java.io.IOException
{
java.nio.file.FileVisitor v;
java.util.Iterator v;
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
java.io.IOException v;
java.nio.file.attribute.BasicFileAttributes v;
java.util.List v;
org.apache.logging.log4j.Logger v;
java.lang.Object v;
java.nio.file.Path v, v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v := @parameter: java.nio.file.FileVisitor;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: java.util.List getSortedPaths()>();
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: void trace(java.lang.String,java.util.List)>("Sorted paths:", v);
v = interfaceinvoke v.<java.util.List: 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()>();
label:
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.PathWithAttributes: java.nio.file.Path getPath()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.PathWithAttributes: java.nio.file.attribute.BasicFileAttributes getAttributes()>();
interfaceinvoke v.<java.nio.file.FileVisitor: java.nio.file.FileVisitResult visitFile(java.lang.Object,java.nio.file.attribute.BasicFileAttributes)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.PathWithAttributes: java.nio.file.Path getPath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("Error in post-rollover Delete when visiting {}", v, v);
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.PathWithAttributes: java.nio.file.Path getPath()>();
interfaceinvoke v.<java.nio.file.FileVisitor: java.nio.file.FileVisitResult visitFileFailed(java.lang.Object,java.io.IOException)>(v, v);
goto label;
label:
return 1;
catch java.io.IOException from label to label with label;
}
private void trace(java.lang.String, java.util.List)
{
java.util.Iterator v;
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
java.util.List v;
org.apache.logging.log4j.Logger v, v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
v = <org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.List: 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 = <org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.Object)>(v);
goto label;
label:
return;
}
java.util.List getSortedPaths() throws java.io.IOException
{
java.util.List v;
org.apache.logging.log4j.core.appender.rolling.action.SortingVisitor v;
org.apache.logging.log4j.core.appender.rolling.action.PathSorter v;
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v = new org.apache.logging.log4j.core.appender.rolling.action.SortingVisitor;
v = v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: org.apache.logging.log4j.core.appender.rolling.action.PathSorter pathSorter>;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.SortingVisitor: void <init>(org.apache.logging.log4j.core.appender.rolling.action.PathSorter)>(v);
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.AbstractPathAction: boolean execute(java.nio.file.FileVisitor)>(v);
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.SortingVisitor: java.util.List getSortedPaths()>();
return v;
}
public boolean isTestMode()
{
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v = v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: boolean testMode>;
return v;
}
protected java.nio.file.FileVisitor createFileVisitor(java.nio.file.Path, java.util.List)
{
java.util.List v;
org.apache.logging.log4j.core.appender.rolling.action.DeletingVisitor v;
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
java.nio.file.Path v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v := @parameter: java.nio.file.Path;
v := @parameter: java.util.List;
v = new org.apache.logging.log4j.core.appender.rolling.action.DeletingVisitor;
v = v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: boolean testMode>;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeletingVisitor: void <init>(java.nio.file.Path,java.util.List,boolean)>(v, v, v);
return v;
}
public static org.apache.logging.log4j.core.appender.rolling.action.DeleteAction createDeleteAction(java.lang.String, boolean, int, boolean, org.apache.logging.log4j.core.appender.rolling.action.PathSorter, org.apache.logging.log4j.core.appender.rolling.action.PathCondition[], org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition, org.apache.logging.log4j.core.config.Configuration)
{
org.apache.logging.log4j.core.appender.rolling.action.DeleteAction v;
org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition v;
org.apache.logging.log4j.core.appender.rolling.action.PathSortByModificationTime v;
org.apache.logging.log4j.core.config.Configuration v;
org.apache.logging.log4j.core.appender.rolling.action.PathCondition[] v;
org.apache.logging.log4j.core.appender.rolling.action.PathSorter v, v;
int v;
java.lang.String v;
boolean v, v;
org.apache.logging.log4j.core.lookup.StrSubstitutor v;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: int;
v := @parameter: boolean;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.action.PathSorter;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.action.PathCondition[];
v := @parameter: org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition;
v := @parameter: org.apache.logging.log4j.core.config.Configuration;
if v != null goto label;
v = new org.apache.logging.log4j.core.appender.rolling.action.PathSortByModificationTime;
v = v;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.PathSortByModificationTime: void <init>(boolean)>(1);
goto label;
label:
v = v;
label:
v = new org.apache.logging.log4j.core.appender.rolling.action.DeleteAction;
v = interfaceinvoke v.<org.apache.logging.log4j.core.config.Configuration: org.apache.logging.log4j.core.lookup.StrSubstitutor getStrSubstitutor()>();
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.DeleteAction: void <init>(java.lang.String,boolean,int,boolean,org.apache.logging.log4j.core.appender.rolling.action.PathSorter,org.apache.logging.log4j.core.appender.rolling.action.PathCondition[],org.apache.logging.log4j.core.appender.rolling.action.ScriptCondition,org.apache.logging.log4j.core.lookup.StrSubstitutor)>(v, v, v, v, v, v, v, v);
return v;
}
}