public class org.glassfish.grizzly.http.server.accesslog.QueueingAppender extends java.lang.Object implements org.glassfish.grizzly.http.server.accesslog.AccessLogAppender
{
private static final java.util.logging.Logger LOGGER;
private final java.util.concurrent.LinkedBlockingQueue queue;
private final org.glassfish.grizzly.http.server.accesslog.AccessLogAppender appender;
private final java.lang.Thread thread;
public void <init>(org.glassfish.grizzly.http.server.accesslog.AccessLogAppender)
{
java.util.concurrent.LinkedBlockingQueue v;
java.lang.NullPointerException v;
org.glassfish.grizzly.http.server.accesslog.QueueingAppender v;
java.lang.Thread v, v, v, v;
org.glassfish.grizzly.http.server.accesslog.QueueingAppender$Dequeuer v;
java.lang.String v;
org.glassfish.grizzly.http.server.accesslog.AccessLogAppender v;
v := @this: org.glassfish.grizzly.http.server.accesslog.QueueingAppender;
v := @parameter: org.glassfish.grizzly.http.server.accesslog.AccessLogAppender;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.LinkedBlockingQueue;
specialinvoke v.<java.util.concurrent.LinkedBlockingQueue: void <init>()>();
v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.util.concurrent.LinkedBlockingQueue queue> = v;
if v != null goto label;
v = new java.lang.NullPointerException;
specialinvoke v.<java.lang.NullPointerException: void <init>(java.lang.String)>("Null appender");
throw v;
label:
v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: org.glassfish.grizzly.http.server.accesslog.AccessLogAppender appender> = v;
v = new java.lang.Thread;
v = new org.glassfish.grizzly.http.server.accesslog.QueueingAppender$Dequeuer;
specialinvoke v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender$Dequeuer: void <init>(org.glassfish.grizzly.http.server.accesslog.QueueingAppender)>(v);
specialinvoke v.<java.lang.Thread: void <init>(java.lang.Runnable)>(v);
v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.lang.Thread thread> = v;
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.lang.Thread thread>;
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
virtualinvoke v.<java.lang.Thread: void setName(java.lang.String)>(v);
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.lang.Thread thread>;
virtualinvoke v.<java.lang.Thread: void setDaemon(boolean)>(1);
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.lang.Thread thread>;
virtualinvoke v.<java.lang.Thread: void start()>();
return;
}
public void append(java.lang.String) throws java.io.IOException
{
java.util.logging.Logger v;
java.util.concurrent.LinkedBlockingQueue v;
java.util.logging.Level v;
org.glassfish.grizzly.http.server.accesslog.QueueingAppender v;
java.lang.InterruptedException v;
java.lang.Thread v;
java.lang.String v;
boolean v;
v := @this: org.glassfish.grizzly.http.server.accesslog.QueueingAppender;
v := @parameter: java.lang.String;
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.lang.Thread thread>;
v = virtualinvoke v.<java.lang.Thread: boolean isAlive()>();
if v == 0 goto label;
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.util.concurrent.LinkedBlockingQueue queue>;
virtualinvoke v.<java.util.concurrent.LinkedBlockingQueue: void put(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "Interrupted adding log entry to the queue", v);
label:
return;
catch java.lang.InterruptedException from label to label with label;
}
public void close() throws java.io.IOException
{
java.lang.Throwable v;
java.util.logging.Logger v;
java.util.logging.Level v;
org.glassfish.grizzly.http.server.accesslog.QueueingAppender v;
java.lang.InterruptedException v;
java.lang.Thread v, v;
org.glassfish.grizzly.http.server.accesslog.AccessLogAppender v, v, v;
v := @this: org.glassfish.grizzly.http.server.accesslog.QueueingAppender;
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.lang.Thread thread>;
virtualinvoke v.<java.lang.Thread: void interrupt()>();
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.lang.Thread thread>;
virtualinvoke v.<java.lang.Thread: void join()>();
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: org.glassfish.grizzly.http.server.accesslog.AccessLogAppender appender>;
interfaceinvoke v.<org.glassfish.grizzly.http.server.accesslog.AccessLogAppender: void close()>();
goto label;
label:
v := @caughtexception;
v = <org.glassfish.grizzly.http.server.accesslog.QueueingAppender: java.util.logging.Logger LOGGER>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "Interrupted stopping de-queuer", v);
label:
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: org.glassfish.grizzly.http.server.accesslog.AccessLogAppender appender>;
interfaceinvoke v.<org.glassfish.grizzly.http.server.accesslog.AccessLogAppender: void close()>();
goto label;
label:
v := @caughtexception;
v = v.<org.glassfish.grizzly.http.server.accesslog.QueueingAppender: org.glassfish.grizzly.http.server.accesslog.AccessLogAppender appender>;
interfaceinvoke v.<org.glassfish.grizzly.http.server.accesslog.AccessLogAppender: void close()>();
throw v;
label:
return;
catch java.lang.InterruptedException 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;
}
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.QueueingAppender: java.util.logging.Logger LOGGER> = v;
return;
}
}