public class org.apache.logging.log4j.core.appender.rolling.RollingFileManager extends org.apache.logging.log4j.core.appender.FileManager
{
private static org.apache.logging.log4j.core.appender.rolling.RollingFileManager$RollingFileManagerFactory factory;
private static final int MAX_TRIES;
private static final int MIN_DURATION;
private static final java.nio.file.attribute.FileTime EPOCH;
protected long size;
private long initialTime;
private volatile org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor;
private final java.util.concurrent.Semaphore semaphore;
private final org.apache.logging.log4j.core.util.Log4jThreadFactory threadFactory;
private volatile org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy;
private volatile org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy;
private volatile boolean renameEmptyFiles;
private volatile boolean initialized;
private volatile java.lang.String fileName;
private final boolean directWrite;
private final java.util.concurrent.CopyOnWriteArrayList rolloverListeners;
private final java.util.concurrent.ExecutorService asyncExecutor;
private static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater triggeringPolicyUpdater;
private static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater rolloverStrategyUpdater;
private static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater patternProcessorUpdater;
protected void <init>(java.lang.String, java.lang.String, java.io.OutputStream, boolean, 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, int, boolean)
{
byte[] v;
long v, v;
java.nio.ByteBuffer v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
int v, v;
java.lang.String v, v, v;
boolean v, v;
java.io.OutputStream v;
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
org.apache.logging.log4j.core.Layout v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.io.OutputStream;
v := @parameter: boolean;
v := @parameter: long;
v := @parameter: long;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.Layout;
v := @parameter: int;
v := @parameter: boolean;
v = <org.apache.logging.log4j.core.util.Constants: int ENCODER_BYTE_BUFFER_SIZE>;
v = newarray (byte)[v];
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer wrap(byte[])>(v);
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void <init>(java.lang.String,java.lang.String,java.io.OutputStream,boolean,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,boolean,java.nio.ByteBuffer)>(v, v, v, v, v, v, v, v, v, v, v, v);
return;
}
protected void <init>(java.lang.String, java.lang.String, java.io.OutputStream, boolean, 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, boolean, java.nio.ByteBuffer)
{
java.util.concurrent.ThreadPoolExecutor v;
long v, v;
java.nio.ByteBuffer v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
java.lang.String v, v, v, v;
boolean v, v, v;
java.io.OutputStream v;
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
java.util.concurrent.Semaphore v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue v;
java.util.concurrent.TimeUnit v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
org.apache.logging.log4j.core.appender.rolling.PatternProcessor v, v;
org.apache.logging.log4j.core.Layout v;
org.apache.logging.log4j.core.util.Log4jThreadFactory v, v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.io.OutputStream;
v := @parameter: boolean;
v := @parameter: long;
v := @parameter: long;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.Layout;
v := @parameter: boolean;
v := @parameter: java.nio.ByteBuffer;
if v == null goto label;
v = v;
goto label;
label:
v = v;
label:
specialinvoke v.<org.apache.logging.log4j.core.appender.FileManager: void <init>(java.lang.String,java.io.OutputStream,boolean,boolean,java.lang.String,org.apache.logging.log4j.core.Layout,boolean,java.nio.ByteBuffer)>(v, v, v, 0, v, v, v, v);
v = new java.util.concurrent.Semaphore;
specialinvoke v.<java.util.concurrent.Semaphore: void <init>(int)>(1);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.Semaphore semaphore> = v;
v = staticinvoke <org.apache.logging.log4j.core.util.Log4jThreadFactory: org.apache.logging.log4j.core.util.Log4jThreadFactory createThreadFactory(java.lang.String)>("RollingFileManager");
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.util.Log4jThreadFactory threadFactory> = v;
v = new java.util.concurrent.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners> = v;
v = new java.util.concurrent.ThreadPoolExecutor;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = new org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue: void <init>()>();
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.util.Log4jThreadFactory threadFactory>;
specialinvoke v.<java.util.concurrent.ThreadPoolExecutor: void <init>(int,int,long,java.util.concurrent.TimeUnit,java.util.concurrent.BlockingQueue,java.util.concurrent.ThreadFactory)>(0, 2147483647, 0L, v, v, v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long initialTime> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy> = v;
v = new org.apache.logging.log4j.core.appender.rolling.PatternProcessor;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void <init>(java.lang.String)>(v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor> = v;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor>;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void setPrevFileTime(long)>(v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String fileName> = v;
v = v instanceof org.apache.logging.log4j.core.appender.rolling.DirectWriteRolloverStrategy;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean directWrite> = v;
return;
}
protected void <init>(org.apache.logging.log4j.core.LoggerContext, java.lang.String, java.lang.String, java.io.OutputStream, boolean, boolean, 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, boolean, java.nio.ByteBuffer)
{
java.util.concurrent.ThreadPoolExecutor v;
org.apache.logging.log4j.core.LoggerContext v;
long v, v;
java.nio.ByteBuffer v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
java.lang.String v, v, v, v;
boolean v, v, v, v;
java.io.OutputStream v;
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
java.util.concurrent.Semaphore v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue v;
java.util.concurrent.TimeUnit v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
org.apache.logging.log4j.core.appender.rolling.PatternProcessor v, v;
org.apache.logging.log4j.core.Layout v;
org.apache.logging.log4j.core.util.Log4jThreadFactory v, v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.LoggerContext;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.io.OutputStream;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: long;
v := @parameter: long;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.Layout;
v := @parameter: boolean;
v := @parameter: java.nio.ByteBuffer;
if v == null goto label;
v = v;
goto label;
label:
v = v;
label:
specialinvoke v.<org.apache.logging.log4j.core.appender.FileManager: void <init>(org.apache.logging.log4j.core.LoggerContext,java.lang.String,java.io.OutputStream,boolean,boolean,boolean,java.lang.String,org.apache.logging.log4j.core.Layout,boolean,java.nio.ByteBuffer)>(v, v, v, v, 0, v, v, v, v, v);
v = new java.util.concurrent.Semaphore;
specialinvoke v.<java.util.concurrent.Semaphore: void <init>(int)>(1);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.Semaphore semaphore> = v;
v = staticinvoke <org.apache.logging.log4j.core.util.Log4jThreadFactory: org.apache.logging.log4j.core.util.Log4jThreadFactory createThreadFactory(java.lang.String)>("RollingFileManager");
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.util.Log4jThreadFactory threadFactory> = v;
v = new java.util.concurrent.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners> = v;
v = new java.util.concurrent.ThreadPoolExecutor;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = new org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue: void <init>()>();
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.util.Log4jThreadFactory threadFactory>;
specialinvoke v.<java.util.concurrent.ThreadPoolExecutor: void <init>(int,int,long,java.util.concurrent.TimeUnit,java.util.concurrent.BlockingQueue,java.util.concurrent.ThreadFactory)>(0, 2147483647, 0L, v, v, v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long initialTime> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy> = v;
v = new org.apache.logging.log4j.core.appender.rolling.PatternProcessor;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void <init>(java.lang.String)>(v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor> = v;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor>;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void setPrevFileTime(long)>(v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String fileName> = v;
v = v instanceof org.apache.logging.log4j.core.appender.rolling.DirectWriteRolloverStrategy;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean directWrite> = v;
return;
}
protected void <init>(org.apache.logging.log4j.core.LoggerContext, java.lang.String, java.lang.String, java.io.OutputStream, boolean, boolean, 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, java.nio.ByteBuffer)
{
java.util.concurrent.ThreadPoolExecutor v;
org.apache.logging.log4j.core.LoggerContext v;
long v, v;
java.nio.ByteBuffer v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
java.lang.String v, v, v, v, v, v, v;
boolean v, v, v, v;
java.io.OutputStream v;
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
java.util.concurrent.Semaphore v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue v;
java.util.concurrent.TimeUnit v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
org.apache.logging.log4j.core.appender.rolling.PatternProcessor v, v;
org.apache.logging.log4j.core.Layout v;
org.apache.logging.log4j.core.util.Log4jThreadFactory v, v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.LoggerContext;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.io.OutputStream;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: long;
v := @parameter: long;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.Layout;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: java.nio.ByteBuffer;
if v == null goto label;
v = v;
goto label;
label:
v = v;
label:
specialinvoke v.<org.apache.logging.log4j.core.appender.FileManager: void <init>(org.apache.logging.log4j.core.LoggerContext,java.lang.String,java.io.OutputStream,boolean,boolean,boolean,java.lang.String,org.apache.logging.log4j.core.Layout,java.lang.String,java.lang.String,java.lang.String,boolean,java.nio.ByteBuffer)>(v, v, v, v, 0, v, v, v, v, v, v, v, v);
v = new java.util.concurrent.Semaphore;
specialinvoke v.<java.util.concurrent.Semaphore: void <init>(int)>(1);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.Semaphore semaphore> = v;
v = staticinvoke <org.apache.logging.log4j.core.util.Log4jThreadFactory: org.apache.logging.log4j.core.util.Log4jThreadFactory createThreadFactory(java.lang.String)>("RollingFileManager");
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.util.Log4jThreadFactory threadFactory> = v;
v = new java.util.concurrent.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners> = v;
v = new java.util.concurrent.ThreadPoolExecutor;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = new org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$EmptyQueue: void <init>()>();
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.util.Log4jThreadFactory threadFactory>;
specialinvoke v.<java.util.concurrent.ThreadPoolExecutor: void <init>(int,int,long,java.util.concurrent.TimeUnit,java.util.concurrent.BlockingQueue,java.util.concurrent.ThreadFactory)>(0, 2147483647, 0L, v, v, v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long initialTime> = v;
v = new org.apache.logging.log4j.core.appender.rolling.PatternProcessor;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void <init>(java.lang.String)>(v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor> = v;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor>;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void setPrevFileTime(long)>(v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy> = v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String fileName> = v;
v = v instanceof org.apache.logging.log4j.core.appender.rolling.DirectFileRolloverStrategy;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean directWrite> = v;
return;
}
public void initialize()
{
long v, v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
java.lang.String v, v;
boolean v, v, v, v, v, v;
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v, v, v, v;
java.io.File v, v;
org.apache.logging.log4j.Logger v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean initialized>;
if v != 0 goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Initializing triggering policy {}", v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean initialized> = 1;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean directWrite>;
if v == 0 goto label;
v = new java.io.File;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String getFileName()>();
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: long length()>();
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size> = v;
goto label;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy>;
interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.DirectFileRolloverStrategy: void clearCurrentFileName()>();
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy: void initialize(org.apache.logging.log4j.core.appender.rolling.RollingFileManager)>(v);
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
v = v instanceof org.apache.logging.log4j.core.LifeCycle;
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
interfaceinvoke v.<org.apache.logging.log4j.core.LifeCycle: void start()>();
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean directWrite>;
if v == 0 goto label;
v = new java.io.File;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String getFileName()>();
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: long length()>();
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size> = v;
goto label;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy>;
interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.DirectFileRolloverStrategy: void clearCurrentFileName()>();
label:
return;
}
public static org.apache.logging.log4j.core.appender.rolling.RollingFileManager getFileManager(java.lang.String, java.lang.String, boolean, boolean, 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, int, boolean, boolean, java.lang.String, java.lang.String, java.lang.String, org.apache.logging.log4j.core.config.Configuration)
{
org.apache.logging.log4j.core.appender.AbstractManager v;
org.apache.logging.log4j.core.config.Configuration v;
int v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager$RollingFileManagerFactory v;
java.lang.String v, v, v, v, v, v, v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager$FactoryData v;
boolean v, v, v, v, v;
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
org.apache.logging.log4j.Logger v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
org.apache.logging.log4j.core.Layout v;
org.apache.logging.log4j.core.appender.OutputStreamManager v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.Layout;
v := @parameter: int;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.config.Configuration;
v = v instanceof org.apache.logging.log4j.core.appender.rolling.DirectWriteRolloverStrategy;
if v == 0 goto label;
if v == null goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>("The fileName attribute must not be specified with the DirectWriteRolloverStrategy");
return null;
label:
if v != null goto label;
v = v;
goto label;
label:
v = v;
label:
v = new org.apache.logging.log4j.core.appender.rolling.RollingFileManager$FactoryData;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$FactoryData: void <init>(java.lang.String,java.lang.String,boolean,boolean,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,int,boolean,boolean,java.lang.String,java.lang.String,java.lang.String,org.apache.logging.log4j.core.config.Configuration)>(v, v, v, v, v, v, v, v, v, v, v, v, v, v, v);
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RollingFileManager$RollingFileManagerFactory factory>;
v = staticinvoke <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.OutputStreamManager getManager(java.lang.String,java.lang.Object,org.apache.logging.log4j.core.appender.ManagerFactory)>(v, v, v);
v = staticinvoke <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.AbstractManager narrow(java.lang.Class,org.apache.logging.log4j.core.appender.AbstractManager)>(class "Lorg/apache/logging/log4j/core/appender/rolling/RollingFileManager;", v);
return v;
}
public void addRolloverListener(org.apache.logging.log4j.core.appender.rolling.RolloverListener)
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.appender.rolling.RolloverListener v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverListener;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean add(java.lang.Object)>(v);
return;
}
public void removeRolloverListener(org.apache.logging.log4j.core.appender.rolling.RolloverListener)
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.appender.rolling.RolloverListener v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverListener;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean remove(java.lang.Object)>(v);
return;
}
public java.lang.String getFileName()
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean directWrite>;
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.DirectFileRolloverStrategy: java.lang.String getCurrentFileName(org.apache.logging.log4j.core.appender.rolling.RollingFileManager)>(v);
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String fileName> = v;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String fileName>;
return v;
}
protected void createParentDir(java.io.File)
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
java.io.File v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: java.io.File;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean directWrite>;
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
if v == null goto label;
virtualinvoke v.<java.io.File: boolean mkdirs()>();
label:
return;
}
public boolean isDirectWrite()
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean directWrite>;
return v;
}
public org.apache.logging.log4j.core.appender.rolling.FileExtension getFileExtension()
{
org.apache.logging.log4j.core.appender.rolling.FileExtension v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.appender.rolling.PatternProcessor v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: org.apache.logging.log4j.core.appender.rolling.FileExtension getFileExtension()>();
return v;
}
protected synchronized void write(byte[], int, int, boolean)
{
byte[] v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
int v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: int;
v := @parameter: boolean;
specialinvoke v.<org.apache.logging.log4j.core.appender.FileManager: void write(byte[],int,int,boolean)>(v, v, v, v);
return;
}
protected synchronized void writeToDestination(byte[], int, int)
{
byte[] v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
int v, v;
long v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: int;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size>;
v = v + v;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size> = v;
specialinvoke v.<org.apache.logging.log4j.core.appender.FileManager: void writeToDestination(byte[],int,int)>(v, v, v);
return;
}
public boolean isRenameEmptyFiles()
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean renameEmptyFiles>;
return v;
}
public void setRenameEmptyFiles(boolean)
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: boolean;
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean renameEmptyFiles> = v;
return;
}
public long getFileSize()
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
int v;
long v, v;
java.nio.ByteBuffer v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.nio.ByteBuffer byteBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = v + v;
return v;
}
public long getFileTime()
{
long v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long initialTime>;
return v;
}
public synchronized void checkRollover(org.apache.logging.log4j.core.LogEvent)
{
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.LogEvent v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy: boolean isTriggeringEvent(org.apache.logging.log4j.core.LogEvent)>(v);
if v == 0 goto label;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void rollover()>();
label:
return;
}
public boolean releaseSub(long, java.util.concurrent.TimeUnit)
{
byte v;
java.lang.Thread v;
boolean v, v, v, v, v, v, v, v, v, v, v;
org.apache.logging.log4j.Logger v, v, v, v, v, v, v, v;
long v, v, v, v, v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
int v;
java.lang.Boolean v;
java.lang.String v;
java.util.concurrent.ExecutorService v, v, v, v, v, v, v, v, v, v;
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v, v, v, v;
java.util.concurrent.TimeUnit v, v;
java.lang.InterruptedException v, v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String getName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Shutting down RollingFileManager {}", v);
v = 1;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
v = v instanceof org.apache.logging.log4j.core.LifeCycle;
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.LifeCycle2: boolean stop(long,java.util.concurrent.TimeUnit)>(v, v);
v = 1 & v;
goto label;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
v = v instanceof org.apache.logging.log4j.core.LifeCycle;
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
interfaceinvoke v.<org.apache.logging.log4j.core.LifeCycle: void stop()>();
v = 1;
label:
v = specialinvoke v.<org.apache.logging.log4j.core.appender.FileManager: boolean releaseSub(long,java.util.concurrent.TimeUnit)>(v, v);
if v == 0 goto label;
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: void shutdown()>();
label:
v = virtualinvoke v.<java.util.concurrent.TimeUnit: long toMillis(long)>(v);
v = 100L cmp v;
if v >= 0 goto label;
v = v;
goto label;
label:
v = 100L;
label:
v = v;
v = 1;
label:
if v > 3 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isTerminated()>();
if v != 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
v = v * v;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean awaitTermination(long,java.util.concurrent.TimeUnit)>(v, v);
v = v + 1;
goto label;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isTerminated()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String)>("All asynchronous threads have terminated");
goto label;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: java.util.List shutdownNow()>();
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean awaitTermination(long,java.util.concurrent.TimeUnit)>(v, v);
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isTerminated()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String)>("All asynchronous threads have terminated");
goto label;
label:
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String)>("RollingFileManager shutting down but some asynchronous services may not have completed");
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String)>("RollingFileManager stopped but some asynchronous services may not have completed.");
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: java.util.List shutdownNow()>();
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean awaitTermination(long,java.util.concurrent.TimeUnit)>(v, v);
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isTerminated()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String)>("All asynchronous threads have terminated");
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String)>("RollingFileManager stopped but some asynchronous services may not have completed.");
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
label:
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("RollingFileManager shutdown completed with status {}", v);
return v;
catch java.lang.InterruptedException from label to label with label;
catch java.lang.InterruptedException from label to label with label;
catch java.lang.InterruptedException from label to label with label;
}
public synchronized void rollover(java.util.Date, java.util.Date)
{
java.util.Date v, v;
long v, v, v, v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.Logger v;
java.lang.Long v, v;
org.apache.logging.log4j.core.appender.rolling.PatternProcessor v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: java.util.Date;
v := @parameter: java.util.Date;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.util.Date: long getTime()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = virtualinvoke v.<java.util.Date: long getTime()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Rollover PrevFileTime: {}, PrevRollTime: {}", v, v);
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor getPatternProcessor()>();
v = virtualinvoke v.<java.util.Date: long getTime()>();
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void setPrevFileTime(long)>(v);
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor getPatternProcessor()>();
v = virtualinvoke v.<java.util.Date: long getTime()>();
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void setCurrentFileTime(long)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void rollover()>();
return;
}
public synchronized void rollover()
{
java.lang.Thread v, v;
boolean v, v, v, v, v, v, v;
java.lang.Exception v, v;
org.apache.logging.log4j.Logger v, v, v;
java.util.concurrent.CopyOnWriteArrayList v, v, v, v;
java.lang.Throwable v;
long v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
int v, v;
java.lang.String v, v, v, v, v, v, v;
java.util.Iterator v, v;
java.io.IOException v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
java.lang.Class v, v, v, v;
java.lang.Object v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean hasOutputStream()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean isCreateOnDemand()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean isDirectWrite()>();
if v != 0 goto label;
return;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.lang.String fileName>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: int size()>();
if v <= 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: 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:
interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverListener: void rolloverTriggered(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object,java.lang.Object)>("Rollover Listener {} failed with {}: {}", v, v, v);
goto label;
label:
v = staticinvoke <java.lang.Thread: boolean interrupted()>();
label:
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String)>("RollingFileManager cleared thread interrupted state, continue to rollover");
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy>;
v = specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean rollover(org.apache.logging.log4j.core.appender.rolling.RolloverStrategy)>(v);
if v == 0 goto label;
label:
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long size> = 0L;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: long initialTime> = v;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void createFileAfterRollover()>();
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void logError(java.lang.String,java.lang.Throwable)>("Failed to create file after rollover", v);
label:
if v == 0 goto label;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
goto label;
label:
v := @caughtexception;
if v == 0 goto label;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
label:
throw v;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: int size()>();
if v <= 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.CopyOnWriteArrayList rolloverListeners>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: 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:
interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverListener: void rolloverComplete(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object,java.lang.Object)>("Rollover Listener {} failed with {}: {}", v, v, v);
goto label;
label:
return;
catch java.lang.Exception from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Exception from label to label with label;
}
protected void createFileAfterRollover() throws java.io.IOException
{
java.io.OutputStream v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.io.OutputStream createOutputStream()>();
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void setOutputStream(java.io.OutputStream)>(v);
return;
}
public org.apache.logging.log4j.core.appender.rolling.PatternProcessor getPatternProcessor()
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.appender.rolling.PatternProcessor v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor>;
return v;
}
public void setTriggeringPolicy(org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy)
{
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v, v, v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
int v;
boolean v, v, v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy;
interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy: void initialize(org.apache.logging.log4j.core.appender.rolling.RollingFileManager)>(v);
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
v = 0;
label:
v = v + 1;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.atomic.AtomicReferenceFieldUpdater triggeringPolicyUpdater>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: boolean compareAndSet(java.lang.Object,java.lang.Object,java.lang.Object)>(v, v, v);
if v != 0 goto label;
if v < 3 goto label;
label:
if v == 0 goto label;
v = v instanceof org.apache.logging.log4j.core.LifeCycle;
if v == 0 goto label;
interfaceinvoke v.<org.apache.logging.log4j.core.LifeCycle: void start()>();
label:
v = v instanceof org.apache.logging.log4j.core.LifeCycle;
if v == 0 goto label;
interfaceinvoke v.<org.apache.logging.log4j.core.LifeCycle: void stop()>();
goto label;
label:
v = v instanceof org.apache.logging.log4j.core.LifeCycle;
if v == 0 goto label;
interfaceinvoke v.<org.apache.logging.log4j.core.LifeCycle: void stop()>();
label:
return;
}
public void setRolloverStrategy(org.apache.logging.log4j.core.appender.rolling.RolloverStrategy)
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.atomic.AtomicReferenceFieldUpdater rolloverStrategyUpdater>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: boolean compareAndSet(java.lang.Object,java.lang.Object,java.lang.Object)>(v, v, v);
return;
}
public void setPatternProcessor(org.apache.logging.log4j.core.appender.rolling.PatternProcessor)
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v;
org.apache.logging.log4j.core.appender.rolling.PatternProcessor v, v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.PatternProcessor;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.atomic.AtomicReferenceFieldUpdater patternProcessorUpdater>;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor patternProcessor>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReferenceFieldUpdater: boolean compareAndSet(java.lang.Object,java.lang.Object,java.lang.Object)>(v, v, v);
return;
}
public org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy getTriggeringPolicy()
{
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy triggeringPolicy>;
return v;
}
java.util.concurrent.Semaphore getSemaphore()
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
java.util.concurrent.Semaphore v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.Semaphore semaphore>;
return v;
}
public org.apache.logging.log4j.core.appender.rolling.RolloverStrategy getRolloverStrategy()
{
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy rolloverStrategy>;
return v;
}
private boolean rollover(org.apache.logging.log4j.core.appender.rolling.RolloverStrategy)
{
java.lang.Throwable v;
org.apache.logging.log4j.core.appender.rolling.RolloverDescription v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.appender.rolling.action.Action v, v, v, v, v, v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager$AsyncAction v;
java.util.concurrent.ExecutorService v;
boolean v, v, v;
java.util.concurrent.Semaphore v, v, v, v;
java.lang.Exception v;
org.apache.logging.log4j.Logger v, v;
java.lang.InterruptedException v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.Semaphore semaphore>;
virtualinvoke v.<java.util.concurrent.Semaphore: void acquire()>();
v = 1;
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void logError(java.lang.String,java.lang.Throwable)>("Thread interrupted while attempting to check rollover", v);
return 0;
label:
v = 1;
label:
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverStrategy: org.apache.logging.log4j.core.appender.rolling.RolloverDescription rollover(org.apache.logging.log4j.core.appender.rolling.RollingFileManager)>(v);
if v == null goto label;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void writeFooter()>();
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: boolean closeOutputStream()>();
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverDescription: org.apache.logging.log4j.core.appender.rolling.action.Action getSynchronous()>();
if v == null goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverDescription: org.apache.logging.log4j.core.appender.rolling.action.Action getSynchronous()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("RollingFileManager executing synchronous {}", v);
label:
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverDescription: org.apache.logging.log4j.core.appender.rolling.action.Action getSynchronous()>();
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.action.Action: boolean execute()>();
label:
goto label;
label:
v := @caughtexception;
v = 0;
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void logError(java.lang.String,java.lang.Throwable)>("Caught error in synchronous task", v);
label:
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverDescription: org.apache.logging.log4j.core.appender.rolling.action.Action getAsynchronous()>();
if v == null goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverDescription: org.apache.logging.log4j.core.appender.rolling.action.Action getAsynchronous()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("RollingFileManager executing async {}", v);
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.ExecutorService asyncExecutor>;
v = new org.apache.logging.log4j.core.appender.rolling.RollingFileManager$AsyncAction;
v = interfaceinvoke v.<org.apache.logging.log4j.core.appender.rolling.RolloverDescription: org.apache.logging.log4j.core.appender.rolling.action.Action getAsynchronous()>();
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$AsyncAction: void <init>(org.apache.logging.log4j.core.appender.rolling.action.Action,org.apache.logging.log4j.core.appender.rolling.RollingFileManager)>(v, v);
interfaceinvoke v.<java.util.concurrent.ExecutorService: void execute(java.lang.Runnable)>(v);
v = 0;
label:
v = v;
label:
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.Semaphore semaphore>;
virtualinvoke v.<java.util.concurrent.Semaphore: void release()>();
label:
return v;
label:
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.Semaphore semaphore>;
virtualinvoke v.<java.util.concurrent.Semaphore: void release()>();
return 0;
label:
v := @caughtexception;
v = v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.Semaphore semaphore>;
virtualinvoke v.<java.util.concurrent.Semaphore: void release()>();
throw v;
catch java.lang.InterruptedException from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void updateData(java.lang.Object)
{
org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager v;
org.apache.logging.log4j.core.appender.rolling.RolloverStrategy v;
org.apache.logging.log4j.core.appender.rolling.PatternProcessor v, v;
java.lang.Object v;
java.lang.String v;
v := @this: org.apache.logging.log4j.core.appender.rolling.RollingFileManager;
v := @parameter: java.lang.Object;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$FactoryData: org.apache.logging.log4j.core.appender.rolling.RolloverStrategy getRolloverStrategy()>();
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void setRolloverStrategy(org.apache.logging.log4j.core.appender.rolling.RolloverStrategy)>(v);
v = new org.apache.logging.log4j.core.appender.rolling.PatternProcessor;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$FactoryData: java.lang.String getPattern()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.PatternProcessor getPatternProcessor()>();
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.PatternProcessor: void <init>(java.lang.String,org.apache.logging.log4j.core.appender.rolling.PatternProcessor)>(v, v);
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void setPatternProcessor(org.apache.logging.log4j.core.appender.rolling.PatternProcessor)>(v);
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$FactoryData: org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy getTriggeringPolicy()>();
virtualinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: void setTriggeringPolicy(org.apache.logging.log4j.core.appender.rolling.TriggeringPolicy)>(v);
return;
}
private static long initialFileTime(java.io.File)
{
java.nio.file.attribute.FileTime v, v;
long v, v;
int v;
java.lang.String v, v, v, v, v, v;
java.nio.file.Path v;
boolean v;
java.nio.file.LinkOption[] v, v;
java.nio.file.attribute.BasicFileAttributes v;
java.io.File v;
java.lang.Exception v;
org.apache.logging.log4j.Logger v, v, v;
v := @parameter: java.io.File;
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
v = newarray (java.nio.file.LinkOption)[0];
v = staticinvoke <java.nio.file.Files: boolean exists(java.nio.file.Path,java.nio.file.LinkOption[])>(v, v);
if v == 0 goto label;
label:
v = newarray (java.nio.file.LinkOption)[0];
v = staticinvoke <java.nio.file.Files: java.nio.file.attribute.BasicFileAttributes readAttributes(java.nio.file.Path,java.lang.Class,java.nio.file.LinkOption[])>(v, class "Ljava/nio/file/attribute/BasicFileAttributes;", v);
v = interfaceinvoke v.<java.nio.file.attribute.BasicFileAttributes: java.nio.file.attribute.FileTime creationTime()>();
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.nio.file.attribute.FileTime EPOCH>;
v = virtualinvoke v.<java.nio.file.attribute.FileTime: int compareTo(java.nio.file.attribute.FileTime)>(v);
if v <= 0 goto label;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Returning file creation time for {}", v);
v = virtualinvoke v.<java.nio.file.attribute.FileTime: long toMillis()>();
label:
return v;
label:
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("Unable to obtain file creation time for \u0001");
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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[])>("Unable to calculate file creation time for \u0001: \u0001");
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String)>(v);
label:
v = virtualinvoke v.<java.io.File: long lastModified()>();
return v;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void <clinit>()
{
java.util.concurrent.atomic.AtomicReferenceFieldUpdater v, v, v;
org.apache.logging.log4j.core.appender.rolling.RollingFileManager$RollingFileManagerFactory v;
java.nio.file.attribute.FileTime v;
v = new org.apache.logging.log4j.core.appender.rolling.RollingFileManager$RollingFileManagerFactory;
specialinvoke v.<org.apache.logging.log4j.core.appender.rolling.RollingFileManager$RollingFileManagerFactory: void <init>()>();
<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: org.apache.logging.log4j.core.appender.rolling.RollingFileManager$RollingFileManagerFactory factory> = v;
v = staticinvoke <java.nio.file.attribute.FileTime: java.nio.file.attribute.FileTime fromMillis(long)>(0L);
<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.nio.file.attribute.FileTime EPOCH> = v;
v = staticinvoke <java.util.concurrent.atomic.AtomicReferenceFieldUpdater: java.util.concurrent.atomic.AtomicReferenceFieldUpdater newUpdater(java.lang.Class,java.lang.Class,java.lang.String)>(class "Lorg/apache/logging/log4j/core/appender/rolling/RollingFileManager;", class "Lorg/apache/logging/log4j/core/appender/rolling/TriggeringPolicy;", "triggeringPolicy");
<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.atomic.AtomicReferenceFieldUpdater triggeringPolicyUpdater> = v;
v = staticinvoke <java.util.concurrent.atomic.AtomicReferenceFieldUpdater: java.util.concurrent.atomic.AtomicReferenceFieldUpdater newUpdater(java.lang.Class,java.lang.Class,java.lang.String)>(class "Lorg/apache/logging/log4j/core/appender/rolling/RollingFileManager;", class "Lorg/apache/logging/log4j/core/appender/rolling/RolloverStrategy;", "rolloverStrategy");
<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.atomic.AtomicReferenceFieldUpdater rolloverStrategyUpdater> = v;
v = staticinvoke <java.util.concurrent.atomic.AtomicReferenceFieldUpdater: java.util.concurrent.atomic.AtomicReferenceFieldUpdater newUpdater(java.lang.Class,java.lang.Class,java.lang.String)>(class "Lorg/apache/logging/log4j/core/appender/rolling/RollingFileManager;", class "Lorg/apache/logging/log4j/core/appender/rolling/PatternProcessor;", "patternProcessor");
<org.apache.logging.log4j.core.appender.rolling.RollingFileManager: java.util.concurrent.atomic.AtomicReferenceFieldUpdater patternProcessorUpdater> = v;
return;
}
}