public class org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender extends java.lang.Object implements org.glassfish.grizzly.http.server.accesslog.AccessLogAppender
{
private static final java.util.logging.Logger LOGGER;
private final org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal fileFormat;
private final org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal archiveFormat;
private org.glassfish.grizzly.http.server.accesslog.FileAppender appender;
private final java.io.File directory;
private java.io.File currentArchive;
private java.io.File currentFile;
private boolean closed;
public void <init>(java.io.File, java.lang.String) throws java.io.IOException
{
org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender v;
java.lang.String v, v;
java.util.logging.Logger v;
java.io.File v;
v := @this: org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
specialinvoke v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: void <init>(java.lang.String,java.lang.String,java.io.File)>(v, v, v);
v = <org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.util.logging.Logger LOGGER>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File,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[])>("Creating rotating log appender in \"\u0001\" with file pattern \"\u0001\"");
virtualinvoke v.<java.util.logging.Logger: void fine(java.lang.String)>(v);
return;
}
public void <init>(java.io.File, java.lang.String, java.lang.String) throws java.io.IOException
{
org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender v;
java.lang.String v, v, v, v;
java.util.logging.Logger v;
java.io.File v;
v := @this: org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.lang.String escape(java.lang.String)>(v);
specialinvoke v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: void <init>(java.lang.String,java.lang.String,java.io.File)>(v, v, v);
v = <org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.util.logging.Logger LOGGER>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File,java.lang.String,java.lang.String)>(v, 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[])>("Creating rotating log appender in \"\u0001\" writing to \"\u0001\" and archive pattern \"\u0001\"");
virtualinvoke v.<java.util.logging.Logger: void fine(java.lang.String)>(v);
return;
}
private static java.lang.String escape(java.lang.String)
{
java.lang.String v, v, v;
java.lang.NullPointerException v;
v := @parameter: java.lang.String;
if v != null goto label;
v = new java.lang.NullPointerException;
specialinvoke v.<java.lang.NullPointerException: void <init>(java.lang.String)>("Null file name");
throw v;
label:
v = virtualinvoke v.<java.lang.String: java.lang.String replace(java.lang.CharSequence,java.lang.CharSequence)>("\'", "\'\'");
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[])>("\'\u0001\'");
return v;
}
private void <init>(java.lang.String, java.lang.String, java.io.File) throws java.io.IOException
{
java.util.Date v;
org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal v, v, v, v;
boolean v, v, v;
org.glassfish.grizzly.http.server.accesslog.FileAppender v;
org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender v;
java.lang.String v, v, v, v, v, v, v;
java.lang.IllegalArgumentException v, v, v;
java.io.File v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.Object v, v;
v := @this: org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.io.File;
specialinvoke v.<java.lang.Object: void <init>()>();
v = virtualinvoke v.<java.io.File: java.io.File getCanonicalFile()>();
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File directory> = v;
v = new org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal;
specialinvoke v.<org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal: void <init>(java.lang.String)>(v);
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal archiveFormat> = v;
v = new org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal;
specialinvoke v.<org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal: void <init>(java.lang.String)>(v);
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal fileFormat> = v;
v = new java.util.Date;
specialinvoke v.<java.util.Date: void <init>()>();
v = new java.io.File;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal archiveFormat>;
v = virtualinvoke v.<org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal: java.lang.Object get()>();
v = virtualinvoke v.<java.text.SimpleDateFormat: java.lang.String format(java.util.Date)>(v);
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = virtualinvoke v.<java.io.File: java.io.File getCanonicalFile()>();
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive> = v;
v = new java.io.File;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal fileFormat>;
v = virtualinvoke v.<org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal: java.lang.Object get()>();
v = virtualinvoke v.<java.text.SimpleDateFormat: java.lang.String format(java.util.Date)>(v);
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = virtualinvoke v.<java.io.File: java.io.File getCanonicalFile()>();
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile> = v;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File directory>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive>;
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
v = virtualinvoke v.<java.io.File: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File directory>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File,java.io.File)>(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[])>("Archive file \"\u0001\" is not a child of the configured directory \"\u0001\"");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File directory>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
v = virtualinvoke v.<java.io.File: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File directory>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File,java.io.File)>(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[])>("Access log file \"\u0001\" is not a child of the configured directory \"\u0001\"");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
v = virtualinvoke v.<java.io.File: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = new java.lang.IllegalArgumentException;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
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[])>("Access log file and archive file point to the same file \"\u0001\"");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new org.glassfish.grizzly.http.server.accesslog.FileAppender;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
specialinvoke v.<org.glassfish.grizzly.http.server.accesslog.FileAppender: void <init>(java.io.File,boolean)>(v, 1);
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.FileAppender appender> = v;
return;
}
public void append(java.lang.String) throws java.io.IOException
{
java.util.Date v;
org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal v, v;
boolean v, v, v, v;
java.util.logging.Logger v, v;
java.lang.Throwable v;
java.util.logging.Level v;
org.glassfish.grizzly.http.server.accesslog.FileAppender v, v, v;
org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender v;
java.lang.String v, v, v, v, v;
java.io.IOException v, v;
java.io.File v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.Object v, v;
v := @this: org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender;
v := @parameter: java.lang.String;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: boolean closed>;
if v == 0 goto label;
return;
label:
v = new java.util.Date;
specialinvoke v.<java.util.Date: void <init>()>();
entermonitor v;
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal archiveFormat>;
v = virtualinvoke v.<org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal: java.lang.Object get()>();
v = new java.io.File;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File directory>;
v = virtualinvoke v.<java.text.SimpleDateFormat: java.lang.String format(java.util.Date)>(v);
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive>;
v = virtualinvoke v.<java.io.File: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.FileAppender appender>;
virtualinvoke v.<org.glassfish.grizzly.http.server.accesslog.FileAppender: void close()>();
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive>;
v = virtualinvoke v.<java.io.File: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = <org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.util.logging.Logger LOGGER>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File,java.io.File)>(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[])>("Archiving \"\u0001\" to \"\u0001\"");
virtualinvoke v.<java.util.logging.Logger: void info(java.lang.String)>(v);
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive>;
v = virtualinvoke v.<java.io.File: boolean renameTo(java.io.File)>(v);
if v != 0 goto label;
v = new java.io.IOException;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File,java.io.File)>(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 rename \"\u0001\" to \"\u0001\"");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentArchive> = v;
v = new java.io.File;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File directory>;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal fileFormat>;
v = virtualinvoke v.<org.glassfish.grizzly.http.server.accesslog.SimpleDateFormatThreadLocal: java.lang.Object get()>();
v = virtualinvoke v.<java.text.SimpleDateFormat: java.lang.String format(java.util.Date)>(v);
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile> = v;
v = new org.glassfish.grizzly.http.server.accesslog.FileAppender;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.io.File currentFile>;
specialinvoke v.<org.glassfish.grizzly.http.server.accesslog.FileAppender: void <init>(java.io.File,boolean)>(v, 1);
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.FileAppender appender> = v;
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "I/O error rotating access log file", v);
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.FileAppender appender>;
virtualinvoke v.<org.glassfish.grizzly.http.server.accesslog.FileAppender: void append(java.lang.String)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void close() throws java.io.IOException
{
org.glassfish.grizzly.http.server.accesslog.FileAppender v;
org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender v;
v := @this: org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender;
v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: boolean closed> = 1;
v = v.<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: org.glassfish.grizzly.http.server.accesslog.FileAppender appender>;
virtualinvoke v.<org.glassfish.grizzly.http.server.accesslog.FileAppender: void close()>();
return;
}
static void <clinit>()
{
java.util.logging.Logger v;
v = staticinvoke <org.glassfish.grizzly.Grizzly: java.util.logging.Logger logger(java.lang.Class)>(class "Lorg/glassfish/grizzly/http/server/HttpServer;");
<org.glassfish.grizzly.http.server.accesslog.RotatingFileAppender: java.util.logging.Logger LOGGER> = v;
return;
}
}