class org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$RollingRandomAccessFileManagerFactory extends java.lang.Object implements org.apache.logging.log4j.core.appender.ManagerFactory
{
private void <init>()
{
org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$RollingRandomAccessFileManagerFactory v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$RollingRandomAccessFileManagerFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager createManager(java.lang.String, org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData)
{
java.io.RandomAccessFile v, v;
org.apache.logging.log4j.core.LoggerContext v;
org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData v;
java.lang.Long v;
java.nio.file.Path v;
boolean v, v, v, v, v, v, v, v, v, v;
org.apache.logging.log4j.Logger v, v, v;
org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager v;
org.apache.logging.log4j.core.Layout v;
long v, v, v, v;
org.apache.logging.log4j.core.util.NullOutputStream v;
org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$RollingRandomAccessFileManagerFactory v;
int v;
java.lang.String v, v, v, v, v, v, v, v;
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
java.io.IOException v;
java.io.File v, v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$RollingRandomAccessFileManagerFactory;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData;
v = null;
v = 0L;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = null;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: java.lang.String fileName>;
if v == null goto label;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = v;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: boolean append>;
if v != 0 goto label;
virtualinvoke v.<java.io.File: boolean delete()>();
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: boolean append>;
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: long length()>();
goto label;
label:
v = 0L;
label:
v = v;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: long lastModified()>();
label:
staticinvoke <org.apache.logging.log4j.core.util.FileUtils: void makeParentDirs(java.io.File)>(v);
v = new java.io.RandomAccessFile;
specialinvoke v.<java.io.RandomAccessFile: void <init>(java.lang.String,java.lang.String)>(v, "rw");
v = v;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: boolean append>;
if v == 0 goto label;
v = virtualinvoke v.<java.io.RandomAccessFile: long length()>();
v = <org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("RandomAccessFile {} seek to {}", v, v);
virtualinvoke v.<java.io.RandomAccessFile: void seek(long)>(v);
goto label;
label:
v = <org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("RandomAccessFile {} set length to 0", v);
virtualinvoke v.<java.io.RandomAccessFile: void setLength(long)>(0L);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.IOException)>(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[])>("Cannot access RandomAccessFile \u0001");
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
return null;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: boolean append>;
if v == 0 goto label;
if v == null goto label;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
v = new org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: org.apache.logging.log4j.core.LoggerContext getLoggerContext()>();
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: java.lang.String pattern>;
v = staticinvoke <org.apache.logging.log4j.core.util.NullOutputStream: org.apache.logging.log4j.core.util.NullOutputStream getInstance()>();
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: boolean append>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: boolean immediateFlush>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: int bufferSize>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy policy>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy strategy>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: java.lang.String advertiseURI>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: org.apache.logging.log4j.core.Layout layout>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: java.lang.String filePermissions>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: java.lang.String fileOwner>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager$FactoryData: java.lang.String fileGroup>;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager: void <init>(org.apache.logging.log4j.core.LoggerContext,java.io.RandomAccessFile,java.lang.String,java.lang.String,java.io.OutputStream,boolean,boolean,int,long,long,org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy,org.apache.logging.log4j.core.appender.rolling.RolloverStrategy,java.lang.String,org.apache.logging.log4j.core.Layout,java.lang.String,java.lang.String,java.lang.String,boolean)>(v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v);
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager: boolean isAttributeViewEnabled()>();
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingRandomAccessFileManager: void defineAttributeView(java.nio.file.Path)>(v);
label:
return v;
catch java.io.IOException from label to label with label;
}
}