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: .line 470
            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 // com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl this
         0: .line 472
            aload 0 /* this */
            invokespecial java.util.logging.Formatter.<init>:()V
         1: .line 473
            return
        end local 0 // com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl this
      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 // com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl this
        start local 1 // java.util.logging.LogRecord record
         0: .line 477
            aload 1 /* record */
            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 /* loggerName */
        start local 2 // java.lang.String loggerName
         1: .line 478
            aload 0 /* this */
            aload 1 /* record */
            invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.formatMessage:(Ljava/util/logging/LogRecord;)Ljava/lang/String;
            astore 3 /* message */
        start local 3 // java.lang.String message
         2: .line 479
            ldc ""
            astore 4 /* stackTrace */
        start local 4 // java.lang.String stackTrace
         3: .line 480
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getThrown:()Ljava/lang/Throwable;
            astore 5 /* exception */
        start local 5 // java.lang.Throwable exception
         4: .line 481
            aload 5 /* exception */
            ifnull 17
         5: .line 482
            new java.io.StringWriter
            dup
            invokespecial java.io.StringWriter.<init>:()V
            astore 6 /* str */
        start local 6 // java.io.StringWriter str
         6: .line 483
            aconst_null
            astore 7
            aconst_null
            astore 8
         7: new java.io.PrintWriter
            dup
            aload 6 /* str */
            invokespecial java.io.PrintWriter.<init>:(Ljava/io/Writer;)V
            astore 9 /* out */
        start local 9 // java.io.PrintWriter out
         8: .line 484
            aload 9 /* out */
            invokevirtual java.io.PrintWriter.println:()V
         9: .line 485
            aload 5 /* exception */
            aload 9 /* out */
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintWriter;)V
        10: .line 486
            aload 9 /* out */
            ifnull 16
            aload 9 /* out */
            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 /* out */
            ifnull 12
            aload 9 /* out */
            invokevirtual java.io.PrintWriter.close:()V
        end local 9 // java.io.PrintWriter out
      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: .line 487
      StackMap locals:
      StackMap stack:
            aload 6 /* str */
            invokevirtual java.io.StringWriter.toString:()Ljava/lang/String;
            astore 4 /* stackTrace */
        end local 6 // java.io.StringWriter str
        17: .line 490
      StackMap locals:
      StackMap stack:
            aload 1 /* record */
            checkcast com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord
            invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord.getFormatKind:()Lcom/oracle/truffle/polyglot/PolyglotLoggers$ImmutableLogRecord$FormatKind;
            astore 7 /* formatKind */
        start local 7 // com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind formatKind
        18: .line 491
            invokestatic com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl.$SWITCH_TABLE$com$oracle$truffle$polyglot$PolyglotLoggers$ImmutableLogRecord$FormatKind:()[I
            aload 7 /* formatKind */
            invokevirtual com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind.ordinal:()I
            iaload
            tableswitch { // 1 - 3
                    1: 23
                    2: 21
                    3: 19
              default: 25
          }
        19: .line 493
      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 /* loggerName */
            aastore
            dup
            iconst_1
            aload 1 /* record */
            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 /* message */
            aastore
            dup
            iconst_3
            aload 4 /* stackTrace */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 6 /* logEntry */
        start local 6 // java.lang.String logEntry
        20: .line 494
            goto 26
        end local 6 // java.lang.String logEntry
        21: .line 496
      StackMap locals:
      StackMap stack:
            ldc "[%1$s] %2$s%3$s%n"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* loggerName */
            aastore
            dup
            iconst_1
            aload 3 /* message */
            aastore
            dup
            iconst_2
            aload 4 /* stackTrace */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 6 /* logEntry */
        start local 6 // java.lang.String logEntry
        22: .line 497
            goto 26
        end local 6 // java.lang.String logEntry
        23: .line 499
      StackMap locals:
      StackMap stack:
            aload 3 /* message */
            astore 6 /* logEntry */
        start local 6 // java.lang.String logEntry
        24: .line 500
            goto 26
        end local 6 // java.lang.String logEntry
        25: .line 502
      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 /* formatKind */
            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 // java.lang.String logEntry
        26: .line 504
      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 /* logEntry */
            areturn
        end local 7 // com.oracle.truffle.polyglot.PolyglotLoggers$ImmutableLogRecord$FormatKind formatKind
        end local 6 // java.lang.String logEntry
        end local 5 // java.lang.Throwable exception
        end local 4 // java.lang.String stackTrace
        end local 3 // java.lang.String message
        end local 2 // java.lang.String loggerName
        end local 1 // java.util.logging.LogRecord record
        end local 0 // com.oracle.truffle.polyglot.PolyglotLoggers$PolyglotStreamHandler$FormatterImpl this
      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 // java.lang.String loggerName
         0: .line 510
            aload 0 /* loggerName */
            bipush 46
            invokevirtual java.lang.String.indexOf:(I)I
            istore 3 /* index */
        start local 3 // int index
         1: .line 511
            iload 3 /* index */
            ifge 5
         2: .line 512
            aload 0 /* loggerName */
            astore 1 /* id */
        start local 1 // java.lang.String id
         3: .line 513
            ldc ""
            astore 2 /* name */
        start local 2 // java.lang.String name
         4: .line 514
            goto 7
        end local 2 // java.lang.String name
        end local 1 // java.lang.String id
         5: .line 515
      StackMap locals: java.lang.String top top int
      StackMap stack:
            aload 0 /* loggerName */
            iconst_0
            iload 3 /* index */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 1 /* id */
        start local 1 // java.lang.String id
         6: .line 516
            aload 0 /* loggerName */
            iload 3 /* index */
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 2 /* name */
        start local 2 // java.lang.String name
         7: .line 518
      StackMap locals: java.lang.String java.lang.String java.lang.String int
      StackMap stack:
            aload 2 /* name */
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 9
         8: .line 519
            aload 1 /* id */
            areturn
         9: .line 521
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 1 /* id */
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 4 /* sb */
        start local 4 // java.lang.StringBuilder sb
        10: .line 522
            aload 4 /* sb */
            ldc "::"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        11: .line 523
            aload 4 /* sb */
            aload 2 /* name */
            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: .line 524
            aload 4 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 4 // java.lang.StringBuilder sb
        end local 3 // int index
        end local 2 // java.lang.String name
        end local 1 // java.lang.String id
        end local 0 // java.lang.String loggerName
      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 // java.lang.String loggerName
         0: .line 528
            iconst_m1
            istore 1 /* index */
        start local 1 // int index
         1: .line 529
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         2: goto 7
         3: .line 530
      StackMap locals: int int
      StackMap stack:
            iload 2 /* i */
            iconst_1
            iadd
            aload 0 /* loggerName */
            invokevirtual java.lang.String.length:()I
            if_icmpge 6
            aload 0 /* loggerName */
            iload 2 /* i */
            iconst_1
            iadd
            invokevirtual java.lang.String.charAt:(I)C
            invokestatic java.lang.Character.isUpperCase:(C)Z
            ifeq 6
         4: .line 531
            iload 2 /* i */
            iconst_1
            iadd
            istore 1 /* index */
         5: .line 532
            goto 8
         6: .line 529
      StackMap locals:
      StackMap stack:
            aload 0 /* loggerName */
            bipush 46
            iload 2 /* i */
            iconst_1
            iadd
            invokevirtual java.lang.String.indexOf:(II)I
            istore 2 /* i */
      StackMap locals:
      StackMap stack:
         7: iload 2 /* i */
            ifge 3
        end local 2 // int i
         8: .line 535
      StackMap locals:
      StackMap stack:
            iload 1 /* index */
            ifge 9
            aload 0 /* loggerName */
            goto 10
      StackMap locals:
      StackMap stack:
         9: aload 0 /* loggerName */
            iload 1 /* index */
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
      StackMap locals:
      StackMap stack: java.lang.String
        10: areturn
        end local 1 // int index
        end local 0 // java.lang.String loggerName
      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: .line 467
            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