final class org.glassfish.main.jul.handler.LoggingOutputStream extends java.io.ByteArrayOutputStream
{
private final java.lang.String lineSeparator;
private final java.util.logging.Level logRecordLevel;
private final org.glassfish.main.jul.handler.LogRecordBuffer logRecordBuffer;
private final java.lang.String loggerName;
private final org.glassfish.main.jul.handler.LoggingOutputStream$Pump pump;
private final java.util.concurrent.atomic.AtomicBoolean closed;
private final java.nio.charset.Charset charset;
void <init>(java.util.logging.Logger, java.util.logging.Level, int, java.nio.charset.Charset)
{
org.glassfish.main.jul.handler.LoggingOutputStream v;
org.glassfish.main.jul.handler.LoggingOutputStream$Pump v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.logging.Logger v;
java.util.logging.Level v;
java.nio.charset.Charset v;
int v;
java.lang.String v, v;
org.glassfish.main.jul.handler.LogRecordBuffer v, v;
v := @this: org.glassfish.main.jul.handler.LoggingOutputStream;
v := @parameter: java.util.logging.Logger;
v := @parameter: java.util.logging.Level;
v := @parameter: int;
v := @parameter: java.nio.charset.Charset;
specialinvoke v.<java.io.ByteArrayOutputStream: void <init>()>();
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>()>();
v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.util.concurrent.atomic.AtomicBoolean closed> = v;
v = staticinvoke <java.lang.System: java.lang.String lineSeparator()>();
v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.lang.String lineSeparator> = v;
v = virtualinvoke v.<java.util.logging.Logger: java.lang.String getName()>();
v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.lang.String loggerName> = v;
v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.util.logging.Level logRecordLevel> = v;
v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.nio.charset.Charset charset> = v;
v = new org.glassfish.main.jul.handler.LogRecordBuffer;
specialinvoke v.<org.glassfish.main.jul.handler.LogRecordBuffer: void <init>(int)>(v);
v.<org.glassfish.main.jul.handler.LoggingOutputStream: org.glassfish.main.jul.handler.LogRecordBuffer logRecordBuffer> = v;
v = new org.glassfish.main.jul.handler.LoggingOutputStream$Pump;
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: org.glassfish.main.jul.handler.LogRecordBuffer logRecordBuffer>;
specialinvoke v.<org.glassfish.main.jul.handler.LoggingOutputStream$Pump: void <init>(java.util.logging.Logger,org.glassfish.main.jul.handler.LogRecordBuffer)>(v, v);
v.<org.glassfish.main.jul.handler.LoggingOutputStream: org.glassfish.main.jul.handler.LoggingOutputStream$Pump pump> = v;
return;
}
void addRecord(java.lang.Throwable)
{
java.lang.Throwable v;
org.glassfish.main.jul.handler.LoggingOutputStream v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.logging.Level v;
org.glassfish.main.jul.record.GlassFishLogRecord v;
java.lang.String v;
org.glassfish.main.jul.handler.LogRecordBuffer v;
boolean v;
v := @this: org.glassfish.main.jul.handler.LoggingOutputStream;
v := @parameter: java.lang.Throwable;
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.util.concurrent.atomic.AtomicBoolean closed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
return;
label:
v = new org.glassfish.main.jul.record.GlassFishLogRecord;
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.util.logging.Level logRecordLevel>;
specialinvoke v.<org.glassfish.main.jul.record.GlassFishLogRecord: void <init>(java.util.logging.Level,java.lang.String)>(v, "");
virtualinvoke v.<org.glassfish.main.jul.record.GlassFishLogRecord: void setThrown(java.lang.Throwable)>(v);
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.lang.String loggerName>;
virtualinvoke v.<org.glassfish.main.jul.record.GlassFishLogRecord: void setLoggerName(java.lang.String)>(v);
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: org.glassfish.main.jul.handler.LogRecordBuffer logRecordBuffer>;
virtualinvoke v.<org.glassfish.main.jul.handler.LogRecordBuffer: void add(org.glassfish.main.jul.record.GlassFishLogRecord)>(v);
return;
}
public void flush() throws java.io.IOException
{
org.glassfish.main.jul.handler.LoggingOutputStream v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.logging.Level v;
org.glassfish.main.jul.record.GlassFishLogRecord v;
java.lang.String v, v, v;
org.glassfish.main.jul.handler.LogRecordBuffer v;
boolean v, v, v;
v := @this: org.glassfish.main.jul.handler.LoggingOutputStream;
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.util.concurrent.atomic.AtomicBoolean closed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
return;
label:
v = specialinvoke v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.lang.String getMessage()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.lang.String lineSeparator>;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
return;
label:
v = new org.glassfish.main.jul.record.GlassFishLogRecord;
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.util.logging.Level logRecordLevel>;
specialinvoke v.<org.glassfish.main.jul.record.GlassFishLogRecord: void <init>(java.util.logging.Level,java.lang.String)>(v, v);
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.lang.String loggerName>;
virtualinvoke v.<org.glassfish.main.jul.record.GlassFishLogRecord: void setLoggerName(java.lang.String)>(v);
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: org.glassfish.main.jul.handler.LogRecordBuffer logRecordBuffer>;
virtualinvoke v.<org.glassfish.main.jul.handler.LogRecordBuffer: void add(org.glassfish.main.jul.record.GlassFishLogRecord)>(v);
return;
}
private synchronized java.lang.String getMessage() throws java.io.IOException
{
java.nio.charset.Charset v;
org.glassfish.main.jul.handler.LoggingOutputStream v;
java.lang.String v, v;
v := @this: org.glassfish.main.jul.handler.LoggingOutputStream;
specialinvoke v.<java.io.ByteArrayOutputStream: void flush()>();
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.nio.charset.Charset charset>;
v = specialinvoke v.<java.io.ByteArrayOutputStream: java.lang.String toString(java.nio.charset.Charset)>(v);
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
specialinvoke v.<java.io.ByteArrayOutputStream: void reset()>();
return v;
}
public void close() throws java.io.IOException
{
java.util.concurrent.atomic.AtomicBoolean v;
org.glassfish.main.jul.handler.LoggingOutputStream v;
org.glassfish.main.jul.handler.LoggingOutputStream$Pump v;
v := @this: org.glassfish.main.jul.handler.LoggingOutputStream;
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.util.concurrent.atomic.AtomicBoolean closed>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(1);
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: org.glassfish.main.jul.handler.LoggingOutputStream$Pump pump>;
virtualinvoke v.<org.glassfish.main.jul.handler.LoggingOutputStream$Pump: void shutdown()>();
specialinvoke v.<java.io.ByteArrayOutputStream: void close()>();
return;
}
public java.lang.String toString()
{
org.glassfish.main.jul.handler.LoggingOutputStream v;
java.lang.Class v;
java.lang.String v, v, v;
v := @this: org.glassfish.main.jul.handler.LoggingOutputStream;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = v.<org.glassfish.main.jul.handler.LoggingOutputStream: java.lang.String loggerName>;
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[])>("\u redirecting messages to the logger \u0001");
return v;
}
}