public final class org.apache.logging.log4j.core.layout.GelfLayout extends org.apache.logging.log4j.core.layout.AbstractStringLayout
{
private static final char C;
private static final int COMPRESSION_THRESHOLD;
private static final char Q;
private static final java.lang.String QC;
private static final java.lang.String QU;
private final org.apache.logging.log4j.core.util.KeyValuePair[] additionalFields;
private final int compressionThreshold;
private final org.apache.logging.log4j.core.layout.GelfLayout$CompressionType compressionType;
private final java.lang.String host;
private final boolean includeStacktrace;
private final boolean includeThreadContext;
private final boolean includeMapMessage;
private final boolean includeNullDelimiter;
private final boolean includeNewLineDelimiter;
private final boolean omitEmptyFields;
private final org.apache.logging.log4j.core.layout.PatternLayout layout;
private final org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter mdcWriter;
private final org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter mapWriter;
private static final java.lang.ThreadLocal messageStringBuilder;
private static final java.lang.ThreadLocal timestampStringBuilder;
public void <init>(java.lang.String, org.apache.logging.log4j.core.util.KeyValuePair[], org.apache.logging.log4j.core.layout.GelfLayout$CompressionType, int, boolean)
{
org.apache.logging.log4j.core.util.KeyValuePair[] v;
org.apache.logging.log4j.core.layout.GelfLayout$CompressionType v;
org.apache.logging.log4j.core.layout.GelfLayout v;
int v;
java.lang.String v;
boolean v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.util.KeyValuePair[];
v := @parameter: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType;
v := @parameter: int;
v := @parameter: boolean;
specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: void <init>(org.apache.logging.log4j.core.config.Configuration,java.lang.String,org.apache.logging.log4j.core.util.KeyValuePair[],org.apache.logging.log4j.core.layout.GelfLayout$CompressionType,int,boolean,boolean,boolean,boolean,boolean,boolean,org.apache.logging.log4j.core.layout.internal.ListChecker,org.apache.logging.log4j.core.layout.internal.ListChecker,org.apache.logging.log4j.core.layout.PatternLayout,java.lang.String,java.lang.String)>(null, v, v, v, v, v, 1, 1, 0, 0, 0, null, null, null, "", "");
return;
}
private void <init>(org.apache.logging.log4j.core.config.Configuration, java.lang.String, org.apache.logging.log4j.core.util.KeyValuePair[], org.apache.logging.log4j.core.layout.GelfLayout$CompressionType, int, boolean, boolean, boolean, boolean, boolean, boolean, org.apache.logging.log4j.core.layout.internal.ListChecker, org.apache.logging.log4j.core.layout.internal.ListChecker, org.apache.logging.log4j.core.layout.PatternLayout, java.lang.String, java.lang.String)
{
org.apache.logging.log4j.core.util.KeyValuePair v;
org.apache.logging.log4j.core.config.Configuration v;
java.nio.charset.Charset v;
int v, v, v;
org.apache.logging.log4j.core.layout.internal.ListChecker v, v;
java.lang.String v, v, v, v, v;
boolean v, v, v, v, v, v, v;
org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter v, v;
java.lang.IllegalArgumentException v, v;
org.apache.logging.log4j.core.util.KeyValuePair[] v, v, v;
org.apache.logging.log4j.core.layout.GelfLayout$CompressionType v, v;
org.apache.logging.log4j.core.layout.GelfLayout v;
org.apache.logging.log4j.core.layout.PatternLayout v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v := @parameter: org.apache.logging.log4j.core.config.Configuration;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.util.KeyValuePair[];
v := @parameter: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType;
v := @parameter: int;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: org.apache.logging.log4j.core.layout.internal.ListChecker;
v := @parameter: org.apache.logging.log4j.core.layout.internal.ListChecker;
v := @parameter: org.apache.logging.log4j.core.layout.PatternLayout;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset UTF_8>;
specialinvoke v.<org.apache.logging.log4j.core.layout.AbstractStringLayout: void <init>(org.apache.logging.log4j.core.config.Configuration,java.nio.charset.Charset,org.apache.logging.log4j.core.layout.AbstractStringLayout$Serializer,org.apache.logging.log4j.core.layout.AbstractStringLayout$Serializer)>(v, v, null, null);
if v == null goto label;
v = v;
goto label;
label:
v = staticinvoke <org.apache.logging.log4j.core.util.NetUtils: java.lang.String getLocalHostname()>();
label:
v.<org.apache.logging.log4j.core.layout.GelfLayout: java.lang.String host> = v;
if v == null goto label;
v = v;
goto label;
label:
v = <org.apache.logging.log4j.core.util.KeyValuePair: org.apache.logging.log4j.core.util.KeyValuePair[] EMPTY_ARRAY>;
label:
v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.util.KeyValuePair[] additionalFields> = v;
if v != null goto label;
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.util.KeyValuePair[] additionalFields>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<org.apache.logging.log4j.core.util.KeyValuePair: java.lang.String getValue()>();
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: boolean valueNeedsLookup(java.lang.String)>(v);
if v == 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("configuration needs to be set when there are additional fields with variables");
throw v;
label:
v = v + 1;
goto label;
label:
v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType compressionType> = v;
v.<org.apache.logging.log4j.core.layout.GelfLayout: int compressionThreshold> = v;
v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeStacktrace> = v;
v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeThreadContext> = v;
v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeMapMessage> = v;
v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeNullDelimiter> = v;
v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeNewLineDelimiter> = v;
v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean omitEmptyFields> = v;
if v == 0 goto label;
v = <org.apache.logging.log4j.core.layout.GelfLayout$CompressionType: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType OFF>;
if v == v goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("null delimiter cannot be used with compression");
throw v;
label:
v = new org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter;
specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter: void <init>(org.apache.logging.log4j.core.layout.GelfLayout,org.apache.logging.log4j.core.layout.internal.ListChecker,java.lang.String)>(v, v, v);
v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter mdcWriter> = v;
v = new org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter;
specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter: void <init>(org.apache.logging.log4j.core.layout.GelfLayout,org.apache.logging.log4j.core.layout.internal.ListChecker,java.lang.String)>(v, v, v);
v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter mapWriter> = v;
v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.PatternLayout layout> = v;
return;
}
public java.lang.String toString()
{
org.apache.logging.log4j.core.layout.internal.ListChecker v, v;
boolean v, v, v, v;
org.apache.logging.log4j.core.layout.GelfLayout$CompressionType v;
org.apache.logging.log4j.core.layout.GelfLayout v;
java.lang.StringBuilder v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.logging.log4j.core.layout.PatternLayout v, v;
int v, v, v;
java.lang.String v, v, v, v, v, v;
org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter v, v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("host=");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: java.lang.String host>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", compressionType=");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType compressionType>;
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout$CompressionType: java.lang.String toString()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", compressionThreshold=");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: int compressionThreshold>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(int)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", includeStackTrace=");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeStacktrace>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(boolean)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", includeThreadContext=");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeThreadContext>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(boolean)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", includeNullDelimiter=");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeNullDelimiter>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(boolean)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", includeNewLineDelimiter=");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeNewLineDelimiter>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(boolean)>(v);
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter mdcWriter>;
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter: org.apache.logging.log4j.core.layout.internal.ListChecker getChecker()>();
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", ");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter mapWriter>;
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter: org.apache.logging.log4j.core.layout.internal.ListChecker getChecker()>();
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", ");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.PatternLayout layout>;
if v == null goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", PatternLayout{");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.PatternLayout layout>;
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.PatternLayout: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("}");
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
public static org.apache.logging.log4j.core.layout.GelfLayout createLayout(java.lang.String, org.apache.logging.log4j.core.util.KeyValuePair[], org.apache.logging.log4j.core.layout.GelfLayout$CompressionType, int, boolean)
{
org.apache.logging.log4j.core.util.KeyValuePair[] v;
org.apache.logging.log4j.core.layout.GelfLayout$CompressionType v;
org.apache.logging.log4j.core.layout.GelfLayout v;
int v;
java.lang.String v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.util.KeyValuePair[];
v := @parameter: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType;
v := @parameter: int;
v := @parameter: boolean;
v = new org.apache.logging.log4j.core.layout.GelfLayout;
specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: void <init>(org.apache.logging.log4j.core.config.Configuration,java.lang.String,org.apache.logging.log4j.core.util.KeyValuePair[],org.apache.logging.log4j.core.layout.GelfLayout$CompressionType,int,boolean,boolean,boolean,boolean,boolean,boolean,org.apache.logging.log4j.core.layout.internal.ListChecker,org.apache.logging.log4j.core.layout.internal.ListChecker,org.apache.logging.log4j.core.layout.PatternLayout,java.lang.String,java.lang.String)>(null, v, v, v, v, v, 1, 1, 0, 0, 0, null, null, null, "", "");
return v;
}
public static org.apache.logging.log4j.core.layout.GelfLayout$Builder newBuilder()
{
org.apache.logging.log4j.core.layout.AbstractLayout$Builder v;
org.apache.logging.log4j.core.layout.GelfLayout$Builder v;
v = new org.apache.logging.log4j.core.layout.GelfLayout$Builder;
specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout$Builder: void <init>()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout$Builder: org.apache.logging.log4j.core.layout.AbstractLayout$Builder asBuilder()>();
return v;
}
public java.util.Map getContentFormat()
{
org.apache.logging.log4j.core.layout.GelfLayout v;
java.util.Map v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v = staticinvoke <java.util.Collections: java.util.Map emptyMap()>();
return v;
}
public java.lang.String getContentType()
{
java.lang.String v;
java.nio.charset.Charset v;
org.apache.logging.log4j.core.layout.GelfLayout v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: java.nio.charset.Charset getCharset()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.nio.charset.Charset)>(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[])>("application/json; charset=\u0001");
return v;
}
public byte[] toByteArray(org.apache.logging.log4j.core.LogEvent)
{
byte[] v, v;
org.apache.logging.log4j.core.LogEvent v;
org.apache.logging.log4j.core.layout.GelfLayout$CompressionType v, v;
org.apache.logging.log4j.core.layout.GelfLayout v;
int v, v;
java.lang.StringBuilder v, v;
java.lang.String v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder getStringBuilder()>();
v = specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder toText(org.apache.logging.log4j.core.LogEvent,java.lang.StringBuilder,boolean)>(v, v, 0);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: byte[] getBytes(java.lang.String)>(v);
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType compressionType>;
v = <org.apache.logging.log4j.core.layout.GelfLayout$CompressionType: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType OFF>;
if v == v goto label;
v = lengthof v;
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: int compressionThreshold>;
if v <= v goto label;
v = specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: byte[] compress(byte[])>(v);
goto label;
label:
v = v;
label:
return v;
}
public void encode(org.apache.logging.log4j.core.LogEvent, org.apache.logging.log4j.core.layout.ByteBufferDestination)
{
org.apache.logging.log4j.core.LogEvent v;
org.apache.logging.log4j.core.layout.GelfLayout$CompressionType v, v;
org.apache.logging.log4j.core.layout.Encoder v;
org.apache.logging.log4j.core.layout.GelfLayout v;
org.apache.logging.log4j.core.layout.ByteBufferDestination v;
java.lang.StringBuilder v, v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v := @parameter: org.apache.logging.log4j.core.layout.ByteBufferDestination;
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType compressionType>;
v = <org.apache.logging.log4j.core.layout.GelfLayout$CompressionType: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType OFF>;
if v == v goto label;
specialinvoke v.<org.apache.logging.log4j.core.layout.AbstractStringLayout: void encode(org.apache.logging.log4j.core.LogEvent,org.apache.logging.log4j.core.layout.ByteBufferDestination)>(v, v);
return;
label:
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder getStringBuilder()>();
v = specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder toText(org.apache.logging.log4j.core.LogEvent,java.lang.StringBuilder,boolean)>(v, v, 1);
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.Encoder getStringBuilderEncoder()>();
interfaceinvoke v.<org.apache.logging.log4j.core.layout.Encoder: void encode(java.lang.Object,org.apache.logging.log4j.core.layout.ByteBufferDestination)>(v, v);
return;
}
public boolean requiresLocation()
{
org.apache.logging.log4j.core.layout.GelfLayout v;
org.apache.logging.log4j.core.layout.PatternLayout v, v;
boolean v, v, v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.PatternLayout layout>;
v = staticinvoke <java.util.Objects: boolean nonNull(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.PatternLayout layout>;
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.PatternLayout: boolean requiresLocation()>();
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private byte[] compress(byte[])
{
java.lang.Throwable v;
byte[] v, v;
java.io.ByteArrayOutputStream v;
java.io.IOException v;
java.util.zip.DeflaterOutputStream v;
org.apache.logging.log4j.core.layout.GelfLayout$CompressionType v;
org.apache.logging.log4j.core.layout.GelfLayout v;
int v, v;
org.apache.logging.log4j.status.StatusLogger v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v := @parameter: byte[];
label:
v = new java.io.ByteArrayOutputStream;
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: int compressionThreshold>;
v = v / 8;
specialinvoke v.<java.io.ByteArrayOutputStream: void <init>(int)>(v);
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$CompressionType compressionType>;
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout$CompressionType: java.util.zip.DeflaterOutputStream createDeflaterOutputStream(java.io.OutputStream)>(v);
label:
if v != null goto label;
label:
return v;
label:
virtualinvoke v.<java.util.zip.DeflaterOutputStream: void write(byte[])>(v);
virtualinvoke v.<java.util.zip.DeflaterOutputStream: void finish()>();
label:
virtualinvoke v.<java.util.zip.DeflaterOutputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v = virtualinvoke v.<java.io.ByteArrayOutputStream: byte[] toByteArray()>();
label:
return v;
label:
v := @caughtexception;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
virtualinvoke v.<org.apache.logging.log4j.status.StatusLogger: void error(java.lang.Object)>(v);
return v;
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;
catch java.io.IOException from label to label with label;
}
public java.lang.String toSerializable(org.apache.logging.log4j.core.LogEvent)
{
org.apache.logging.log4j.core.layout.GelfLayout v;
java.lang.StringBuilder v, v;
java.lang.String v;
org.apache.logging.log4j.core.LogEvent v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder getStringBuilder()>();
v = specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder toText(org.apache.logging.log4j.core.LogEvent,java.lang.StringBuilder,boolean)>(v, v, 0);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
private java.lang.StringBuilder toText(org.apache.logging.log4j.core.LogEvent, java.lang.StringBuilder, boolean)
{
org.apache.logging.log4j.core.util.KeyValuePair v;
org.apache.logging.log4j.Level v;
org.apache.logging.log4j.core.LogEvent v;
org.apache.logging.log4j.core.config.Configuration v;
boolean v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.CharSequence v, v, v, v, v;
org.apache.logging.log4j.util.BiConsumer v;
org.apache.logging.log4j.core.layout.GelfLayout v;
java.lang.StringBuilder v, v, v, v, v, v, v;
org.apache.logging.log4j.core.layout.PatternLayout v, v, v;
org.apache.logging.log4j.core.lookup.StrSubstitutor v;
java.lang.Throwable v, v, v, v;
long v;
org.apache.logging.log4j.message.Message v, v, v;
int v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter v;
org.apache.logging.log4j.util.ReadOnlyStringMap v;
org.apache.logging.log4j.core.util.KeyValuePair[] v, v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v := @parameter: java.lang.StringBuilder;
v := @parameter: boolean;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(123);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"version\":\"1.1\",");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"host\":\"");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: java.lang.String host>;
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.CharSequence toNullSafeString(java.lang.CharSequence)>(v);
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\",");
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"timestamp\":");
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: long getTimeMillis()>();
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.CharSequence formatTimestamp(long)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.CharSequence)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(44);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"level\":");
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: org.apache.logging.log4j.Level getLevel()>();
v = specialinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: int formatLevel(org.apache.logging.log4j.Level)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(int)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(44);
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.String getThreadName()>();
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"_thread\":\"");
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.String getThreadName()>();
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\",");
label:
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.String getLoggerName()>();
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"_logger\":\"");
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.String getLoggerName()>();
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\",");
label:
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.util.KeyValuePair[] additionalFields>;
v = lengthof v;
if v <= 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.config.Configuration getConfiguration()>();
v = interfaceinvoke v.<org.apache.logging.log4j.core.config.Configuration: org.apache.logging.log4j.core.lookup.StrSubstitutor getStrSubstitutor()>();
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.util.KeyValuePair[] additionalFields>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<org.apache.logging.log4j.core.util.KeyValuePair: java.lang.String getValue()>();
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: boolean valueNeedsLookup(java.lang.String)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.util.KeyValuePair: java.lang.String getValue()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.lookup.StrSubstitutor: java.lang.String replace(org.apache.logging.log4j.core.LogEvent,java.lang.String)>(v, v);
goto label;
label:
v = virtualinvoke v.<org.apache.logging.log4j.core.util.KeyValuePair: java.lang.String getValue()>();
label:
v = v;
v = staticinvoke <org.apache.logging.log4j.util.Strings: boolean isNotEmpty(java.lang.CharSequence)>(v);
if v != 0 goto label;
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean omitEmptyFields>;
if v != 0 goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"_");
v = virtualinvoke v.<org.apache.logging.log4j.core.util.KeyValuePair: java.lang.String getKey()>();
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\":\"");
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.CharSequence toNullSafeString(java.lang.CharSequence)>(v);
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\",");
label:
v = v + 1;
goto label;
label:
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeThreadContext>;
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: org.apache.logging.log4j.util.ReadOnlyStringMap getContextData()>();
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.GelfLayout$FieldWriter mdcWriter>;
interfaceinvoke v.<org.apache.logging.log4j.util.ReadOnlyStringMap: void forEach(org.apache.logging.log4j.util.TriConsumer,java.lang.Object)>(v, v);
label:
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeMapMessage>;
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: org.apache.logging.log4j.message.Message getMessage()>();
v = v instanceof org.apache.logging.log4j.message.MapMessage;
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: org.apache.logging.log4j.message.Message getMessage()>();
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout$lambda_toText_0__1143: org.apache.logging.log4j.util.BiConsumer bootstrap$(org.apache.logging.log4j.core.layout.GelfLayout,java.lang.StringBuilder)>(v, v);
virtualinvoke v.<org.apache.logging.log4j.message.MapMessage: void forEach(org.apache.logging.log4j.util.BiConsumer)>(v);
label:
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.Throwable getThrown()>();
if v != null goto label;
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.PatternLayout layout>;
if v == null goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"full_message\":\"");
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.PatternLayout layout>;
if v == null goto label;
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder getMessageStringBuilder()>();
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: org.apache.logging.log4j.core.layout.PatternLayout layout>;
virtualinvoke v.<org.apache.logging.log4j.core.layout.PatternLayout: void serialize(org.apache.logging.log4j.core.LogEvent,java.lang.StringBuilder)>(v, v);
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
goto label;
label:
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeStacktrace>;
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.Throwable getThrown()>();
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.CharSequence formatThrowable(java.lang.Throwable)>(v);
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
goto label;
label:
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.Throwable getThrown()>();
v = virtualinvoke v.<java.lang.Throwable: java.lang.String toString()>();
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\",");
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\"short_message\":\"");
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: org.apache.logging.log4j.message.Message getMessage()>();
v = v instanceof java.lang.CharSequence;
if v == 0 goto label;
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
goto label;
label:
if v == 0 goto label;
v = v instanceof org.apache.logging.log4j.util.StringBuilderFormattable;
if v == 0 goto label;
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder getMessageStringBuilder()>();
label:
interfaceinvoke v.<org.apache.logging.log4j.util.StringBuilderFormattable: void formatTo(java.lang.StringBuilder)>(v);
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
label:
staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: void trimToMaxSize(java.lang.StringBuilder)>(v);
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: void trimToMaxSize(java.lang.StringBuilder)>(v);
throw v;
label:
v = interfaceinvoke v.<org.apache.logging.log4j.message.Message: java.lang.String getFormattedMessage()>();
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.CharSequence toNullSafeString(java.lang.CharSequence)>(v);
staticinvoke <org.apache.logging.log4j.core.util.JsonUtils: void quoteAsString(java.lang.CharSequence,java.lang.StringBuilder)>(v, v);
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(34);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(125);
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeNullDelimiter>;
if v == 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(0);
label:
v = v.<org.apache.logging.log4j.core.layout.GelfLayout: boolean includeNewLineDelimiter>;
if v == 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(10);
label:
return v;
catch java.lang.Throwable from label to label with label;
}
private static boolean valueNeedsLookup(java.lang.String)
{
java.lang.String v;
boolean v, v;
v := @parameter: java.lang.String;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>("${");
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private static java.lang.StringBuilder getMessageStringBuilder()
{
java.lang.ThreadLocal v, v;
java.lang.Object v;
java.lang.StringBuilder v;
v = <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.ThreadLocal messageStringBuilder>;
v = virtualinvoke v.<java.lang.ThreadLocal: java.lang.Object get()>();
if v != null goto label;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>(int)>(1024);
v = v;
v = <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.ThreadLocal messageStringBuilder>;
virtualinvoke v.<java.lang.ThreadLocal: void set(java.lang.Object)>(v);
label:
virtualinvoke v.<java.lang.StringBuilder: void setLength(int)>(0);
return v;
}
private static java.lang.CharSequence toNullSafeString(java.lang.CharSequence)
{
java.lang.CharSequence v, v;
v := @parameter: java.lang.CharSequence;
if v != null goto label;
v = "";
goto label;
label:
v = v;
label:
return v;
}
static java.lang.CharSequence formatTimestamp(long)
{
byte v;
int v, v;
java.lang.StringBuilder v;
long v;
v := @parameter: long;
v = v cmp 1000L;
if v >= 0 goto label;
return "0";
label:
v = staticinvoke <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.StringBuilder getTimestampStringBuilder()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(long)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: int length()>();
v = v - 3;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder insert(int,char)>(v, 46);
return v;
}
private static java.lang.StringBuilder getTimestampStringBuilder()
{
java.lang.ThreadLocal v, v;
java.lang.Object v;
java.lang.StringBuilder v;
v = <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.ThreadLocal timestampStringBuilder>;
v = virtualinvoke v.<java.lang.ThreadLocal: java.lang.Object get()>();
if v != null goto label;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>(int)>(20);
v = v;
v = <org.apache.logging.log4j.core.layout.GelfLayout: java.lang.ThreadLocal timestampStringBuilder>;
virtualinvoke v.<java.lang.ThreadLocal: void set(java.lang.Object)>(v);
label:
virtualinvoke v.<java.lang.StringBuilder: void setLength(int)>(0);
return v;
}
private int formatLevel(org.apache.logging.log4j.Level)
{
org.apache.logging.log4j.core.layout.GelfLayout v;
int v;
org.apache.logging.log4j.Level v;
org.apache.logging.log4j.core.net.Severity v;
v := @this: org.apache.logging.log4j.core.layout.GelfLayout;
v := @parameter: org.apache.logging.log4j.Level;
v = staticinvoke <org.apache.logging.log4j.core.net.Severity: org.apache.logging.log4j.core.net.Severity getSeverity(org.apache.logging.log4j.Level)>(v);
v = virtualinvoke v.<org.apache.logging.log4j.core.net.Severity: int getCode()>();
return v;
}
static java.lang.CharSequence formatThrowable(java.lang.Throwable)
{
java.io.PrintWriter v;
java.lang.Throwable v;
java.lang.StringBuffer v;
java.io.StringWriter v;
v := @parameter: java.lang.Throwable;
v = new java.io.StringWriter;
specialinvoke v.<java.io.StringWriter: void <init>(int)>(2048);
v = new java.io.PrintWriter;
specialinvoke v.<java.io.PrintWriter: void <init>(java.io.Writer)>(v);
virtualinvoke v.<java.lang.Throwable: void printStackTrace(java.io.PrintWriter)>(v);
virtualinvoke v.<java.io.PrintWriter: void flush()>();
v = virtualinvoke v.<java.io.StringWriter: java.lang.StringBuffer getBuffer()>();
return v;
}
static void <clinit>()
{
java.lang.ThreadLocal v, v;
v = new java.lang.ThreadLocal;
specialinvoke v.<java.lang.ThreadLocal: void <init>()>();
<org.apache.logging.log4j.core.layout.GelfLayout: java.lang.ThreadLocal messageStringBuilder> = v;
v = new java.lang.ThreadLocal;
specialinvoke v.<java.lang.ThreadLocal: void <init>()>();
<org.apache.logging.log4j.core.layout.GelfLayout: java.lang.ThreadLocal timestampStringBuilder> = v;
return;
}
}