class org.apache.logging.log4j.core.message.ExtendedThreadInformation implements org.apache.logging.log4j.message.ThreadInformation
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.apache.logging.log4j.core.message.ExtendedThreadInformation
  super_class: java.lang.Object
{
  private final java.lang.management.ThreadInfo threadInfo;
    descriptor: Ljava/lang/management/ThreadInfo;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private static volatile int[] $SWITCH_TABLE$java$lang$Thread$State;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  void <init>(java.lang.management.ThreadInfo);
    descriptor: (Ljava/lang/management/ThreadInfo;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
        start local 1 // java.lang.management.ThreadInfo thread
         0: .line 34
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 35
            aload 0 /* this */
            aload 1 /* thread */
            putfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
         2: .line 36
            return
        end local 1 // java.lang.management.ThreadInfo thread
        end local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/apache/logging/log4j/core/message/ExtendedThreadInformation;
            0    3     1  thread  Ljava/lang/management/ThreadInfo;
    MethodParameters:
        Name  Flags
      thread  final

  public void printThreadInfo(java.lang.StringBuilder);
    descriptor: (Ljava/lang/StringBuilder;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
        start local 1 // java.lang.StringBuilder sb
         0: .line 40
            aload 1 /* sb */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getThreadName:()Ljava/lang/String;
            invokestatic org.apache.logging.log4j.util.StringBuilders.appendDqValue:(Ljava/lang/StringBuilder;Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         1: .line 41
            aload 1 /* sb */
            ldc " Id="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getThreadId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         2: .line 42
            aload 0 /* this */
            aload 1 /* sb */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual org.apache.logging.log4j.core.message.ExtendedThreadInformation.formatState:(Ljava/lang/StringBuilder;Ljava/lang/management/ThreadInfo;)V
         3: .line 43
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.isSuspended:()Z
            ifeq 5
         4: .line 44
            aload 1 /* sb */
            ldc " (suspended)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         5: .line 46
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.isInNative:()Z
            ifeq 7
         6: .line 47
            aload 1 /* sb */
            ldc " (in native)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         7: .line 49
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         8: .line 50
            return
        end local 1 // java.lang.StringBuilder sb
        end local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/apache/logging/log4j/core/message/ExtendedThreadInformation;
            0    9     1    sb  Ljava/lang/StringBuilder;
    MethodParameters:
      Name  Flags
      sb    final

  public void printStack(java.lang.StringBuilder, java.lang.StackTraceElement[]);
    descriptor: (Ljava/lang/StringBuilder;[Ljava/lang/StackTraceElement;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=12, args_size=3
        start local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
        start local 1 // java.lang.StringBuilder sb
        start local 2 // java.lang.StackTraceElement[] stack
         0: .line 54
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         1: .line 55
            aload 2 /* stack */
            dup
            astore 7
            arraylength
            istore 6
            iconst_0
            istore 5
            goto 29
      StackMap locals: org.apache.logging.log4j.core.message.ExtendedThreadInformation java.lang.StringBuilder java.lang.StackTraceElement[] int top int int java.lang.StackTraceElement[]
      StackMap stack:
         2: aload 7
            iload 5
            aaload
            astore 4 /* element */
        start local 4 // java.lang.StackTraceElement element
         3: .line 56
            aload 1 /* sb */
            ldc "\tat "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* element */
            invokevirtual java.lang.StackTraceElement.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 57
            aload 1 /* sb */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         5: .line 58
            iload 3 /* i */
            ifne 19
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getLockInfo:()Ljava/lang/management/LockInfo;
            ifnull 19
         6: .line 59
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getThreadState:()Ljava/lang/Thread$State;
            astore 8 /* ts */
        start local 8 // java.lang.Thread$State ts
         7: .line 60
            invokestatic org.apache.logging.log4j.core.message.ExtendedThreadInformation.$SWITCH_TABLE$java$lang$Thread$State:()[I
            aload 8 /* ts */
            invokevirtual java.lang.Thread$State.ordinal:()I
            iaload
            tableswitch { // 3 - 5
                    3: 8
                    4: 12
                    5: 16
              default: 19
          }
         8: .line 62
      StackMap locals: org.apache.logging.log4j.core.message.ExtendedThreadInformation java.lang.StringBuilder java.lang.StackTraceElement[] int java.lang.StackTraceElement int int java.lang.StackTraceElement[] java.lang.Thread$State
      StackMap stack:
            aload 1 /* sb */
            ldc "\t-  blocked on "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         9: .line 63
            aload 0 /* this */
            aload 1 /* sb */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getLockInfo:()Ljava/lang/management/LockInfo;
            invokevirtual org.apache.logging.log4j.core.message.ExtendedThreadInformation.formatLock:(Ljava/lang/StringBuilder;Ljava/lang/management/LockInfo;)V
        10: .line 64
            aload 1 /* sb */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        11: .line 65
            goto 19
        12: .line 67
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            ldc "\t-  waiting on "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        13: .line 68
            aload 0 /* this */
            aload 1 /* sb */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getLockInfo:()Ljava/lang/management/LockInfo;
            invokevirtual org.apache.logging.log4j.core.message.ExtendedThreadInformation.formatLock:(Ljava/lang/StringBuilder;Ljava/lang/management/LockInfo;)V
        14: .line 69
            aload 1 /* sb */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        15: .line 70
            goto 19
        16: .line 72
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            ldc "\t-  waiting on "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        17: .line 73
            aload 0 /* this */
            aload 1 /* sb */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getLockInfo:()Ljava/lang/management/LockInfo;
            invokevirtual org.apache.logging.log4j.core.message.ExtendedThreadInformation.formatLock:(Ljava/lang/StringBuilder;Ljava/lang/management/LockInfo;)V
        18: .line 74
            aload 1 /* sb */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        end local 8 // java.lang.Thread$State ts
        19: .line 80
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getLockedMonitors:()[Ljava/lang/management/MonitorInfo;
            dup
            astore 11
            arraylength
            istore 10
            iconst_0
            istore 9
            goto 26
      StackMap locals: org.apache.logging.log4j.core.message.ExtendedThreadInformation java.lang.StringBuilder java.lang.StackTraceElement[] int java.lang.StackTraceElement int int java.lang.StackTraceElement[] top int int java.lang.management.MonitorInfo[]
      StackMap stack:
        20: aload 11
            iload 9
            aaload
            astore 8 /* mi */
        start local 8 // java.lang.management.MonitorInfo mi
        21: .line 81
            aload 8 /* mi */
            invokevirtual java.lang.management.MonitorInfo.getLockedStackDepth:()I
            iload 3 /* i */
            if_icmpne 25
        22: .line 82
            aload 1 /* sb */
            ldc "\t-  locked "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        23: .line 83
            aload 0 /* this */
            aload 1 /* sb */
            aload 8 /* mi */
            invokevirtual org.apache.logging.log4j.core.message.ExtendedThreadInformation.formatLock:(Ljava/lang/StringBuilder;Ljava/lang/management/LockInfo;)V
        24: .line 84
            aload 1 /* sb */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        end local 8 // java.lang.management.MonitorInfo mi
        25: .line 80
      StackMap locals:
      StackMap stack:
            iinc 9 1
      StackMap locals:
      StackMap stack:
        26: iload 9
            iload 10
            if_icmplt 20
        27: .line 87
            iinc 3 /* i */ 1
        end local 4 // java.lang.StackTraceElement element
        28: .line 55
            iinc 5 1
      StackMap locals: org.apache.logging.log4j.core.message.ExtendedThreadInformation java.lang.StringBuilder java.lang.StackTraceElement[] int top int int java.lang.StackTraceElement[]
      StackMap stack:
        29: iload 5
            iload 6
            if_icmplt 2
        30: .line 90
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.message.ExtendedThreadInformation.threadInfo:Ljava/lang/management/ThreadInfo;
            invokevirtual java.lang.management.ThreadInfo.getLockedSynchronizers:()[Ljava/lang/management/LockInfo;
            astore 4 /* locks */
        start local 4 // java.lang.management.LockInfo[] locks
        31: .line 91
            aload 4 /* locks */
            arraylength
            ifle 40
        32: .line 92
            aload 1 /* sb */
            ldc "\n\tNumber of locked synchronizers = "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* locks */
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        33: .line 93
            aload 4 /* locks */
            dup
            astore 8
            arraylength
            istore 7
            iconst_0
            istore 6
            goto 39
      StackMap locals: org.apache.logging.log4j.core.message.ExtendedThreadInformation java.lang.StringBuilder java.lang.StackTraceElement[] int java.lang.management.LockInfo[] top int int java.lang.management.LockInfo[]
      StackMap stack:
        34: aload 8
            iload 6
            aaload
            astore 5 /* li */
        start local 5 // java.lang.management.LockInfo li
        35: .line 94
            aload 1 /* sb */
            ldc "\t- "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        36: .line 95
            aload 0 /* this */
            aload 1 /* sb */
            aload 5 /* li */
            invokevirtual org.apache.logging.log4j.core.message.ExtendedThreadInformation.formatLock:(Ljava/lang/StringBuilder;Ljava/lang/management/LockInfo;)V
        37: .line 96
            aload 1 /* sb */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        end local 5 // java.lang.management.LockInfo li
        38: .line 93
            iinc 6 1
      StackMap locals:
      StackMap stack:
        39: iload 6
            iload 7
            if_icmplt 34
        40: .line 99
      StackMap locals: org.apache.logging.log4j.core.message.ExtendedThreadInformation java.lang.StringBuilder java.lang.StackTraceElement[] int java.lang.management.LockInfo[]
      StackMap stack:
            return
        end local 4 // java.lang.management.LockInfo[] locks
        end local 3 // int i
        end local 2 // java.lang.StackTraceElement[] stack
        end local 1 // java.lang.StringBuilder sb
        end local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   41     0     this  Lorg/apache/logging/log4j/core/message/ExtendedThreadInformation;
            0   41     1       sb  Ljava/lang/StringBuilder;
            0   41     2    stack  [Ljava/lang/StackTraceElement;
            1   41     3        i  I
            3   28     4  element  Ljava/lang/StackTraceElement;
            7   19     8       ts  Ljava/lang/Thread$State;
           21   25     8       mi  Ljava/lang/management/MonitorInfo;
           31   41     4    locks  [Ljava/lang/management/LockInfo;
           35   38     5       li  Ljava/lang/management/LockInfo;
    MethodParameters:
       Name  Flags
      sb     final
      stack  final

  private void formatLock(java.lang.StringBuilder, java.lang.management.LockInfo);
    descriptor: (Ljava/lang/StringBuilder;Ljava/lang/management/LockInfo;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
        start local 1 // java.lang.StringBuilder sb
        start local 2 // java.lang.management.LockInfo lock
         0: .line 102
            aload 1 /* sb */
            bipush 60
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            aload 2 /* lock */
            invokevirtual java.lang.management.LockInfo.getIdentityHashCode:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "> (a "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         1: .line 103
            aload 1 /* sb */
            aload 2 /* lock */
            invokevirtual java.lang.management.LockInfo.getClassName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         2: .line 104
            return
        end local 2 // java.lang.management.LockInfo lock
        end local 1 // java.lang.StringBuilder sb
        end local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/message/ExtendedThreadInformation;
            0    3     1    sb  Ljava/lang/StringBuilder;
            0    3     2  lock  Ljava/lang/management/LockInfo;
    MethodParameters:
      Name  Flags
      sb    final
      lock  final

  private void formatState(java.lang.StringBuilder, java.lang.management.ThreadInfo);
    descriptor: (Ljava/lang/StringBuilder;Ljava/lang/management/ThreadInfo;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=7, args_size=3
        start local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
        start local 1 // java.lang.StringBuilder sb
        start local 2 // java.lang.management.ThreadInfo info
         0: .line 107
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getThreadState:()Ljava/lang/Thread$State;
            astore 3 /* state */
        start local 3 // java.lang.Thread$State state
         1: .line 108
            aload 1 /* sb */
            aload 3 /* state */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         2: .line 109
            invokestatic org.apache.logging.log4j.core.message.ExtendedThreadInformation.$SWITCH_TABLE$java$lang$Thread$State:()[I
            aload 3 /* state */
            invokevirtual java.lang.Thread$State.ordinal:()I
            iaload
            tableswitch { // 3 - 5
                    3: 3
                    4: 6
                    5: 25
              default: 47
          }
         3: .line 111
      StackMap locals: java.lang.Thread$State
      StackMap stack:
            aload 1 /* sb */
            ldc " (on object monitor owned by \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 112
            aload 1 /* sb */
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\" Id="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         5: .line 113
            goto 47
         6: .line 116
      StackMap locals:
      StackMap stack:
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getStackTrace:()[Ljava/lang/StackTraceElement;
            iconst_0
            aaload
            astore 4 /* element */
        start local 4 // java.lang.StackTraceElement element
         7: .line 117
            aload 4 /* element */
            invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
            astore 5 /* className */
        start local 5 // java.lang.String className
         8: .line 118
            aload 4 /* element */
            invokevirtual java.lang.StackTraceElement.getMethodName:()Ljava/lang/String;
            astore 6 /* method */
        start local 6 // java.lang.String method
         9: .line 119
            aload 5 /* className */
            ldc "java.lang.Object"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 16
            aload 6 /* method */
            ldc "wait"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 16
        10: .line 120
            aload 1 /* sb */
            ldc " (on object monitor"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        11: .line 121
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            ifnull 14
        12: .line 122
            aload 1 /* sb */
            ldc " owned by \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        13: .line 123
            aload 1 /* sb */
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\" Id="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            pop
        14: .line 125
      StackMap locals: java.lang.StackTraceElement java.lang.String java.lang.String
      StackMap stack:
            aload 1 /* sb */
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        15: .line 126
            goto 47
      StackMap locals:
      StackMap stack:
        16: aload 5 /* className */
            ldc "java.lang.Thread"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 19
            aload 6 /* method */
            ldc "join"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 19
        17: .line 127
            aload 1 /* sb */
            ldc " (on completion of thread "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        18: .line 128
            goto 47
        19: .line 129
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            ldc " (parking for lock"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        20: .line 130
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            ifnull 23
        21: .line 131
            aload 1 /* sb */
            ldc " owned by \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        22: .line 132
            aload 1 /* sb */
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\" Id="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            pop
        23: .line 134
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        24: .line 136
            goto 47
        end local 6 // java.lang.String method
        end local 5 // java.lang.String className
        end local 4 // java.lang.StackTraceElement element
        25: .line 139
      StackMap locals:
      StackMap stack:
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getStackTrace:()[Ljava/lang/StackTraceElement;
            iconst_0
            aaload
            astore 4 /* element */
        start local 4 // java.lang.StackTraceElement element
        26: .line 140
            aload 4 /* element */
            invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
            astore 5 /* className */
        start local 5 // java.lang.String className
        27: .line 141
            aload 4 /* element */
            invokevirtual java.lang.StackTraceElement.getMethodName:()Ljava/lang/String;
            astore 6 /* method */
        start local 6 // java.lang.String method
        28: .line 142
            aload 5 /* className */
            ldc "java.lang.Object"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 35
            aload 6 /* method */
            ldc "wait"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 35
        29: .line 143
            aload 1 /* sb */
            ldc " (on object monitor"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        30: .line 144
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            ifnull 33
        31: .line 145
            aload 1 /* sb */
            ldc " owned by \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        32: .line 146
            aload 1 /* sb */
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\" Id="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            pop
        33: .line 148
      StackMap locals: java.lang.StackTraceElement java.lang.String java.lang.String
      StackMap stack:
            aload 1 /* sb */
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        34: .line 149
            goto 47
      StackMap locals:
      StackMap stack:
        35: aload 5 /* className */
            ldc "java.lang.Thread"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 38
            aload 6 /* method */
            ldc "sleep"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 38
        36: .line 150
            aload 1 /* sb */
            ldc " (sleeping)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        37: .line 151
            goto 47
      StackMap locals:
      StackMap stack:
        38: aload 5 /* className */
            ldc "java.lang.Thread"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 41
            aload 6 /* method */
            ldc "join"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 41
        39: .line 152
            aload 1 /* sb */
            ldc " (on completion of thread "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        40: .line 153
            goto 47
        41: .line 154
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            ldc " (parking for lock"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        42: .line 155
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            ifnull 45
        43: .line 156
            aload 1 /* sb */
            ldc " owned by \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        44: .line 157
            aload 1 /* sb */
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\" Id="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* info */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            pop
        45: .line 159
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        46: .line 161
            goto 47
        end local 6 // java.lang.String method
        end local 5 // java.lang.String className
        end local 4 // java.lang.StackTraceElement element
        47: .line 166
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.Thread$State state
        end local 2 // java.lang.management.ThreadInfo info
        end local 1 // java.lang.StringBuilder sb
        end local 0 // org.apache.logging.log4j.core.message.ExtendedThreadInformation this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   48     0       this  Lorg/apache/logging/log4j/core/message/ExtendedThreadInformation;
            0   48     1         sb  Ljava/lang/StringBuilder;
            0   48     2       info  Ljava/lang/management/ThreadInfo;
            1   48     3      state  Ljava/lang/Thread$State;
            7   25     4    element  Ljava/lang/StackTraceElement;
            8   25     5  className  Ljava/lang/String;
            9   25     6     method  Ljava/lang/String;
           26   47     4    element  Ljava/lang/StackTraceElement;
           27   47     5  className  Ljava/lang/String;
           28   47     6     method  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      sb    final
      info  final

  static int[] $SWITCH_TABLE$java$lang$Thread$State();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 30
            getstatic org.apache.logging.log4j.core.message.ExtendedThreadInformation.$SWITCH_TABLE$java$lang$Thread$State:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic java.lang.Thread$State.values:()[Ljava/lang/Thread$State;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic java.lang.Thread$State.BLOCKED:Ljava/lang/Thread$State;
            invokevirtual java.lang.Thread$State.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 java.lang.Thread$State.NEW:Ljava/lang/Thread$State;
            invokevirtual java.lang.Thread$State.ordinal:()I
            iconst_1
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic java.lang.Thread$State.RUNNABLE:Ljava/lang/Thread$State;
            invokevirtual java.lang.Thread$State.ordinal:()I
            iconst_2
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            getstatic java.lang.Thread$State.TERMINATED:Ljava/lang/Thread$State;
            invokevirtual java.lang.Thread$State.ordinal:()I
            bipush 6
            iastore
        12: goto 14
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        13: pop
      StackMap locals:
      StackMap stack:
        14: aload 0
            getstatic java.lang.Thread$State.TIMED_WAITING:Ljava/lang/Thread$State;
            invokevirtual java.lang.Thread$State.ordinal:()I
            iconst_5
            iastore
        15: goto 17
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        16: pop
      StackMap locals:
      StackMap stack:
        17: aload 0
            getstatic java.lang.Thread$State.WAITING:Ljava/lang/Thread$State;
            invokevirtual java.lang.Thread$State.ordinal:()I
            iconst_4
            iastore
        18: goto 20
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        19: pop
      StackMap locals:
      StackMap stack:
        20: aload 0
            dup
            putstatic org.apache.logging.log4j.core.message.ExtendedThreadInformation.$SWITCH_TABLE$java$lang$Thread$State:[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
          11    12      13  Class java.lang.NoSuchFieldError
          14    15      16  Class java.lang.NoSuchFieldError
          17    18      19  Class java.lang.NoSuchFieldError
}
SourceFile: "ExtendedThreadInformation.java"
InnerClasses:
  public final State = java.lang.Thread$State of java.lang.Thread