public final class psiprobe.tools.LogOutputStream extends java.io.OutputStream
{
private static final org.slf4j.Logger INTERNAL_LOGGER;
public static final int LEVEL_OFF;
public static final int LEVEL_TRACE;
public static final int LEVEL_DEBUG;
public static final int LEVEL_INFO;
public static final int LEVEL_WARN;
public static final int LEVEL_ERROR;
public static final int LEVEL_FATAL;
private final org.slf4j.Logger logger;
private final int level;
private final java.lang.StringBuilder buf;
private void <init>(org.slf4j.Logger, int)
{
org.slf4j.Logger v;
int v;
java.lang.StringBuilder v;
java.lang.IllegalArgumentException v;
psiprobe.tools.LogOutputStream v;
v := @this: psiprobe.tools.LogOutputStream;
v := @parameter: org.slf4j.Logger;
v := @parameter: int;
specialinvoke v.<java.io.OutputStream: void <init>()>();
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v.<psiprobe.tools.LogOutputStream: java.lang.StringBuilder buf> = v;
if v != null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Log cannot be null");
throw v;
label:
v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger> = v;
v.<psiprobe.tools.LogOutputStream: int level> = v;
return;
}
public static java.io.PrintStream createPrintStream(org.slf4j.Logger, int)
{
java.io.PrintStream v;
java.lang.Throwable v;
org.slf4j.Logger v, v;
java.io.IOException v;
psiprobe.tools.LogOutputStream v;
java.nio.charset.Charset v;
int v;
java.lang.String v;
v := @parameter: org.slf4j.Logger;
v := @parameter: int;
label:
v = new psiprobe.tools.LogOutputStream;
specialinvoke v.<psiprobe.tools.LogOutputStream: void <init>(org.slf4j.Logger,int)>(v, v);
label:
v = new java.io.PrintStream;
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset UTF_8>;
v = virtualinvoke v.<java.nio.charset.Charset: java.lang.String name()>();
specialinvoke v.<java.io.PrintStream: void <init>(java.io.OutputStream,boolean,java.lang.String)>(v, 1, v);
label:
virtualinvoke v.<psiprobe.tools.LogOutputStream: void close()>();
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <psiprobe.tools.LogOutputStream: org.slf4j.Logger INTERNAL_LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("", v);
return null;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
public void flush()
{
java.lang.StringBuilder v, v;
java.lang.String v;
psiprobe.tools.LogOutputStream v;
boolean v;
v := @this: psiprobe.tools.LogOutputStream;
v = specialinvoke v.<psiprobe.tools.LogOutputStream: boolean shouldWrite()>();
if v == 0 goto label;
v = v.<psiprobe.tools.LogOutputStream: java.lang.StringBuilder buf>;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
specialinvoke v.<psiprobe.tools.LogOutputStream: void log(java.lang.String)>(v);
label:
v = v.<psiprobe.tools.LogOutputStream: java.lang.StringBuilder buf>;
virtualinvoke v.<java.lang.StringBuilder: void setLength(int)>(0);
return;
}
public void write(int)
{
int v;
java.lang.StringBuilder v;
psiprobe.tools.LogOutputStream v;
boolean v;
v := @this: psiprobe.tools.LogOutputStream;
v := @parameter: int;
v = specialinvoke v.<psiprobe.tools.LogOutputStream: boolean shouldWrite()>();
if v == 0 goto label;
v = v.<psiprobe.tools.LogOutputStream: java.lang.StringBuilder buf>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(v);
label:
return;
}
public org.slf4j.Logger getLog()
{
org.slf4j.Logger v;
psiprobe.tools.LogOutputStream v;
v := @this: psiprobe.tools.LogOutputStream;
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
return v;
}
public int getLevel()
{
int v;
psiprobe.tools.LogOutputStream v;
v := @this: psiprobe.tools.LogOutputStream;
v = v.<psiprobe.tools.LogOutputStream: int level>;
return v;
}
private boolean shouldWrite()
{
org.slf4j.Logger v, v, v, v, v;
psiprobe.tools.LogOutputStream v;
int v;
boolean v, v, v, v, v;
v := @this: psiprobe.tools.LogOutputStream;
v = v.<psiprobe.tools.LogOutputStream: int level>;
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
case 5: goto label;
default: goto label;
};
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
return v;
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
return v;
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isInfoEnabled()>();
return v;
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isWarnEnabled()>();
return v;
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isErrorEnabled()>();
return v;
label:
return 0;
}
private void log(java.lang.String)
{
org.slf4j.Logger v, v, v, v, v;
psiprobe.tools.LogOutputStream v;
int v;
java.lang.String v;
boolean v;
v := @this: psiprobe.tools.LogOutputStream;
v := @parameter: java.lang.String;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
label:
return;
label:
v = v.<psiprobe.tools.LogOutputStream: int level>;
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
case 5: goto label;
default: goto label;
};
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>(v);
goto label;
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
goto label;
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
goto label;
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
goto label;
label:
v = v.<psiprobe.tools.LogOutputStream: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
label:
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lpsiprobe/tools/LogOutputStream;");
<psiprobe.tools.LogOutputStream: org.slf4j.Logger INTERNAL_LOGGER> = v;
return;
}
}