public class org.glassfish.main.jul.rotation.LogFileManager extends java.lang.Object
{
private static final java.util.logging.Logger LOG;
private static final java.time.format.DateTimeFormatter SUFFIX_FORMATTER;
private static final java.lang.String GZIP_EXTENSION;
private final java.io.File logFile;
private final long maxFileSize;
private final boolean compressOldLogFiles;
private final int maxCountOfOldLogFiles;
private final org.glassfish.main.jul.rotation.LogFileManager$HandlerSetStreamMethod streamSetter;
private final org.glassfish.main.jul.rotation.LogFileManager$HandlerCloseStreamMethod streamCloser;
private org.glassfish.main.jul.rotation.MeteredStream meter;
public void <init>(java.io.File, long, boolean, int, org.glassfish.main.jul.rotation.LogFileManager$HandlerSetStreamMethod, org.glassfish.main.jul.rotation.LogFileManager$HandlerCloseStreamMethod)
{
org.glassfish.main.jul.rotation.LogFileManager$HandlerSetStreamMethod v;
int v;
long v;
org.glassfish.main.jul.rotation.LogFileManager$HandlerCloseStreamMethod v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.io.File;
v := @parameter: long;
v := @parameter: boolean;
v := @parameter: int;
v := @parameter: org.glassfish.main.jul.rotation.LogFileManager$HandlerSetStreamMethod;
v := @parameter: org.glassfish.main.jul.rotation.LogFileManager$HandlerCloseStreamMethod;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile> = v;
v.<org.glassfish.main.jul.rotation.LogFileManager: long maxFileSize> = v;
v.<org.glassfish.main.jul.rotation.LogFileManager: boolean compressOldLogFiles> = v;
v.<org.glassfish.main.jul.rotation.LogFileManager: int maxCountOfOldLogFiles> = v;
v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.LogFileManager$HandlerSetStreamMethod streamSetter> = v;
v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.LogFileManager$HandlerCloseStreamMethod streamCloser> = v;
return;
}
public long getFileSize()
{
long v;
org.glassfish.main.jul.rotation.MeteredStream v, v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.MeteredStream meter>;
if v != null goto label;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: long length()>();
goto label;
label:
v = v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.MeteredStream meter>;
v = virtualinvoke v.<org.glassfish.main.jul.rotation.MeteredStream: long getBytesWritten()>();
label:
return v;
}
public void rollIfFileTooBig()
{
org.glassfish.main.jul.rotation.LogFileManager v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: boolean isRollFileSizeLimitReached()>();
if v == 0 goto label;
virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void roll()>();
label:
return;
}
public void rollIfFileNotEmpty()
{
long v;
byte v;
org.glassfish.main.jul.rotation.LogFileManager v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: long getFileSize()>();
v = v cmp 0L;
if v <= 0 goto label;
virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void roll()>();
label:
return;
}
public synchronized void roll()
{
java.util.logging.Logger v;
java.lang.Runnable v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v, v;
java.util.logging.Level v;
java.lang.Thread v;
java.lang.String v, v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = <org.glassfish.main.jul.rotation.LogFileManager: java.util.logging.Logger LOG>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "roll(); {0}", v);
v = virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: boolean isOutputEnabled()>();
virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void disableOutput()>();
v = specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File rollToNewFile()>();
v = staticinvoke <org.glassfish.main.jul.rotation.LogFileManager$lambda_roll_0__84: java.lang.Runnable bootstrap$(org.glassfish.main.jul.rotation.LogFileManager,java.io.File)>(v, v);
v = new java.lang.Thread;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
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[])>("old-log-files-cleanup-\u0001");
specialinvoke v.<java.lang.Thread: void <init>(java.lang.Runnable,java.lang.String)>(v, v);
virtualinvoke v.<java.lang.Thread: void start()>();
if v == 0 goto label;
virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void enableOutput()>();
label:
return;
}
public synchronized boolean isOutputEnabled()
{
org.glassfish.main.jul.rotation.MeteredStream v;
org.glassfish.main.jul.rotation.LogFileManager v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.MeteredStream meter>;
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public synchronized void enableOutput()
{
java.lang.IllegalStateException v, v;
org.glassfish.main.jul.rotation.LogFileManager$HandlerSetStreamMethod v;
long v;
java.io.BufferedOutputStream v;
org.glassfish.main.jul.rotation.MeteredStream v, v;
java.lang.String v, v, v;
boolean v, v, v;
java.io.FileOutputStream v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v, v, v, v;
java.lang.Exception v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: boolean isOutputEnabled()>();
if v == 0 goto label;
return;
label:
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
v = virtualinvoke v.<java.io.File: boolean mkdirs()>();
if v != 0 goto label;
v = new java.lang.IllegalStateException;
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[])>("Failed to create the parent directory \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new java.io.FileOutputStream;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File,boolean)>(v, 1);
v = new java.io.BufferedOutputStream;
specialinvoke v.<java.io.BufferedOutputStream: void <init>(java.io.OutputStream)>(v);
v = new org.glassfish.main.jul.rotation.MeteredStream;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: long length()>();
specialinvoke v.<org.glassfish.main.jul.rotation.MeteredStream: void <init>(java.io.OutputStream,long)>(v, v);
v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.MeteredStream meter> = v;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.LogFileManager$HandlerSetStreamMethod streamSetter>;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.MeteredStream meter>;
interfaceinvoke v.<org.glassfish.main.jul.rotation.LogFileManager$HandlerSetStreamMethod: void setStream(java.io.OutputStream)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Could not open the log file for writing: \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
public synchronized void disableOutput()
{
java.io.IOException v;
java.lang.Class v;
org.glassfish.main.jul.rotation.MeteredStream v;
org.glassfish.main.jul.rotation.LogFileManager$HandlerCloseStreamMethod v;
org.glassfish.main.jul.rotation.LogFileManager v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: boolean isOutputEnabled()>();
if v == 0 goto label;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.LogFileManager$HandlerCloseStreamMethod streamCloser>;
interfaceinvoke v.<org.glassfish.main.jul.rotation.LogFileManager$HandlerCloseStreamMethod: void close()>();
label:
v = v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.MeteredStream meter>;
virtualinvoke v.<org.glassfish.main.jul.rotation.MeteredStream: void close()>();
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
staticinvoke <org.glassfish.main.jul.tracing.GlassFishLoggingTracer: void error(java.lang.Class,java.lang.String,java.lang.Throwable)>(v, "Could not close the output stream.", v);
label:
v.<org.glassfish.main.jul.rotation.LogFileManager: org.glassfish.main.jul.rotation.MeteredStream meter> = null;
label:
return;
catch java.io.IOException from label to label with label;
}
private boolean isRollFileSizeLimitReached()
{
byte v, v;
long v, v, v;
org.glassfish.main.jul.rotation.LogFileManager v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: long maxFileSize>;
v = v cmp 0L;
if v > 0 goto label;
return 0;
label:
v = virtualinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: long getFileSize()>();
v = v.<org.glassfish.main.jul.rotation.LogFileManager: long maxFileSize>;
v = v cmp v;
if v < 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private java.io.File rollToNewFile()
{
java.util.logging.Logger v, v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v, v, v, v, v;
java.lang.Exception v;
java.util.logging.Level v, v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
label:
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: boolean createNewFile()>();
if v == 0 goto label;
v = <org.glassfish.main.jul.rotation.LogFileManager: java.util.logging.Logger LOG>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "Created new log file: {0}", v);
label:
return null;
label:
v = <org.glassfish.main.jul.rotation.LogFileManager: java.util.logging.Logger LOG>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "Rolling log file: {0}", v);
v = specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File prepareAchivedLogFileTarget()>();
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void moveFile(java.io.File,java.io.File)>(v, v);
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void forceOSFilesync(java.io.File)>(v);
label:
return v;
label:
v := @caughtexception;
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void logError(java.lang.String,java.lang.Throwable)>("Error, could not rotate log file", v);
return null;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
private java.io.File prepareAchivedLogFileTarget()
{
java.time.LocalDateTime v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v, v, v, v;
java.time.format.DateTimeFormatter v;
int v;
java.lang.String v, v, v, v;
boolean v, v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
v = <org.glassfish.main.jul.rotation.LogFileManager: java.time.format.DateTimeFormatter SUFFIX_FORMATTER>;
v = staticinvoke <java.time.LocalDateTime: java.time.LocalDateTime now()>();
v = virtualinvoke v.<java.time.format.DateTimeFormatter: java.lang.String format(java.time.temporal.TemporalAccessor)>(v);
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[])>("\u0001_\u0001");
v = 1;
v = v;
label:
v = new java.io.File;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File getGzArchiveFile(java.io.File)>(v);
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
return v;
label:
v = v + 1;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(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[])>("\u0001_\u0001");
goto label;
}
private void forceOSFilesync(java.io.File) throws java.io.IOException
{
java.io.FileOutputStream v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.io.File;
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
virtualinvoke v.<java.io.FileOutputStream: void close()>();
return;
}
private void moveFile(java.io.File, java.io.File) throws java.io.IOException
{
java.nio.file.CopyOption[] v;
java.lang.Object[] v;
java.util.logging.Logger v;
java.util.function.Supplier v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v;
java.nio.file.StandardCopyOption v;
java.util.logging.Level v;
java.lang.String v;
java.nio.file.Path v, v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.io.File;
v := @parameter: java.io.File;
v = <org.glassfish.main.jul.rotation.LogFileManager: java.util.logging.Logger LOG>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = staticinvoke <org.glassfish.main.jul.rotation.LogFileManager$lambda_moveFile_1__85: java.util.function.Supplier bootstrap$(java.io.File,java.io.File)>(v, v);
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.util.function.Supplier)>(v, v);
v = virtualinvoke v.<java.io.File: boolean renameTo(java.io.File)>(v);
if v != 0 goto label;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("File %s could not be renamed to %s trying to copy and delete it with NIO.", v);
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void logError(java.lang.String)>(v);
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
v = newarray (java.nio.file.CopyOption)[1];
v = <java.nio.file.StandardCopyOption: java.nio.file.StandardCopyOption ATOMIC_MOVE>;
v[0] = v;
staticinvoke <java.nio.file.Files: java.nio.file.Path copy(java.nio.file.Path,java.nio.file.Path,java.nio.file.CopyOption[])>(v, v, v);
label:
return;
}
private synchronized void cleanUpHistoryLogFiles(java.io.File)
{
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.io.File;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: boolean compressOldLogFiles>;
if v == 0 goto label;
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void compressFile(java.io.File)>(v);
label:
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void deleteOldLogFiles()>();
return;
}
private void compressFile(java.io.File)
{
java.lang.Object[] v;
long v, v, v, v, v;
java.util.logging.Level v;
java.lang.Long v, v, v;
java.lang.String v, v, v, v;
boolean v, v;
java.util.logging.Logger v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.io.File;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File getGzArchiveFile(java.io.File)>(v);
v = specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: boolean gzipFile(java.io.File,java.io.File)>(v, v);
if v == 0 goto label;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
v = <org.glassfish.main.jul.rotation.LogFileManager: java.util.logging.Logger LOG>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = newarray (java.lang.Object)[5];
v[0] = v;
v = virtualinvoke v.<java.io.File: long length()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[1] = v;
v[2] = v;
v = virtualinvoke v.<java.io.File: long length()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[3] = v;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[4] = v;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object[])>(v, "File {0} of size {1} has been archived to file {2} of size {3} in {4} ms", v);
v = virtualinvoke v.<java.io.File: boolean delete()>();
if v != 0 goto label;
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[])>("Could not delete uncompressed log file: \u0001");
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void logError(java.lang.String)>(v);
goto label;
label:
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[])>("Could not compress log file: \u0001");
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void logError(java.lang.String)>(v);
label:
return;
}
private java.io.File getGzArchiveFile(java.io.File)
{
java.lang.String v, v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v, v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.io.File;
v = new java.io.File;
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
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[])>("\u.gz");
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
return v;
}
private void deleteOldLogFiles()
{
java.util.function.Function v;
int v, v;
java.lang.String v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v, v;
java.util.function.Consumer v;
java.io.FileFilter v;
java.util.stream.Stream v, v, v;
java.util.Comparator v, v;
java.io.File[] v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v = v.<org.glassfish.main.jul.rotation.LogFileManager: int maxCountOfOldLogFiles>;
if v != 0 goto label;
return;
label:
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
v = v.<org.glassfish.main.jul.rotation.LogFileManager: java.io.File logFile>;
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
if v != null goto label;
return;
label:
v = staticinvoke <org.glassfish.main.jul.rotation.LogFileManager$lambda_deleteOldLogFiles_2__86: java.io.FileFilter bootstrap$(java.lang.String)>(v);
v = virtualinvoke v.<java.io.File: java.io.File[] listFiles(java.io.FileFilter)>(v);
v = staticinvoke <java.util.Arrays: java.util.stream.Stream stream(java.lang.Object[])>(v);
v = staticinvoke <org.glassfish.main.jul.rotation.LogFileManager$getName__87: java.util.function.Function bootstrap$()>();
v = staticinvoke <java.util.Comparator: java.util.Comparator comparing(java.util.function.Function)>(v);
v = interfaceinvoke v.<java.util.Comparator: java.util.Comparator reversed()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream sorted(java.util.Comparator)>(v);
v = v.<org.glassfish.main.jul.rotation.LogFileManager: int maxCountOfOldLogFiles>;
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream skip(long)>(v);
v = staticinvoke <org.glassfish.main.jul.rotation.LogFileManager$deleteFile__88: java.util.function.Consumer bootstrap$(org.glassfish.main.jul.rotation.LogFileManager)>(v);
interfaceinvoke v.<java.util.stream.Stream: void forEach(java.util.function.Consumer)>(v);
return;
}
public void deleteFile(java.io.File)
{
java.lang.String v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v;
boolean v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.io.File;
v = virtualinvoke v.<java.io.File: boolean delete()>();
if v != 0 goto label;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Could not delete the log file: \u0001");
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void logError(java.lang.String)>(v);
label:
return;
}
private boolean gzipFile(java.io.File, java.io.File)
{
java.lang.Throwable v, v, v;
byte[] v;
java.io.FileOutputStream v;
java.io.IOException v;
java.io.FileInputStream v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.io.File v, v;
int v, v;
java.util.zip.GZIPOutputStream v;
java.lang.String v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.io.File;
v := @parameter: java.io.File;
label:
v = new java.io.FileInputStream;
specialinvoke v.<java.io.FileInputStream: void <init>(java.io.File)>(v);
label:
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
label:
v = new java.util.zip.GZIPOutputStream;
specialinvoke v.<java.util.zip.GZIPOutputStream: void <init>(java.io.OutputStream)>(v);
label:
v = newarray (byte)[1024];
label:
v = virtualinvoke v.<java.io.FileInputStream: int read(byte[])>(v);
v = (int) -1;
if v == v goto label;
virtualinvoke v.<java.util.zip.GZIPOutputStream: void write(byte[],int,int)>(v, 0, v);
goto label;
label:
virtualinvoke v.<java.util.zip.GZIPOutputStream: void finish()>();
label:
virtualinvoke v.<java.util.zip.GZIPOutputStream: void close()>();
label:
virtualinvoke v.<java.io.FileOutputStream: void close()>();
label:
virtualinvoke v.<java.io.FileInputStream: void close()>();
label:
return 1;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Error gzipping log file \u0001");
specialinvoke v.<org.glassfish.main.jul.rotation.LogFileManager: void logError(java.lang.String,java.lang.Throwable)>(v, v);
return 0;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
private void logError(java.lang.String)
{
java.lang.Class v;
java.lang.String v;
java.util.logging.Logger v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.util.logging.Level v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
staticinvoke <org.glassfish.main.jul.tracing.GlassFishLoggingTracer: void error(java.lang.Class,java.lang.String)>(v, v);
v = <org.glassfish.main.jul.rotation.LogFileManager: java.util.logging.Logger LOG>;
v = <java.util.logging.Level: java.util.logging.Level SEVERE>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
return;
}
private void logError(java.lang.String, java.lang.Throwable)
{
java.lang.Throwable v;
java.lang.Class v;
java.lang.String v;
java.util.logging.Logger v;
org.glassfish.main.jul.rotation.LogFileManager v;
java.util.logging.Level v;
v := @this: org.glassfish.main.jul.rotation.LogFileManager;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Throwable;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
staticinvoke <org.glassfish.main.jul.tracing.GlassFishLoggingTracer: void error(java.lang.Class,java.lang.String,java.lang.Throwable)>(v, v, v);
v = <org.glassfish.main.jul.rotation.LogFileManager: java.util.logging.Logger LOG>;
v = <java.util.logging.Level: java.util.logging.Level SEVERE>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
return;
}
static void <clinit>()
{
java.time.format.DateTimeFormatter v;
java.lang.Class v;
java.lang.String v;
java.util.logging.Logger v;
v = class "Lorg/glassfish/main/jul/rotation/LogFileManager;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <java.util.logging.Logger: java.util.logging.Logger getLogger(java.lang.String)>(v);
<org.glassfish.main.jul.rotation.LogFileManager: java.util.logging.Logger LOG> = v;
v = staticinvoke <java.time.format.DateTimeFormatter: java.time.format.DateTimeFormatter ofPattern(java.lang.String)>("yyyy-MM-dd\'T\'HH-mm-ss");
<org.glassfish.main.jul.rotation.LogFileManager: java.time.format.DateTimeFormatter SUFFIX_FORMATTER> = v;
return;
}
}