final class com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl extends java.util.logging.Formatter
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl
super_class: java.util.logging.Formatter
{
private static final java.lang.String FORMAT_FULL;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "[%1$s] %2$s: %3$s%4$s%n"
private static final java.lang.String FORMAT_NO_LEVEL;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "[%1$s] %2$s%3$s%n"
static final java.util.logging.Formatter INSTANCE;
descriptor: Ljava/util/logging/Formatter;
flags: (0x0018) ACC_STATIC, ACC_FINAL
private static volatile int[] $SWITCH_TABLE$com$oracle$truffle$polyglot$PolyglotLoggers$ImmutableLogRecord$FormatKind;
descriptor: [I
flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl
dup
invokespecial com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.<init>:()V
putstatic com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.INSTANCE:Ljava/util/logging/Formatter;
return
LocalVariableTable:
Start End Slot Name Signature
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.util.logging.Formatter.<init>:()V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lcom/oracle/truffle/polyglot/PolyglotLoggers$PolyglotStreamHandler$FormatterImpl;
public java.lang.String format(java.util.logging.LogRecord);
descriptor: (Ljava/util/logging/LogRecord;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=10, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual java.util.logging.LogRecord.getLoggerName:()Ljava/lang/String;
invokestatic com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.formatLoggerName:(Ljava/lang/String;)Ljava/lang/String;
astore 2
start local 2 1: aload 0
aload 1
invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.formatMessage:(Ljava/util/logging/LogRecord;)Ljava/lang/String;
astore 3
start local 3 2: ldc ""
astore 4
start local 4 3: aload 1
invokevirtual java.util.logging.LogRecord.getThrown:()Ljava/lang/Throwable;
astore 5
start local 5 4: aload 5
ifnull 17
5: new java.io.StringWriter
dup
invokespecial java.io.StringWriter.<init>:()V
astore 6
start local 6 6: aconst_null
astore 7
aconst_null
astore 8
7: new java.io.PrintWriter
dup
aload 6
invokespecial java.io.PrintWriter.<init>:(Ljava/io/Writer;)V
astore 9
start local 9 8: aload 9
invokevirtual java.io.PrintWriter.println:()V
9: aload 5
aload 9
invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintWriter;)V
10: aload 9
ifnull 16
aload 9
invokevirtual java.io.PrintWriter.close:()V
goto 16
StackMap locals: com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl java.util.logging.LogRecord java.lang.String java.lang.String java.lang.String java.lang.Throwable java.io.StringWriter java.lang.Throwable java.lang.Throwable java.io.PrintWriter
StackMap stack: java.lang.Throwable
11: astore 7
aload 9
ifnull 12
aload 9
invokevirtual java.io.PrintWriter.close:()V
end local 9 StackMap locals:
StackMap stack:
12: aload 7
athrow
StackMap locals:
StackMap stack: java.lang.Throwable
13: astore 8
aload 7
ifnonnull 14
aload 8
astore 7
goto 15
StackMap locals:
StackMap stack:
14: aload 7
aload 8
if_acmpeq 15
aload 7
aload 8
invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
StackMap locals:
StackMap stack:
15: aload 7
athrow
16: StackMap locals:
StackMap stack:
aload 6
invokevirtual java.io.StringWriter.toString:()Ljava/lang/String;
astore 4
end local 6 17: StackMap locals:
StackMap stack:
aload 1
checkcast com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord
invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord.getFormatKind:()Lcom/oracle/truffle/polyglot/PolyglotLoggers$ImmutableLogRecord$FormatKind;
astore 7
start local 7 18: invokestatic com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.$SWITCH_TABLE$com$oracle$truffle$polyglot$PolyglotLoggers$ImmutableLogRecord$FormatKind:()[I
aload 7
invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.ordinal:()I
iaload
tableswitch { // 1 - 3
1: 23
2: 21
3: 19
default: 25
}
19: StackMap locals: com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl java.util.logging.LogRecord java.lang.String java.lang.String java.lang.String java.lang.Throwable top com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind
StackMap stack:
ldc "[%1$s] %2$s: %3$s%4$s%n"
iconst_4
anewarray java.lang.Object
dup
iconst_0
aload 2
aastore
dup
iconst_1
aload 1
invokevirtual java.util.logging.LogRecord.getLevel:()Ljava/util/logging/Level;
invokevirtual java.util.logging.Level.getName:()Ljava/lang/String;
aastore
dup
iconst_2
aload 3
aastore
dup
iconst_3
aload 4
aastore
invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
astore 6
start local 6 20: goto 26
end local 6 21: StackMap locals:
StackMap stack:
ldc "[%1$s] %2$s%3$s%n"
iconst_3
anewarray java.lang.Object
dup
iconst_0
aload 2
aastore
dup
iconst_1
aload 3
aastore
dup
iconst_2
aload 4
aastore
invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
astore 6
start local 6 22: goto 26
end local 6 23: StackMap locals:
StackMap stack:
aload 3
astore 6
start local 6 24: goto 26
end local 6 25: StackMap locals:
StackMap stack:
new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
ldc "Unsupported FormatKind "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 7
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
start local 6 26: StackMap locals: com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl java.util.logging.LogRecord java.lang.String java.lang.String java.lang.String java.lang.Throwable java.lang.String com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind
StackMap stack:
aload 6
areturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 27 0 this Lcom/oracle/truffle/polyglot/PolyglotLoggers$PolyglotStreamHandler$FormatterImpl;
0 27 1 record Ljava/util/logging/LogRecord;
1 27 2 loggerName Ljava/lang/String;
2 27 3 message Ljava/lang/String;
3 27 4 stackTrace Ljava/lang/String;
4 27 5 exception Ljava/lang/Throwable;
6 17 6 str Ljava/io/StringWriter;
8 12 9 out Ljava/io/PrintWriter;
20 21 6 logEntry Ljava/lang/String;
22 23 6 logEntry Ljava/lang/String;
24 25 6 logEntry Ljava/lang/String;
26 27 6 logEntry Ljava/lang/String;
18 27 7 formatKind Lcom/oracle/truffle/polyglot/PolyglotLoggers$ImmutableLogRecord$FormatKind;
Exception table:
from to target type
8 10 11 any
7 13 13 any
MethodParameters:
Name Flags
record
private static java.lang.String formatLoggerName(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=5, args_size=1
start local 0 0: aload 0
bipush 46
invokevirtual java.lang.String.indexOf:(I)I
istore 3
start local 3 1: iload 3
ifge 5
2: aload 0
astore 1
start local 1 3: ldc ""
astore 2
start local 2 4: goto 7
end local 2 end local 1 5: StackMap locals: java.lang.String top top int
StackMap stack:
aload 0
iconst_0
iload 3
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
astore 1
start local 1 6: aload 0
iload 3
iconst_1
iadd
invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
astore 2
start local 2 7: StackMap locals: java.lang.String java.lang.String java.lang.String int
StackMap stack:
aload 2
invokevirtual java.lang.String.isEmpty:()Z
ifeq 9
8: aload 1
areturn
9: StackMap locals:
StackMap stack:
new java.lang.StringBuilder
dup
aload 1
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
astore 4
start local 4 10: aload 4
ldc "::"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
11: aload 4
aload 2
invokestatic com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.possibleSimpleName:(Ljava/lang/String;)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
12: aload 4
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 loggerName Ljava/lang/String;
3 5 1 id Ljava/lang/String;
6 13 1 id Ljava/lang/String;
4 5 2 name Ljava/lang/String;
7 13 2 name Ljava/lang/String;
1 13 3 index I
10 13 4 sb Ljava/lang/StringBuilder;
MethodParameters:
Name Flags
loggerName final
private static java.lang.String possibleSimpleName(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=3, args_size=1
start local 0 0: iconst_m1
istore 1
start local 1 1: iconst_0
istore 2
start local 2 2: goto 7
3: StackMap locals: int int
StackMap stack:
iload 2
iconst_1
iadd
aload 0
invokevirtual java.lang.String.length:()I
if_icmpge 6
aload 0
iload 2
iconst_1
iadd
invokevirtual java.lang.String.charAt:(I)C
invokestatic java.lang.Character.isUpperCase:(C)Z
ifeq 6
4: iload 2
iconst_1
iadd
istore 1
5: goto 8
6: StackMap locals:
StackMap stack:
aload 0
bipush 46
iload 2
iconst_1
iadd
invokevirtual java.lang.String.indexOf:(II)I
istore 2
StackMap locals:
StackMap stack:
7: iload 2
ifge 3
end local 2 8: StackMap locals:
StackMap stack:
iload 1
ifge 9
aload 0
goto 10
StackMap locals:
StackMap stack:
9: aload 0
iload 1
invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
StackMap locals:
StackMap stack: java.lang.String
10: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 loggerName Ljava/lang/String;
1 11 1 index I
2 8 2 i I
MethodParameters:
Name Flags
loggerName final
static int[] $SWITCH_TABLE$com$oracle$truffle$polyglot$PolyglotLoggers$ImmutableLogRecord$FormatKind();
descriptor: ()[I
flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
Code:
stack=3, locals=1, args_size=0
0: getstatic com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.$SWITCH_TABLE$com$oracle$truffle$polyglot$PolyglotLoggers$ImmutableLogRecord$FormatKind:[I
dup
ifnull 1
areturn
StackMap locals:
StackMap stack: int[]
1: pop
invokestatic com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.values:()[Lcom/oracle/truffle/polyglot/PolyglotLoggers$ImmutableLogRecord$FormatKind;
arraylength
newarray 10
astore 0
2: aload 0
getstatic com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.DEFAULT:Lcom/oracle/truffle/polyglot/PolyglotLoggers$ImmutableLogRecord$FormatKind;
invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.ordinal:()I
iconst_3
iastore
3: goto 5
StackMap locals: int[]
StackMap stack: java.lang.NoSuchFieldError
4: pop
StackMap locals:
StackMap stack:
5: aload 0
getstatic com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.NO_LEVEL:Lcom/oracle/truffle/polyglot/PolyglotLoggers$ImmutableLogRecord$FormatKind;
invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.ordinal:()I
iconst_2
iastore
6: goto 8
StackMap locals:
StackMap stack: java.lang.NoSuchFieldError
7: pop
StackMap locals:
StackMap stack:
8: aload 0
getstatic com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.RAW:Lcom/oracle/truffle/polyglot/PolyglotLoggers$ImmutableLogRecord$FormatKind;
invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.ordinal:()I
iconst_1
iastore
9: goto 11
StackMap locals:
StackMap stack: java.lang.NoSuchFieldError
10: pop
StackMap locals:
StackMap stack:
11: aload 0
dup
putstatic com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.$SWITCH_TABLE$com$oracle$truffle$polyglot$PolyglotLoggers$ImmutableLogRecord$FormatKind:[I
areturn
LocalVariableTable:
Start End Slot Name Signature
Exception table:
from to target type
2 3 4 Class java.lang.NoSuchFieldError
5 6 7 Class java.lang.NoSuchFieldError
8 9 10 Class java.lang.NoSuchFieldError
}
SourceFile: "PolyglotLoggers.java"
NestHost: com.oracle.truffle.polyglot.PolyglotLoggers
InnerClasses:
private final ImmutableLogRecord = com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord of com.oracle.truffle.polyglot.PolyglotLoggers
final FormatKind = com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind of com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord
private PolyglotStreamHandler = com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler of com.oracle.truffle.polyglot.PolyglotLoggers
private final FormatterImpl = com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl of com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler