public class sun.awt.X11.XAWTFormatter extends java.util.logging.Formatter
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.awt.X11.XAWTFormatter
  super_class: java.util.logging.Formatter
{
  java.util.Date dat;
    descriptor: Ljava/util/Date;
    flags: (0x0000) 

  private static final java.lang.String format;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "{0,date} {0,time}"

  private java.text.MessageFormat formatter;
    descriptor: Ljava/text/MessageFormat;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.Object[] args;
    descriptor: [Ljava/lang/Object;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String lineSeparator;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  boolean displayFullRecord;
    descriptor: Z
    flags: (0x0000) 

  boolean useANSI;
    descriptor: Z
    flags: (0x0000) 

  boolean showDate;
    descriptor: Z
    flags: (0x0000) 

  boolean showLevel;
    descriptor: Z
    flags: (0x0000) 

  boolean swapMethodClass;
    descriptor: Z
    flags: (0x0000) 

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // sun.awt.X11.XAWTFormatter this
         0: .line 54
            aload 0 /* this */
            invokespecial java.util.logging.Formatter.<init>:()V
         1: .line 38
            aload 0 /* this */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.awt.X11.XAWTFormatter.dat:Ljava/util/Date;
         2: .line 42
            aload 0 /* this */
            iconst_1
            anewarray java.lang.Object
            putfield sun.awt.X11.XAWTFormatter.args:[Ljava/lang/Object;
         3: .line 46
            aload 0 /* this */
         4: .line 47
            new sun.security.action.GetPropertyAction
            dup
            ldc "line.separator"
            invokespecial sun.security.action.GetPropertyAction.<init>:(Ljava/lang/String;)V
         5: .line 46
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            putfield sun.awt.X11.XAWTFormatter.lineSeparator:Ljava/lang/String;
         6: .line 49
            aload 0 /* this */
            iconst_0
            putfield sun.awt.X11.XAWTFormatter.displayFullRecord:Z
         7: .line 50
            aload 0 /* this */
            iconst_0
            putfield sun.awt.X11.XAWTFormatter.useANSI:Z
         8: .line 51
            aload 0 /* this */
            iconst_1
            putfield sun.awt.X11.XAWTFormatter.showDate:Z
         9: .line 52
            aload 0 /* this */
            iconst_1
            putfield sun.awt.X11.XAWTFormatter.showLevel:Z
        10: .line 53
            aload 0 /* this */
            iconst_0
            putfield sun.awt.X11.XAWTFormatter.swapMethodClass:Z
        11: .line 55
            aload 0 /* this */
            ldc "true"
            invokestatic java.util.logging.LogManager.getLogManager:()Ljava/util/logging/LogManager;
            ldc "XAWTFormatter.displayFullRecord"
            invokevirtual java.util.logging.LogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            putfield sun.awt.X11.XAWTFormatter.displayFullRecord:Z
        12: .line 56
            aload 0 /* this */
            ldc "true"
            invokestatic java.util.logging.LogManager.getLogManager:()Ljava/util/logging/LogManager;
            ldc "XAWTFormatter.useANSI"
            invokevirtual java.util.logging.LogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            putfield sun.awt.X11.XAWTFormatter.useANSI:Z
        13: .line 57
            aload 0 /* this */
            ldc "false"
            invokestatic java.util.logging.LogManager.getLogManager:()Ljava/util/logging/LogManager;
            ldc "XAWTFormatter.showDate"
            invokevirtual java.util.logging.LogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 14
            iconst_0
            goto 15
      StackMap locals: sun.awt.X11.XAWTFormatter
      StackMap stack: sun.awt.X11.XAWTFormatter
        14: iconst_1
      StackMap locals: sun.awt.X11.XAWTFormatter
      StackMap stack: sun.awt.X11.XAWTFormatter int
        15: putfield sun.awt.X11.XAWTFormatter.showDate:Z
        16: .line 58
            aload 0 /* this */
            ldc "false"
            invokestatic java.util.logging.LogManager.getLogManager:()Ljava/util/logging/LogManager;
            ldc "XAWTFormatter.showLevel"
            invokevirtual java.util.logging.LogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 17
            iconst_0
            goto 18
      StackMap locals:
      StackMap stack: sun.awt.X11.XAWTFormatter
        17: iconst_1
      StackMap locals: sun.awt.X11.XAWTFormatter
      StackMap stack: sun.awt.X11.XAWTFormatter int
        18: putfield sun.awt.X11.XAWTFormatter.showLevel:Z
        19: .line 59
            aload 0 /* this */
            ldc "true"
            invokestatic java.util.logging.LogManager.getLogManager:()Ljava/util/logging/LogManager;
            ldc "XAWTFormatter.swapMethodClass"
            invokevirtual java.util.logging.LogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            putfield sun.awt.X11.XAWTFormatter.swapMethodClass:Z
        20: .line 60
            return
        end local 0 // sun.awt.X11.XAWTFormatter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   21     0  this  Lsun/awt/X11/XAWTFormatter;

  public synchronized java.lang.String format(java.util.logging.LogRecord);
    descriptor: (Ljava/util/logging/LogRecord;)Ljava/lang/String;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // sun.awt.X11.XAWTFormatter this
        start local 1 // java.util.logging.LogRecord record
         0: .line 68
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 2 /* sb */
        start local 2 // java.lang.StringBuffer sb
         1: .line 69
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.useANSI:Z
            ifeq 11
         2: .line 70
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getLevel:()Ljava/util/logging/Level;
            astore 3 /* lev */
        start local 3 // java.util.logging.Level lev
         3: .line 71
            getstatic java.util.logging.Level.FINEST:Ljava/util/logging/Level;
            aload 3 /* lev */
            invokevirtual java.util.logging.Level.equals:(Ljava/lang/Object;)Z
            ifeq 6
         4: .line 72
            aload 2 /* sb */
            ldc "\u001B[36m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         5: .line 73
            goto 11
      StackMap locals: java.lang.StringBuffer java.util.logging.Level
      StackMap stack:
         6: getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            aload 3 /* lev */
            invokevirtual java.util.logging.Level.equals:(Ljava/lang/Object;)Z
            ifeq 9
         7: .line 74
            aload 2 /* sb */
            ldc "\u001B[32m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         8: .line 75
            goto 11
      StackMap locals:
      StackMap stack:
         9: getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            aload 3 /* lev */
            invokevirtual java.util.logging.Level.equals:(Ljava/lang/Object;)Z
            ifeq 11
        10: .line 76
            aload 2 /* sb */
            ldc "\u001B[34m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        end local 3 // java.util.logging.Level lev
        11: .line 79
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.displayFullRecord:Z
            ifeq 42
        12: .line 80
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.showDate:Z
            ifeq 22
        13: .line 82
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.dat:Ljava/util/Date;
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getMillis:()J
            invokevirtual java.util.Date.setTime:(J)V
        14: .line 83
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.args:[Ljava/lang/Object;
            iconst_0
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.dat:Ljava/util/Date;
            aastore
        15: .line 84
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 3 /* text */
        start local 3 // java.lang.StringBuffer text
        16: .line 85
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.formatter:Ljava/text/MessageFormat;
            ifnonnull 18
        17: .line 86
            aload 0 /* this */
            new java.text.MessageFormat
            dup
            ldc "{0,date} {0,time}"
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;)V
            putfield sun.awt.X11.XAWTFormatter.formatter:Ljava/text/MessageFormat;
        18: .line 88
      StackMap locals: java.lang.StringBuffer
      StackMap stack:
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.formatter:Ljava/text/MessageFormat;
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.args:[Ljava/lang/Object;
            aload 3 /* text */
            aconst_null
            invokevirtual java.text.MessageFormat.format:([Ljava/lang/Object;Ljava/lang/StringBuffer;Ljava/text/FieldPosition;)Ljava/lang/StringBuffer;
            pop
        19: .line 89
            aload 2 /* sb */
            aload 3 /* text */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/StringBuffer;)Ljava/lang/StringBuffer;
            pop
        20: .line 90
            aload 2 /* sb */
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        end local 3 // java.lang.StringBuffer text
        21: .line 91
            goto 23
        22: .line 92
      StackMap locals:
      StackMap stack:
            aload 2 /* sb */
            ldc "    "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        23: .line 94
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.swapMethodClass:Z
            ifeq 33
        24: .line 95
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getSourceMethodName:()Ljava/lang/String;
            ifnull 28
        25: .line 96
            aload 2 /* sb */
            ldc " \u001B[35m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        26: .line 97
            aload 2 /* sb */
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getSourceMethodName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        27: .line 98
            aload 2 /* sb */
            ldc "\u001B[30m "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        28: .line 100
      StackMap locals:
      StackMap stack:
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getSourceClassName:()Ljava/lang/String;
            ifnull 31
        29: .line 101
            aload 2 /* sb */
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getSourceClassName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        30: .line 102
            goto 41
        31: .line 103
      StackMap locals:
      StackMap stack:
            aload 2 /* sb */
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getLoggerName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        32: .line 105
            goto 41
        33: .line 106
      StackMap locals:
      StackMap stack:
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getSourceClassName:()Ljava/lang/String;
            ifnull 36
        34: .line 107
            aload 2 /* sb */
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getSourceClassName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        35: .line 108
            goto 37
        36: .line 109
      StackMap locals:
      StackMap stack:
            aload 2 /* sb */
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getLoggerName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        37: .line 111
      StackMap locals:
      StackMap stack:
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getSourceMethodName:()Ljava/lang/String;
            ifnull 41
        38: .line 112
            aload 2 /* sb */
            ldc " \u001B[35m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        39: .line 113
            aload 2 /* sb */
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getSourceMethodName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        40: .line 114
            aload 2 /* sb */
            ldc "\u001B[30m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        41: .line 117
      StackMap locals:
      StackMap stack:
            aload 2 /* sb */
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.lineSeparator:Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        42: .line 119
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.useANSI:Z
            ifeq 52
        43: .line 120
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getLevel:()Ljava/util/logging/Level;
            astore 3 /* lev */
        start local 3 // java.util.logging.Level lev
        44: .line 121
            getstatic java.util.logging.Level.FINEST:Ljava/util/logging/Level;
            aload 3 /* lev */
            invokevirtual java.util.logging.Level.equals:(Ljava/lang/Object;)Z
            ifeq 47
        45: .line 122
            aload 2 /* sb */
            ldc "\u001B[36m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        46: .line 123
            goto 52
      StackMap locals: java.util.logging.Level
      StackMap stack:
        47: getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            aload 3 /* lev */
            invokevirtual java.util.logging.Level.equals:(Ljava/lang/Object;)Z
            ifeq 50
        48: .line 124
            aload 2 /* sb */
            ldc "\u001B[32m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        49: .line 125
            goto 52
      StackMap locals:
      StackMap stack:
        50: getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            aload 3 /* lev */
            invokevirtual java.util.logging.Level.equals:(Ljava/lang/Object;)Z
            ifeq 52
        51: .line 126
            aload 2 /* sb */
            ldc "\u001B[34m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        end local 3 // java.util.logging.Level lev
        52: .line 129
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.showLevel:Z
            ifeq 55
        53: .line 130
            aload 2 /* sb */
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getLevel:()Ljava/util/logging/Level;
            invokevirtual java.util.logging.Level.getLocalizedName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        54: .line 131
            aload 2 /* sb */
            ldc ": "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        55: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* record */
            invokevirtual sun.awt.X11.XAWTFormatter.formatMessage:(Ljava/util/logging/LogRecord;)Ljava/lang/String;
            astore 3 /* message */
        start local 3 // java.lang.String message
        56: .line 134
            aload 2 /* sb */
            aload 3 /* message */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        57: .line 135
            aload 2 /* sb */
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.lineSeparator:Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        58: .line 136
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getThrown:()Ljava/lang/Throwable;
            ifnull 66
        59: .line 138
            new java.io.StringWriter
            dup
            invokespecial java.io.StringWriter.<init>:()V
            astore 4 /* sw */
        start local 4 // java.io.StringWriter sw
        60: .line 139
            new java.io.PrintWriter
            dup
            aload 4 /* sw */
            invokespecial java.io.PrintWriter.<init>:(Ljava/io/Writer;)V
            astore 5 /* pw */
        start local 5 // java.io.PrintWriter pw
        61: .line 140
            aload 1 /* record */
            invokevirtual java.util.logging.LogRecord.getThrown:()Ljava/lang/Throwable;
            aload 5 /* pw */
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintWriter;)V
        62: .line 141
            aload 5 /* pw */
            invokevirtual java.io.PrintWriter.close:()V
        63: .line 142
            aload 2 /* sb */
            aload 4 /* sw */
            invokevirtual java.io.StringWriter.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        end local 5 // java.io.PrintWriter pw
        end local 4 // java.io.StringWriter sw
        64: .line 143
            goto 66
      StackMap locals: sun.awt.X11.XAWTFormatter java.util.logging.LogRecord java.lang.StringBuffer java.lang.String
      StackMap stack: java.lang.Exception
        65: pop
        66: .line 146
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.awt.X11.XAWTFormatter.useANSI:Z
            ifeq 68
        67: .line 147
            aload 2 /* sb */
            ldc "\u001B[30m"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        68: .line 149
      StackMap locals:
      StackMap stack:
            aload 2 /* sb */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            areturn
        end local 3 // java.lang.String message
        end local 2 // java.lang.StringBuffer sb
        end local 1 // java.util.logging.LogRecord record
        end local 0 // sun.awt.X11.XAWTFormatter this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   69     0     this  Lsun/awt/X11/XAWTFormatter;
            0   69     1   record  Ljava/util/logging/LogRecord;
            1   69     2       sb  Ljava/lang/StringBuffer;
            3   11     3      lev  Ljava/util/logging/Level;
           16   21     3     text  Ljava/lang/StringBuffer;
           44   52     3      lev  Ljava/util/logging/Level;
           56   69     3  message  Ljava/lang/String;
           60   64     4       sw  Ljava/io/StringWriter;
           61   64     5       pw  Ljava/io/PrintWriter;
      Exception table:
        from    to  target  type
          59    64      65  Class java.lang.Exception
    MethodParameters:
        Name  Flags
      record  
}
SourceFile: "XAWTFormatter.java"