public class org.apache.juli.ClassLoaderLogManager extends java.util.logging.LogManager
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.juli.ClassLoaderLogManager
  super_class: java.util.logging.LogManager
{
  private static final boolean isJava9;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static java.lang.ThreadLocal<java.lang.Boolean> addingLocalRootLogger;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Signature: Ljava/lang/ThreadLocal<Ljava/lang/Boolean;>;

  public static final java.lang.String DEBUG_PROPERTY;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  protected final java.util.Map<java.lang.ClassLoader, org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo> classLoaderLoggers;
    descriptor: Ljava/util/Map;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/ClassLoader;Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;>;

  protected final java.lang.ThreadLocal<java.lang.String> prefix;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Ljava/lang/String;>;

  protected volatile boolean useShutdownHook;
    descriptor: Z
    flags: (0x0044) ACC_PROTECTED, ACC_VOLATILE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 56
            new org.apache.juli.ClassLoaderLogManager$1
            dup
            invokespecial org.apache.juli.ClassLoaderLogManager$1.<init>:()V
            putstatic org.apache.juli.ClassLoaderLogManager.addingLocalRootLogger:Ljava/lang/ThreadLocal;
         1: .line 64
            new java.lang.StringBuilder
            dup
            ldc Lorg/apache/juli/ClassLoaderLogManager;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".debug"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         2: .line 63
            putstatic org.apache.juli.ClassLoaderLogManager.DEBUG_PROPERTY:Ljava/lang/String;
         3: .line 67
            aconst_null
            astore 0 /* c */
        start local 0 // java.lang.Class c
         4: .line 69
            ldc "java.lang.Runtime$Version"
            invokestatic java.lang.Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
            astore 0 /* c */
         5: .line 70
            goto 7
      StackMap locals: java.lang.Class
      StackMap stack: java.lang.ClassNotFoundException
         6: pop
         7: .line 73
      StackMap locals:
      StackMap stack:
            aload 0 /* c */
            ifnull 8
            iconst_1
            goto 9
      StackMap locals:
      StackMap stack:
         8: iconst_0
      StackMap locals:
      StackMap stack: int
         9: putstatic org.apache.juli.ClassLoaderLogManager.isJava9:Z
        end local 0 // java.lang.Class c
        10: .line 74
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            4   10     0     c  Ljava/lang/Class<*>;
      Exception table:
        from    to  target  type
           4     5       6  Class java.lang.ClassNotFoundException

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.apache.juli.ClassLoaderLogManager this
         0: .line 91
            aload 0 /* this */
            invokespecial java.util.logging.LogManager.<init>:()V
         1: .line 108
            aload 0 /* this */
         2: .line 109
            new java.util.WeakHashMap
            dup
            invokespecial java.util.WeakHashMap.<init>:()V
            putfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
         3: .line 116
            aload 0 /* this */
            new java.lang.ThreadLocal
            dup
            invokespecial java.lang.ThreadLocal.<init>:()V
            putfield org.apache.juli.ClassLoaderLogManager.prefix:Ljava/lang/ThreadLocal;
         4: .line 125
            aload 0 /* this */
            iconst_1
            putfield org.apache.juli.ClassLoaderLogManager.useShutdownHook:Z
         5: .line 93
            invokestatic java.lang.Runtime.getRuntime:()Ljava/lang/Runtime;
            new org.apache.juli.ClassLoaderLogManager$Cleaner
            dup
            aload 0 /* this */
            invokespecial org.apache.juli.ClassLoaderLogManager$Cleaner.<init>:(Lorg/apache/juli/ClassLoaderLogManager;)V
            invokevirtual java.lang.Runtime.addShutdownHook:(Ljava/lang/Thread;)V
         6: .line 94
            goto 8
      StackMap locals: org.apache.juli.ClassLoaderLogManager
      StackMap stack: java.lang.IllegalStateException
         7: pop
         8: .line 97
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/apache/juli/ClassLoaderLogManager;
      Exception table:
        from    to  target  type
           5     6       7  Class java.lang.IllegalStateException

  public boolean isUseShutdownHook();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.juli.ClassLoaderLogManager this
         0: .line 132
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.useShutdownHook:Z
            ireturn
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/juli/ClassLoaderLogManager;

  public void setUseShutdownHook(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // boolean useShutdownHook
         0: .line 137
            aload 0 /* this */
            iload 1 /* useShutdownHook */
            putfield org.apache.juli.ClassLoaderLogManager.useShutdownHook:Z
         1: .line 138
            return
        end local 1 // boolean useShutdownHook
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Lorg/apache/juli/ClassLoaderLogManager;
            0    2     1  useShutdownHook  Z
    MethodParameters:
                 Name  Flags
      useShutdownHook  

  public synchronized boolean addLogger(java.util.logging.Logger);
    descriptor: (Ljava/util/logging/Logger;)Z
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=14, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.util.logging.Logger logger
         0: .line 152
            aload 1 /* logger */
            invokevirtual java.util.logging.Logger.getName:()Ljava/lang/String;
            astore 2 /* loggerName */
        start local 2 // java.lang.String loggerName
         1: .line 155
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
         2: .line 154
            astore 3 /* classLoader */
        start local 3 // java.lang.ClassLoader classLoader
         3: .line 156
            aload 0 /* this */
            aload 3 /* classLoader */
            invokevirtual org.apache.juli.ClassLoaderLogManager.getClassLoaderInfo:(Ljava/lang/ClassLoader;)Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            astore 4 /* info */
        start local 4 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
         4: .line 157
            aload 4 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.loggers:Ljava/util/Map;
            aload 2 /* loggerName */
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ifeq 6
         5: .line 158
            iconst_0
            ireturn
         6: .line 160
      StackMap locals: java.lang.String java.lang.ClassLoader org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
      StackMap stack:
            aload 4 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.loggers:Ljava/util/Map;
            aload 2 /* loggerName */
            aload 1 /* logger */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 163
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            aload 2 /* loggerName */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".level"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.juli.ClassLoaderLogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 5 /* levelString */
        start local 5 // java.lang.String levelString
         8: .line 164
            aload 5 /* levelString */
            ifnull 12
         9: .line 166
            new org.apache.juli.ClassLoaderLogManager$2
            dup
            aload 0 /* this */
            aload 1 /* logger */
            aload 5 /* levelString */
            invokespecial org.apache.juli.ClassLoaderLogManager$2.<init>:(Lorg/apache/juli/ClassLoaderLogManager;Ljava/util/logging/Logger;Ljava/lang/String;)V
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            pop
        10: .line 173
            goto 12
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.util.logging.Logger java.lang.String java.lang.ClassLoader org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo java.lang.String
      StackMap stack: java.lang.IllegalArgumentException
        11: pop
        12: .line 180
      StackMap locals:
      StackMap stack:
            aload 2 /* loggerName */
            bipush 46
            invokevirtual java.lang.String.lastIndexOf:(I)I
            istore 6 /* dotIndex */
        start local 6 // int dotIndex
        13: .line 181
            iload 6 /* dotIndex */
            iflt 16
        14: .line 182
            aload 2 /* loggerName */
            iconst_0
            iload 6 /* dotIndex */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 7 /* parentName */
        start local 7 // java.lang.String parentName
        15: .line 183
            aload 7 /* parentName */
            invokestatic java.util.logging.Logger.getLogger:(Ljava/lang/String;)Ljava/util/logging/Logger;
            pop
        end local 7 // java.lang.String parentName
        16: .line 187
      StackMap locals: int
      StackMap stack:
            aload 4 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.rootNode:Lorg/apache/juli/ClassLoaderLogManager$LogNode;
            aload 2 /* loggerName */
            invokevirtual org.apache.juli.ClassLoaderLogManager$LogNode.findNode:(Ljava/lang/String;)Lorg/apache/juli/ClassLoaderLogManager$LogNode;
            astore 7 /* node */
        start local 7 // org.apache.juli.ClassLoaderLogManager$LogNode node
        17: .line 188
            aload 7 /* node */
            aload 1 /* logger */
            putfield org.apache.juli.ClassLoaderLogManager$LogNode.logger:Ljava/util/logging/Logger;
        18: .line 191
            aload 7 /* node */
            invokevirtual org.apache.juli.ClassLoaderLogManager$LogNode.findParentLogger:()Ljava/util/logging/Logger;
            astore 8 /* parentLogger */
        start local 8 // java.util.logging.Logger parentLogger
        19: .line 192
            aload 8 /* parentLogger */
            ifnull 21
        20: .line 193
            aload 1 /* logger */
            aload 8 /* parentLogger */
            invokestatic org.apache.juli.ClassLoaderLogManager.doSetParentLogger:(Ljava/util/logging/Logger;Ljava/util/logging/Logger;)V
        21: .line 197
      StackMap locals: org.apache.juli.ClassLoaderLogManager$LogNode java.util.logging.Logger
      StackMap stack:
            aload 7 /* node */
            aload 1 /* logger */
            invokevirtual org.apache.juli.ClassLoaderLogManager$LogNode.setParentLogger:(Ljava/util/logging/Logger;)V
        22: .line 201
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            aload 2 /* loggerName */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".handlers"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.juli.ClassLoaderLogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 9 /* handlers */
        start local 9 // java.lang.String handlers
        23: .line 202
            aload 9 /* handlers */
            ifnull 41
        24: .line 203
            aload 1 /* logger */
            iconst_0
            invokevirtual java.util.logging.Logger.setUseParentHandlers:(Z)V
        25: .line 204
            new java.util.StringTokenizer
            dup
            aload 9 /* handlers */
            ldc ","
            invokespecial java.util.StringTokenizer.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            astore 10 /* tok */
        start local 10 // java.util.StringTokenizer tok
        26: .line 205
            goto 40
        27: .line 206
      StackMap locals: java.lang.String java.util.StringTokenizer
      StackMap stack:
            aload 10 /* tok */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            astore 11 /* handlerName */
        start local 11 // java.lang.String handlerName
        28: .line 207
            aconst_null
            astore 12 /* handler */
        start local 12 // java.util.logging.Handler handler
        29: .line 208
            aload 3 /* classLoader */
            astore 13 /* current */
        start local 13 // java.lang.ClassLoader current
        30: .line 209
            goto 37
        31: .line 210
      StackMap locals: java.lang.String java.util.logging.Handler java.lang.ClassLoader
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
            aload 13 /* current */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
            astore 4 /* info */
        32: .line 211
            aload 4 /* info */
            ifnull 36
        33: .line 212
            aload 4 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.handlers:Ljava/util/Map;
            aload 11 /* handlerName */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.logging.Handler
            astore 12 /* handler */
        34: .line 213
            aload 12 /* handler */
            ifnull 36
        35: .line 214
            goto 38
        36: .line 217
      StackMap locals:
      StackMap stack:
            aload 13 /* current */
            invokevirtual java.lang.ClassLoader.getParent:()Ljava/lang/ClassLoader;
            astore 13 /* current */
        37: .line 209
      StackMap locals:
      StackMap stack:
            aload 13 /* current */
            ifnonnull 31
        38: .line 219
      StackMap locals:
      StackMap stack:
            aload 12 /* handler */
            ifnull 40
        39: .line 220
            aload 1 /* logger */
            aload 12 /* handler */
            invokevirtual java.util.logging.Logger.addHandler:(Ljava/util/logging/Handler;)V
        end local 13 // java.lang.ClassLoader current
        end local 12 // java.util.logging.Handler handler
        end local 11 // java.lang.String handlerName
        40: .line 205
      StackMap locals:
      StackMap stack:
            aload 10 /* tok */
            invokevirtual java.util.StringTokenizer.hasMoreTokens:()Z
            ifne 27
        end local 10 // java.util.StringTokenizer tok
        41: .line 228
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            aload 2 /* loggerName */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".useParentHandlers"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.juli.ClassLoaderLogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 10 /* useParentHandlersString */
        start local 10 // java.lang.String useParentHandlersString
        42: .line 229
            aload 10 /* useParentHandlersString */
            invokestatic java.lang.Boolean.parseBoolean:(Ljava/lang/String;)Z
            ifeq 44
        43: .line 230
            aload 1 /* logger */
            iconst_1
            invokevirtual java.util.logging.Logger.setUseParentHandlers:(Z)V
        44: .line 233
      StackMap locals: java.lang.String
      StackMap stack:
            iconst_1
            ireturn
        end local 10 // java.lang.String useParentHandlersString
        end local 9 // java.lang.String handlers
        end local 8 // java.util.logging.Logger parentLogger
        end local 7 // org.apache.juli.ClassLoaderLogManager$LogNode node
        end local 6 // int dotIndex
        end local 5 // java.lang.String levelString
        end local 4 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        end local 3 // java.lang.ClassLoader classLoader
        end local 2 // java.lang.String loggerName
        end local 1 // java.util.logging.Logger logger
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            0   45     0                     this  Lorg/apache/juli/ClassLoaderLogManager;
            0   45     1                   logger  Ljava/util/logging/Logger;
            1   45     2               loggerName  Ljava/lang/String;
            3   45     3              classLoader  Ljava/lang/ClassLoader;
            4   45     4                     info  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            8   45     5              levelString  Ljava/lang/String;
           13   45     6                 dotIndex  I
           15   16     7               parentName  Ljava/lang/String;
           17   45     7                     node  Lorg/apache/juli/ClassLoaderLogManager$LogNode;
           19   45     8             parentLogger  Ljava/util/logging/Logger;
           23   45     9                 handlers  Ljava/lang/String;
           26   41    10                      tok  Ljava/util/StringTokenizer;
           28   40    11              handlerName  Ljava/lang/String;
           29   40    12                  handler  Ljava/util/logging/Handler;
           30   40    13                  current  Ljava/lang/ClassLoader;
           42   45    10  useParentHandlersString  Ljava/lang/String;
      Exception table:
        from    to  target  type
           9    10      11  Class java.lang.IllegalArgumentException
    MethodParameters:
        Name  Flags
      logger  final

  public synchronized java.util.logging.Logger getLogger(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/logging/Logger;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.lang.String name
         0: .line 248
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
         1: .line 249
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
         2: .line 248
            astore 2 /* classLoader */
        start local 2 // java.lang.ClassLoader classLoader
         3: .line 250
            aload 0 /* this */
            aload 2 /* classLoader */
            invokevirtual org.apache.juli.ClassLoaderLogManager.getClassLoaderInfo:(Ljava/lang/ClassLoader;)Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.loggers:Ljava/util/Map;
            aload 1 /* name */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.logging.Logger
            areturn
        end local 2 // java.lang.ClassLoader classLoader
        end local 1 // java.lang.String name
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lorg/apache/juli/ClassLoaderLogManager;
            0    4     1         name  Ljava/lang/String;
            3    4     2  classLoader  Ljava/lang/ClassLoader;
    MethodParameters:
      Name  Flags
      name  final

  public synchronized java.util.Enumeration<java.lang.String> getLoggerNames();
    descriptor: ()Ljava/util/Enumeration;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.apache.juli.ClassLoaderLogManager this
         0: .line 260
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
         1: .line 261
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
         2: .line 260
            astore 1 /* classLoader */
        start local 1 // java.lang.ClassLoader classLoader
         3: .line 262
            aload 0 /* this */
            aload 1 /* classLoader */
            invokevirtual org.apache.juli.ClassLoaderLogManager.getClassLoaderInfo:(Ljava/lang/ClassLoader;)Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.loggers:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokestatic java.util.Collections.enumeration:(Ljava/util/Collection;)Ljava/util/Enumeration;
            areturn
        end local 1 // java.lang.ClassLoader classLoader
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lorg/apache/juli/ClassLoaderLogManager;
            3    4     1  classLoader  Ljava/lang/ClassLoader;
    Signature: ()Ljava/util/Enumeration<Ljava/lang/String;>;

  public java.lang.String getProperty(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.lang.String name
         0: .line 277
            ldc ".handlers"
            aload 1 /* name */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 2
            getstatic org.apache.juli.ClassLoaderLogManager.addingLocalRootLogger:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifne 2
         1: .line 278
            aconst_null
            areturn
         2: .line 281
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.prefix:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 2 /* prefix */
        start local 2 // java.lang.String prefix
         3: .line 282
            aconst_null
            astore 3 /* result */
        start local 3 // java.lang.String result
         4: .line 285
            aload 2 /* prefix */
            ifnull 6
         5: .line 286
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            aload 2 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.juli.ClassLoaderLogManager.findProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* result */
         6: .line 291
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
            aload 3 /* result */
            ifnonnull 8
         7: .line 292
            aload 0 /* this */
            aload 1 /* name */
            invokevirtual org.apache.juli.ClassLoaderLogManager.findProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* result */
         8: .line 296
      StackMap locals:
      StackMap stack:
            aload 3 /* result */
            ifnull 10
         9: .line 297
            aload 0 /* this */
            aload 3 /* result */
            invokevirtual org.apache.juli.ClassLoaderLogManager.replace:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* result */
        10: .line 299
      StackMap locals:
      StackMap stack:
            aload 3 /* result */
            areturn
        end local 3 // java.lang.String result
        end local 2 // java.lang.String prefix
        end local 1 // java.lang.String name
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   11     0    this  Lorg/apache/juli/ClassLoaderLogManager;
            0   11     1    name  Ljava/lang/String;
            3   11     2  prefix  Ljava/lang/String;
            4   11     3  result  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  

  private synchronized java.lang.String findProperty(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=6, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.lang.String name
         0: .line 304
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
         1: .line 305
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
         2: .line 304
            astore 2 /* classLoader */
        start local 2 // java.lang.ClassLoader classLoader
         3: .line 306
            aload 0 /* this */
            aload 2 /* classLoader */
            invokevirtual org.apache.juli.ClassLoaderLogManager.getClassLoaderInfo:(Ljava/lang/ClassLoader;)Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            astore 3 /* info */
        start local 3 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
         4: .line 307
            aload 3 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.props:Ljava/util/Properties;
            aload 1 /* name */
            invokevirtual java.util.Properties.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* result */
        start local 4 // java.lang.String result
         5: .line 311
            aload 4 /* result */
            ifnonnull 17
            aload 3 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.props:Ljava/util/Properties;
            invokevirtual java.util.Properties.isEmpty:()Z
            ifeq 17
         6: .line 312
            aload 2 /* classLoader */
            invokevirtual java.lang.ClassLoader.getParent:()Ljava/lang/ClassLoader;
            astore 5 /* current */
        start local 5 // java.lang.ClassLoader current
         7: .line 313
            goto 14
         8: .line 314
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.String java.lang.ClassLoader org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo java.lang.String java.lang.ClassLoader
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
            aload 5 /* current */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
            astore 3 /* info */
         9: .line 315
            aload 3 /* info */
            ifnull 13
        10: .line 316
            aload 3 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.props:Ljava/util/Properties;
            aload 1 /* name */
            invokevirtual java.util.Properties.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* result */
        11: .line 317
            aload 4 /* result */
            ifnonnull 15
            aload 3 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.props:Ljava/util/Properties;
            invokevirtual java.util.Properties.isEmpty:()Z
            ifne 13
        12: .line 318
            goto 15
        13: .line 321
      StackMap locals:
      StackMap stack:
            aload 5 /* current */
            invokevirtual java.lang.ClassLoader.getParent:()Ljava/lang/ClassLoader;
            astore 5 /* current */
        14: .line 313
      StackMap locals:
      StackMap stack:
            aload 5 /* current */
            ifnonnull 8
        15: .line 323
      StackMap locals:
      StackMap stack:
            aload 4 /* result */
            ifnonnull 17
        16: .line 324
            aload 0 /* this */
            aload 1 /* name */
            invokespecial java.util.logging.LogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* result */
        end local 5 // java.lang.ClassLoader current
        17: .line 327
      StackMap locals:
      StackMap stack:
            aload 4 /* result */
            areturn
        end local 4 // java.lang.String result
        end local 3 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        end local 2 // java.lang.ClassLoader classLoader
        end local 1 // java.lang.String name
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   18     0         this  Lorg/apache/juli/ClassLoaderLogManager;
            0   18     1         name  Ljava/lang/String;
            3   18     2  classLoader  Ljava/lang/ClassLoader;
            4   18     3         info  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            5   18     4       result  Ljava/lang/String;
            7   17     5      current  Ljava/lang/ClassLoader;
    MethodParameters:
      Name  Flags
      name  

  public void readConfiguration();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.juli.ClassLoaderLogManager this
         0: .line 334
            aload 0 /* this */
            invokevirtual org.apache.juli.ClassLoaderLogManager.checkAccess:()V
         1: .line 336
            aload 0 /* this */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
            invokevirtual org.apache.juli.ClassLoaderLogManager.readConfiguration:(Ljava/lang/ClassLoader;)V
         2: .line 338
            return
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/juli/ClassLoaderLogManager;
    Exceptions:
      throws java.io.IOException, java.lang.SecurityException

  public void readConfiguration(java.io.InputStream);
    descriptor: (Ljava/io/InputStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.io.InputStream is
         0: .line 344
            aload 0 /* this */
            invokevirtual org.apache.juli.ClassLoaderLogManager.checkAccess:()V
         1: .line 345
            aload 0 /* this */
            invokevirtual org.apache.juli.ClassLoaderLogManager.reset:()V
         2: .line 347
            aload 0 /* this */
            aload 1 /* is */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
            invokevirtual org.apache.juli.ClassLoaderLogManager.readConfiguration:(Ljava/io/InputStream;Ljava/lang/ClassLoader;)V
         3: .line 349
            return
        end local 1 // java.io.InputStream is
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/juli/ClassLoaderLogManager;
            0    4     1    is  Ljava/io/InputStream;
    Exceptions:
      throws java.io.IOException, java.lang.SecurityException
    MethodParameters:
      Name  Flags
      is    

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.juli.ClassLoaderLogManager this
         0: .line 353
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 1 /* thread */
        start local 1 // java.lang.Thread thread
         1: .line 354
            aload 1 /* thread */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
         2: .line 355
            ldc "java.util.logging.LogManager$"
         3: .line 354
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
         4: .line 355
            ifeq 6
         5: .line 358
            return
         6: .line 360
      StackMap locals: java.lang.Thread
      StackMap stack:
            aload 1 /* thread */
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
            astore 2 /* classLoader */
        start local 2 // java.lang.ClassLoader classLoader
         7: .line 361
            aload 0 /* this */
            aload 2 /* classLoader */
            invokevirtual org.apache.juli.ClassLoaderLogManager.getClassLoaderInfo:(Ljava/lang/ClassLoader;)Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            astore 3 /* clLogInfo */
        start local 3 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo clLogInfo
         8: .line 362
            aload 0 /* this */
            aload 3 /* clLogInfo */
            invokevirtual org.apache.juli.ClassLoaderLogManager.resetLoggers:(Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;)V
         9: .line 368
            return
        end local 3 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo clLogInfo
        end local 2 // java.lang.ClassLoader classLoader
        end local 1 // java.lang.Thread thread
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   10     0         this  Lorg/apache/juli/ClassLoaderLogManager;
            1   10     1       thread  Ljava/lang/Thread;
            7   10     2  classLoader  Ljava/lang/ClassLoader;
            8   10     3    clLogInfo  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
    Exceptions:
      throws java.lang.SecurityException

  public synchronized void shutdown();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // org.apache.juli.ClassLoaderLogManager this
         0: .line 376
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 3
      StackMap locals: org.apache.juli.ClassLoaderLogManager top java.util.Iterator
      StackMap stack:
         1: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
            astore 1 /* clLogInfo */
        start local 1 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo clLogInfo
         2: .line 377
            aload 0 /* this */
            aload 1 /* clLogInfo */
            invokevirtual org.apache.juli.ClassLoaderLogManager.resetLoggers:(Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;)V
        end local 1 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo clLogInfo
         3: .line 376
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 379
            return
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    5     0       this  Lorg/apache/juli/ClassLoaderLogManager;
            2    3     1  clLogInfo  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;

  private void resetLoggers(org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo);
    descriptor: (Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=10, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo clLogInfo
         0: .line 389
            aload 1 /* clLogInfo */
            dup
            astore 2
            monitorenter
         1: .line 390
            aload 1 /* clLogInfo */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.loggers:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 9
      StackMap locals: org.apache.juli.ClassLoaderLogManager org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.logging.Logger
            astore 3 /* logger */
        start local 3 // java.util.logging.Logger logger
         3: .line 391
            aload 3 /* logger */
            invokevirtual java.util.logging.Logger.getHandlers:()[Ljava/util/logging/Handler;
            astore 5 /* handlers */
        start local 5 // java.util.logging.Handler[] handlers
         4: .line 392
            aload 5 /* handlers */
            dup
            astore 9
            arraylength
            istore 8
            iconst_0
            istore 7
            goto 8
      StackMap locals: org.apache.juli.ClassLoaderLogManager org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo java.util.logging.Logger java.util.Iterator java.util.logging.Handler[] top int int java.util.logging.Handler[]
      StackMap stack:
         5: aload 9
            iload 7
            aaload
            astore 6 /* handler */
        start local 6 // java.util.logging.Handler handler
         6: .line 393
            aload 3 /* logger */
            aload 6 /* handler */
            invokevirtual java.util.logging.Logger.removeHandler:(Ljava/util/logging/Handler;)V
        end local 6 // java.util.logging.Handler handler
         7: .line 392
            iinc 7 1
      StackMap locals:
      StackMap stack:
         8: iload 7
            iload 8
            if_icmplt 5
        end local 5 // java.util.logging.Handler[] handlers
        end local 3 // java.util.logging.Logger logger
         9: .line 390
      StackMap locals: org.apache.juli.ClassLoaderLogManager org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        10: .line 396
            aload 1 /* clLogInfo */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.handlers:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 15
      StackMap locals:
      StackMap stack:
        11: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.logging.Handler
            astore 3 /* handler */
        start local 3 // java.util.logging.Handler handler
        12: .line 398
            aload 3 /* handler */
            invokevirtual java.util.logging.Handler.close:()V
        13: .line 399
            goto 15
      StackMap locals: org.apache.juli.ClassLoaderLogManager org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo java.util.logging.Handler java.util.Iterator
      StackMap stack: java.lang.Exception
        14: pop
        end local 3 // java.util.logging.Handler handler
        15: .line 396
      StackMap locals: org.apache.juli.ClassLoaderLogManager org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        16: .line 403
            aload 1 /* clLogInfo */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.handlers:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
        17: .line 389
            aload 2
            monitorexit
        18: goto 21
      StackMap locals: org.apache.juli.ClassLoaderLogManager org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
      StackMap stack: java.lang.Throwable
        19: aload 2
            monitorexit
        20: athrow
        21: .line 405
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo clLogInfo
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   22     0       this  Lorg/apache/juli/ClassLoaderLogManager;
            0   22     1  clLogInfo  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            3    9     3     logger  Ljava/util/logging/Logger;
            4    9     5   handlers  [Ljava/util/logging/Handler;
            6    7     6    handler  Ljava/util/logging/Handler;
           12   15     3    handler  Ljava/util/logging/Handler;
      Exception table:
        from    to  target  type
          12    13      14  Class java.lang.Exception
           1    18      19  any
          19    20      19  any
    MethodParameters:
           Name  Flags
      clLogInfo  

  protected synchronized org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo getClassLoaderInfo(java.lang.ClassLoader);
    descriptor: (Ljava/lang/ClassLoader;)Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
    flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.lang.ClassLoader classLoader
         0: .line 420
            aload 1 /* classLoader */
            ifnonnull 2
         1: .line 421
            invokestatic java.lang.ClassLoader.getSystemClassLoader:()Ljava/lang/ClassLoader;
            astore 1 /* classLoader */
         2: .line 423
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
            aload 1 /* classLoader */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
            astore 2 /* info */
        start local 2 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
         3: .line 424
            aload 2 /* info */
            ifnonnull 7
         4: .line 425
            aload 1 /* classLoader */
            astore 3 /* classLoaderParam */
        start local 3 // java.lang.ClassLoader classLoaderParam
         5: .line 426
            new org.apache.juli.ClassLoaderLogManager$3
            dup
            aload 0 /* this */
            aload 3 /* classLoaderParam */
            invokespecial org.apache.juli.ClassLoaderLogManager$3.<init>:(Lorg/apache/juli/ClassLoaderLogManager;Ljava/lang/ClassLoader;)V
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            pop
         6: .line 437
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
            aload 1 /* classLoader */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
            astore 2 /* info */
        end local 3 // java.lang.ClassLoader classLoaderParam
         7: .line 439
      StackMap locals: org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
      StackMap stack:
            aload 2 /* info */
            areturn
        end local 2 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        end local 1 // java.lang.ClassLoader classLoader
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    8     0              this  Lorg/apache/juli/ClassLoaderLogManager;
            0    8     1       classLoader  Ljava/lang/ClassLoader;
            3    8     2              info  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            5    7     3  classLoaderParam  Ljava/lang/ClassLoader;
    MethodParameters:
             Name  Flags
      classLoader  

  protected synchronized void readConfiguration(java.lang.ClassLoader);
    descriptor: (Ljava/lang/ClassLoader;)V
    flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=7, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.lang.ClassLoader classLoader
         0: .line 452
            aconst_null
            astore 2 /* is */
        start local 2 // java.io.InputStream is
         1: .line 456
            aload 1 /* classLoader */
            instanceof org.apache.juli.WebappProperties
            ifeq 5
         2: .line 457
            aload 1 /* classLoader */
            checkcast org.apache.juli.WebappProperties
            invokeinterface org.apache.juli.WebappProperties.hasLoggingConfig:()Z
            ifeq 33
         3: .line 458
            aload 1 /* classLoader */
            ldc "logging.properties"
            invokevirtual java.lang.ClassLoader.getResourceAsStream:(Ljava/lang/String;)Ljava/io/InputStream;
            astore 2 /* is */
         4: .line 460
            goto 33
      StackMap locals: java.io.InputStream
      StackMap stack:
         5: aload 1 /* classLoader */
            instanceof java.net.URLClassLoader
            ifeq 33
         6: .line 461
            aload 1 /* classLoader */
            checkcast java.net.URLClassLoader
            ldc "logging.properties"
            invokevirtual java.net.URLClassLoader.findResource:(Ljava/lang/String;)Ljava/net/URL;
            astore 3 /* logConfig */
        start local 3 // java.net.URL logConfig
         7: .line 463
            aload 3 /* logConfig */
            ifnull 16
         8: .line 464
            getstatic org.apache.juli.ClassLoaderLogManager.DEBUG_PROPERTY:Ljava/lang/String;
            invokestatic java.lang.Boolean.getBoolean:(Ljava/lang/String;)Z
            ifeq 14
         9: .line 465
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        10: .line 466
            ldc ".readConfiguration(): "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        11: .line 467
            ldc "Found logging.properties at "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        12: .line 468
            aload 3 /* logConfig */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 465
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        14: .line 470
      StackMap locals: java.net.URL
      StackMap stack:
            aload 1 /* classLoader */
            ldc "logging.properties"
            invokevirtual java.lang.ClassLoader.getResourceAsStream:(Ljava/lang/String;)Ljava/io/InputStream;
            astore 2 /* is */
        15: .line 471
            goto 33
        16: .line 472
      StackMap locals:
      StackMap stack:
            getstatic org.apache.juli.ClassLoaderLogManager.DEBUG_PROPERTY:Ljava/lang/String;
            invokestatic java.lang.Boolean.getBoolean:(Ljava/lang/String;)Z
            ifeq 33
        17: .line 473
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        18: .line 474
            ldc ".readConfiguration(): "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        19: .line 475
            ldc "Found no logging.properties"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 473
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 3 // java.net.URL logConfig
        21: .line 478
            goto 33
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.ClassLoader java.io.InputStream
      StackMap stack: java.security.AccessControlException
        22: astore 3 /* ace */
        start local 3 // java.security.AccessControlException ace
        23: .line 481
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
            invokestatic java.lang.ClassLoader.getSystemClassLoader:()Ljava/lang/ClassLoader;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
            astore 4 /* info */
        start local 4 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        24: .line 482
            aload 4 /* info */
            ifnull 33
        25: .line 483
            aload 4 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.loggers:Ljava/util/Map;
            ldc ""
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.logging.Logger
            astore 5 /* log */
        start local 5 // java.util.logging.Logger log
        26: .line 484
            aload 5 /* log */
            ifnull 33
        27: .line 485
            aload 3 /* ace */
            invokevirtual java.security.AccessControlException.getPermission:()Ljava/security/Permission;
            astore 6 /* perm */
        start local 6 // java.security.Permission perm
        28: .line 486
            aload 6 /* perm */
            instanceof java.io.FilePermission
            ifeq 31
            aload 6 /* perm */
            invokevirtual java.security.Permission.getActions:()Ljava/lang/String;
            ldc "read"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 31
        29: .line 487
            aload 5 /* log */
            new java.lang.StringBuilder
            dup
            ldc "Reading "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* perm */
            invokevirtual java.security.Permission.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " is not permitted. See \"per context logging\" in the default catalina.policy file."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.warning:(Ljava/lang/String;)V
        30: .line 488
            goto 33
        31: .line 490
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.ClassLoader java.io.InputStream java.security.AccessControlException org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo java.util.logging.Logger java.security.Permission
      StackMap stack:
            aload 5 /* log */
            ldc "Reading logging.properties is not permitted in some context. See \"per context logging\" in the default catalina.policy file."
            invokevirtual java.util.logging.Logger.warning:(Ljava/lang/String;)V
        32: .line 491
            aload 5 /* log */
            new java.lang.StringBuilder
            dup
            ldc "Original error was: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* ace */
            invokevirtual java.security.AccessControlException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.warning:(Ljava/lang/String;)V
        end local 6 // java.security.Permission perm
        end local 5 // java.util.logging.Logger log
        end local 4 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        end local 3 // java.security.AccessControlException ace
        33: .line 496
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.ClassLoader java.io.InputStream
      StackMap stack:
            aload 2 /* is */
            ifnonnull 54
            aload 1 /* classLoader */
            invokestatic java.lang.ClassLoader.getSystemClassLoader:()Ljava/lang/ClassLoader;
            if_acmpne 54
        34: .line 497
            ldc "java.util.logging.config.file"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* configFileStr */
        start local 3 // java.lang.String configFileStr
        35: .line 498
            aload 3 /* configFileStr */
            ifnull 41
        36: .line 500
            new java.io.FileInputStream
            dup
            aload 0 /* this */
            aload 3 /* configFileStr */
            invokevirtual org.apache.juli.ClassLoaderLogManager.replace:(Ljava/lang/String;)Ljava/lang/String;
            invokespecial java.io.FileInputStream.<init>:(Ljava/lang/String;)V
            astore 2 /* is */
        37: .line 501
            goto 41
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.ClassLoader java.io.InputStream java.lang.String
      StackMap stack: java.io.IOException
        38: astore 4 /* e */
        start local 4 // java.io.IOException e
        39: .line 502
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            ldc "Configuration error"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        40: .line 503
            aload 4 /* e */
            invokevirtual java.io.IOException.printStackTrace:()V
        end local 4 // java.io.IOException e
        41: .line 507
      StackMap locals:
      StackMap stack:
            aload 2 /* is */
            ifnonnull 54
        42: .line 508
            new java.io.File
            dup
        43: new java.io.File
            dup
            ldc "java.home"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
        44: .line 509
            getstatic org.apache.juli.ClassLoaderLogManager.isJava9:Z
            ifeq 45
            ldc "conf"
            goto 46
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.ClassLoader java.io.InputStream java.lang.String
      StackMap stack: new 42 new 42 new 43 new 43 java.lang.String
        45: ldc "lib"
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.ClassLoader java.io.InputStream java.lang.String
      StackMap stack: new 42 new 42 new 43 new 43 java.lang.String java.lang.String
        46: invokespecial java.io.File.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        47: .line 510
            ldc "logging.properties"
        48: .line 508
            invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
            astore 4 /* defaultFile */
        start local 4 // java.io.File defaultFile
        49: .line 512
            new java.io.FileInputStream
            dup
            aload 4 /* defaultFile */
            invokespecial java.io.FileInputStream.<init>:(Ljava/io/File;)V
            astore 2 /* is */
        50: .line 513
            goto 54
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.ClassLoader java.io.InputStream java.lang.String java.io.File
      StackMap stack: java.io.IOException
        51: astore 5 /* e */
        start local 5 // java.io.IOException e
        52: .line 514
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            ldc "Configuration error"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        53: .line 515
            aload 5 /* e */
            invokevirtual java.io.IOException.printStackTrace:()V
        end local 5 // java.io.IOException e
        end local 4 // java.io.File defaultFile
        end local 3 // java.lang.String configFileStr
        54: .line 520
      StackMap locals:
      StackMap stack:
            new org.apache.juli.ClassLoaderLogManager$RootLogger
            dup
            invokespecial org.apache.juli.ClassLoaderLogManager$RootLogger.<init>:()V
            astore 3 /* localRootLogger */
        start local 3 // java.util.logging.Logger localRootLogger
        55: .line 521
            aload 2 /* is */
            ifnonnull 64
        56: .line 523
            aload 1 /* classLoader */
            invokevirtual java.lang.ClassLoader.getParent:()Ljava/lang/ClassLoader;
            astore 4 /* current */
        start local 4 // java.lang.ClassLoader current
        57: .line 524
            aconst_null
            astore 5 /* info */
        start local 5 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        58: .line 525
            goto 61
        59: .line 526
      StackMap locals: java.util.logging.Logger java.lang.ClassLoader org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
      StackMap stack:
            aload 0 /* this */
            aload 4 /* current */
            invokevirtual org.apache.juli.ClassLoaderLogManager.getClassLoaderInfo:(Ljava/lang/ClassLoader;)Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            astore 5 /* info */
        60: .line 527
            aload 4 /* current */
            invokevirtual java.lang.ClassLoader.getParent:()Ljava/lang/ClassLoader;
            astore 4 /* current */
        61: .line 525
      StackMap locals:
      StackMap stack:
            aload 4 /* current */
            ifnull 62
            aload 5 /* info */
            ifnull 59
        62: .line 529
      StackMap locals:
      StackMap stack:
            aload 5 /* info */
            ifnull 64
        63: .line 530
            aload 3 /* localRootLogger */
            aload 5 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.rootNode:Lorg/apache/juli/ClassLoaderLogManager$LogNode;
            getfield org.apache.juli.ClassLoaderLogManager$LogNode.logger:Ljava/util/logging/Logger;
            invokevirtual java.util.logging.Logger.setParent:(Ljava/util/logging/Logger;)V
        end local 5 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        end local 4 // java.lang.ClassLoader current
        64: .line 534
      StackMap locals:
      StackMap stack:
            new org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
            dup
            new org.apache.juli.ClassLoaderLogManager$LogNode
            dup
            aconst_null
            aload 3 /* localRootLogger */
            invokespecial org.apache.juli.ClassLoaderLogManager$LogNode.<init>:(Lorg/apache/juli/ClassLoaderLogManager$LogNode;Ljava/util/logging/Logger;)V
            invokespecial org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.<init>:(Lorg/apache/juli/ClassLoaderLogManager$LogNode;)V
        65: .line 533
            astore 4 /* info */
        start local 4 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        66: .line 535
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
            aload 1 /* classLoader */
            aload 4 /* info */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        67: .line 537
            aload 2 /* is */
            ifnull 69
        68: .line 538
            aload 0 /* this */
            aload 2 /* is */
            aload 1 /* classLoader */
            invokevirtual org.apache.juli.ClassLoaderLogManager.readConfiguration:(Ljava/io/InputStream;Ljava/lang/ClassLoader;)V
        69: .line 543
      StackMap locals: org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
      StackMap stack:
            getstatic org.apache.juli.ClassLoaderLogManager.addingLocalRootLogger:Ljava/lang/ThreadLocal;
            getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        70: .line 544
            aload 0 /* this */
            aload 3 /* localRootLogger */
            invokevirtual org.apache.juli.ClassLoaderLogManager.addLogger:(Ljava/util/logging/Logger;)Z
            pop
        71: .line 545
            goto 75
      StackMap locals:
      StackMap stack: java.lang.Throwable
        72: astore 5
        73: .line 546
            getstatic org.apache.juli.ClassLoaderLogManager.addingLocalRootLogger:Ljava/lang/ThreadLocal;
            getstatic java.lang.Boolean.FALSE:Ljava/lang/Boolean;
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        74: .line 547
            aload 5
            athrow
        75: .line 546
      StackMap locals:
      StackMap stack:
            getstatic org.apache.juli.ClassLoaderLogManager.addingLocalRootLogger:Ljava/lang/ThreadLocal;
            getstatic java.lang.Boolean.FALSE:Ljava/lang/Boolean;
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        76: .line 548
            return
        end local 4 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        end local 3 // java.util.logging.Logger localRootLogger
        end local 2 // java.io.InputStream is
        end local 1 // java.lang.ClassLoader classLoader
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   77     0             this  Lorg/apache/juli/ClassLoaderLogManager;
            0   77     1      classLoader  Ljava/lang/ClassLoader;
            1   77     2               is  Ljava/io/InputStream;
            7   21     3        logConfig  Ljava/net/URL;
           23   33     3              ace  Ljava/security/AccessControlException;
           24   33     4             info  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
           26   33     5              log  Ljava/util/logging/Logger;
           28   33     6             perm  Ljava/security/Permission;
           35   54     3    configFileStr  Ljava/lang/String;
           39   41     4                e  Ljava/io/IOException;
           49   54     4      defaultFile  Ljava/io/File;
           52   54     5                e  Ljava/io/IOException;
           55   77     3  localRootLogger  Ljava/util/logging/Logger;
           57   64     4          current  Ljava/lang/ClassLoader;
           58   64     5             info  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
           66   77     4             info  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
      Exception table:
        from    to  target  type
           1    21      22  Class java.security.AccessControlException
          36    37      38  Class java.io.IOException
          49    50      51  Class java.io.IOException
          69    72      72  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      classLoader  

  protected synchronized void readConfiguration(java.io.InputStream, java.lang.ClassLoader);
    descriptor: (Ljava/io/InputStream;Ljava/lang/ClassLoader;)V
    flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=12, args_size=3
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.io.InputStream is
        start local 2 // java.lang.ClassLoader classLoader
         0: .line 561
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.classLoaderLoggers:Ljava/util/Map;
            aload 2 /* classLoader */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
            astore 3 /* info */
        start local 3 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
         1: .line 564
            aload 3 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.props:Ljava/util/Properties;
            aload 1 /* is */
            invokevirtual java.util.Properties.load:(Ljava/io/InputStream;)V
         2: .line 565
            goto 14
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.io.InputStream java.lang.ClassLoader org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
      StackMap stack: java.io.IOException
         3: astore 4 /* e */
        start local 4 // java.io.IOException e
         4: .line 567
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            ldc "Configuration error"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         5: .line 568
            aload 4 /* e */
            invokevirtual java.io.IOException.printStackTrace:()V
        end local 4 // java.io.IOException e
         6: .line 571
            aload 1 /* is */
            invokevirtual java.io.InputStream.close:()V
         7: .line 572
            goto 17
      StackMap locals:
      StackMap stack: java.io.IOException
         8: pop
            goto 17
         9: .line 569
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 5
        10: .line 571
            aload 1 /* is */
            invokevirtual java.io.InputStream.close:()V
        11: .line 572
            goto 13
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.io.InputStream java.lang.ClassLoader org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo top java.lang.Throwable
      StackMap stack: java.io.IOException
        12: pop
        13: .line 575
      StackMap locals:
      StackMap stack:
            aload 5
            athrow
        14: .line 571
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.io.InputStream java.lang.ClassLoader org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo
      StackMap stack:
            aload 1 /* is */
            invokevirtual java.io.InputStream.close:()V
        15: .line 572
            goto 17
      StackMap locals:
      StackMap stack: java.io.IOException
        16: pop
        17: .line 575
      StackMap locals:
      StackMap stack:
            aload 3 /* info */
        18: .line 578
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.props:Ljava/util/Properties;
            ldc ".handlers"
            invokevirtual java.util.Properties.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* rootHandlers */
        start local 4 // java.lang.String rootHandlers
        19: .line 579
            aload 3 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.props:Ljava/util/Properties;
            ldc "handlers"
            invokevirtual java.util.Properties.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 5 /* handlers */
        start local 5 // java.lang.String handlers
        20: .line 580
            aload 3 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.rootNode:Lorg/apache/juli/ClassLoaderLogManager$LogNode;
            getfield org.apache.juli.ClassLoaderLogManager$LogNode.logger:Ljava/util/logging/Logger;
            astore 6 /* localRootLogger */
        start local 6 // java.util.logging.Logger localRootLogger
        21: .line 581
            aload 5 /* handlers */
            ifnull 49
        22: .line 582
            new java.util.StringTokenizer
            dup
            aload 5 /* handlers */
            ldc ","
            invokespecial java.util.StringTokenizer.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            astore 7 /* tok */
        start local 7 // java.util.StringTokenizer tok
        23: .line 583
            goto 48
        24: .line 584
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.io.InputStream java.lang.ClassLoader org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo java.lang.String java.lang.String java.util.logging.Logger java.util.StringTokenizer
      StackMap stack:
            aload 7 /* tok */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            astore 8 /* handlerName */
        start local 8 // java.lang.String handlerName
        25: .line 585
            aload 8 /* handlerName */
            astore 9 /* handlerClassName */
        start local 9 // java.lang.String handlerClassName
        26: .line 586
            ldc ""
            astore 10 /* prefix */
        start local 10 // java.lang.String prefix
        27: .line 587
            aload 9 /* handlerClassName */
            invokevirtual java.lang.String.length:()I
            ifgt 29
        28: .line 588
            goto 48
        29: .line 592
      StackMap locals: java.lang.String java.lang.String java.lang.String
      StackMap stack:
            aload 9 /* handlerClassName */
            iconst_0
            invokevirtual java.lang.String.charAt:(I)C
            invokestatic java.lang.Character.isDigit:(C)Z
            ifeq 34
        30: .line 593
            aload 9 /* handlerClassName */
            bipush 46
            invokevirtual java.lang.String.indexOf:(I)I
            istore 11 /* pos */
        start local 11 // int pos
        31: .line 594
            iload 11 /* pos */
            iflt 34
        32: .line 595
            aload 9 /* handlerClassName */
            iconst_0
            iload 11 /* pos */
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 10 /* prefix */
        33: .line 596
            aload 9 /* handlerClassName */
            iload 11 /* pos */
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 9 /* handlerClassName */
        end local 11 // int pos
        34: .line 600
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.prefix:Ljava/lang/ThreadLocal;
            aload 10 /* prefix */
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        35: .line 601
            aload 2 /* classLoader */
        36: .line 602
            aload 9 /* handlerClassName */
        37: .line 601
            invokevirtual java.lang.ClassLoader.loadClass:(Ljava/lang/String;)Ljava/lang/Class;
            iconst_0
            anewarray java.lang.Class
        38: .line 602
            invokevirtual java.lang.Class.getConstructor:([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
            iconst_0
            anewarray java.lang.Object
            invokevirtual java.lang.reflect.Constructor.newInstance:([Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.logging.Handler
        39: .line 601
            astore 11 /* handler */
        start local 11 // java.util.logging.Handler handler
        40: .line 606
            aload 0 /* this */
            getfield org.apache.juli.ClassLoaderLogManager.prefix:Ljava/lang/ThreadLocal;
            aconst_null
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        41: .line 607
            aload 3 /* info */
            getfield org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo.handlers:Ljava/util/Map;
            aload 8 /* handlerName */
            aload 11 /* handler */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        42: .line 608
            aload 4 /* rootHandlers */
            ifnonnull 48
        43: .line 609
            aload 6 /* localRootLogger */
            aload 11 /* handler */
            invokevirtual java.util.logging.Logger.addHandler:(Ljava/util/logging/Handler;)V
        end local 11 // java.util.logging.Handler handler
        44: .line 611
            goto 48
      StackMap locals:
      StackMap stack: java.lang.Exception
        45: astore 11 /* e */
        start local 11 // java.lang.Exception e
        46: .line 613
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            ldc "Handler error"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        47: .line 614
            aload 11 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        end local 11 // java.lang.Exception e
        end local 10 // java.lang.String prefix
        end local 9 // java.lang.String handlerClassName
        end local 8 // java.lang.String handlerName
        48: .line 583
      StackMap locals:
      StackMap stack:
            aload 7 /* tok */
            invokevirtual java.util.StringTokenizer.hasMoreTokens:()Z
            ifne 24
        end local 7 // java.util.StringTokenizer tok
        49: .line 620
      StackMap locals:
      StackMap stack:
            return
        end local 6 // java.util.logging.Logger localRootLogger
        end local 5 // java.lang.String handlers
        end local 4 // java.lang.String rootHandlers
        end local 3 // org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo info
        end local 2 // java.lang.ClassLoader classLoader
        end local 1 // java.io.InputStream is
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   50     0              this  Lorg/apache/juli/ClassLoaderLogManager;
            0   50     1                is  Ljava/io/InputStream;
            0   50     2       classLoader  Ljava/lang/ClassLoader;
            1   50     3              info  Lorg/apache/juli/ClassLoaderLogManager$ClassLoaderLogInfo;
            4    6     4                 e  Ljava/io/IOException;
           19   50     4      rootHandlers  Ljava/lang/String;
           20   50     5          handlers  Ljava/lang/String;
           21   50     6   localRootLogger  Ljava/util/logging/Logger;
           23   49     7               tok  Ljava/util/StringTokenizer;
           25   48     8       handlerName  Ljava/lang/String;
           26   48     9  handlerClassName  Ljava/lang/String;
           27   48    10            prefix  Ljava/lang/String;
           31   34    11               pos  I
           40   44    11           handler  Ljava/util/logging/Handler;
           46   48    11                 e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     2       3  Class java.io.IOException
           6     7       8  Class java.io.IOException
           1     6       9  any
          10    11      12  Class java.io.IOException
          14    15      16  Class java.io.IOException
          34    44      45  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      is           
      classLoader  

  protected static void doSetParentLogger(java.util.logging.Logger, java.util.logging.Logger);
    descriptor: (Ljava/util/logging/Logger;Ljava/util/logging/Logger;)V
    flags: (0x000c) ACC_PROTECTED, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // java.util.logging.Logger logger
        start local 1 // java.util.logging.Logger parent
         0: .line 631
            new org.apache.juli.ClassLoaderLogManager$4
            dup
            aload 0 /* logger */
            aload 1 /* parent */
            invokespecial org.apache.juli.ClassLoaderLogManager$4.<init>:(Ljava/util/logging/Logger;Ljava/util/logging/Logger;)V
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            pop
         1: .line 638
            return
        end local 1 // java.util.logging.Logger parent
        end local 0 // java.util.logging.Logger logger
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0  logger  Ljava/util/logging/Logger;
            0    2     1  parent  Ljava/util/logging/Logger;
    MethodParameters:
        Name  Flags
      logger  final
      parent  final

  protected java.lang.String replace(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=8, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.lang.String str
         0: .line 648
            aload 1 /* str */
            astore 2 /* result */
        start local 2 // java.lang.String result
         1: .line 649
            aload 1 /* str */
            ldc "${"
            invokevirtual java.lang.String.indexOf:(Ljava/lang/String;)I
            istore 3 /* pos_start */
        start local 3 // int pos_start
         2: .line 650
            iload 3 /* pos_start */
            iflt 25
         3: .line 651
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 4 /* builder */
        start local 4 // java.lang.StringBuilder builder
         4: .line 652
            iconst_m1
            istore 5 /* pos_end */
        start local 5 // int pos_end
         5: .line 653
            goto 22
         6: .line 654
      StackMap locals: org.apache.juli.ClassLoaderLogManager java.lang.String java.lang.String int java.lang.StringBuilder int
      StackMap stack:
            aload 4 /* builder */
            aload 1 /* str */
            iload 5 /* pos_end */
            iconst_1
            iadd
            iload 3 /* pos_start */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;II)Ljava/lang/StringBuilder;
            pop
         7: .line 655
            aload 1 /* str */
            bipush 125
            iload 3 /* pos_start */
            iconst_2
            iadd
            invokevirtual java.lang.String.indexOf:(II)I
            istore 5 /* pos_end */
         8: .line 656
            iload 5 /* pos_end */
            ifge 11
         9: .line 657
            iload 3 /* pos_start */
            iconst_1
            isub
            istore 5 /* pos_end */
        10: .line 658
            goto 23
        11: .line 660
      StackMap locals:
      StackMap stack:
            aload 1 /* str */
            iload 3 /* pos_start */
            iconst_2
            iadd
            iload 5 /* pos_end */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 6 /* propName */
        start local 6 // java.lang.String propName
        12: .line 662
            aload 0 /* this */
            aload 6 /* propName */
            invokevirtual org.apache.juli.ClassLoaderLogManager.replaceWebApplicationProperties:(Ljava/lang/String;)Ljava/lang/String;
            astore 7 /* replacement */
        start local 7 // java.lang.String replacement
        13: .line 663
            aload 7 /* replacement */
            ifnonnull 17
        14: .line 664
            aload 6 /* propName */
            invokevirtual java.lang.String.length:()I
            ifle 15
            aload 6 /* propName */
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            goto 16
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
        15: aconst_null
      StackMap locals:
      StackMap stack: java.lang.String
        16: astore 7 /* replacement */
        17: .line 666
      StackMap locals:
      StackMap stack:
            aload 7 /* replacement */
            ifnull 20
        18: .line 667
            aload 4 /* builder */
            aload 7 /* replacement */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        19: .line 668
            goto 21
        20: .line 669
      StackMap locals:
      StackMap stack:
            aload 4 /* builder */
            aload 1 /* str */
            iload 3 /* pos_start */
            iload 5 /* pos_end */
            iconst_1
            iadd
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;II)Ljava/lang/StringBuilder;
            pop
        21: .line 671
      StackMap locals:
      StackMap stack:
            aload 1 /* str */
            ldc "${"
            iload 5 /* pos_end */
            iconst_1
            iadd
            invokevirtual java.lang.String.indexOf:(Ljava/lang/String;I)I
            istore 3 /* pos_start */
        end local 7 // java.lang.String replacement
        end local 6 // java.lang.String propName
        22: .line 653
      StackMap locals:
      StackMap stack:
            iload 3 /* pos_start */
            ifge 6
        23: .line 673
      StackMap locals:
      StackMap stack:
            aload 4 /* builder */
            aload 1 /* str */
            iload 5 /* pos_end */
            iconst_1
            iadd
            aload 1 /* str */
            invokevirtual java.lang.String.length:()I
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;II)Ljava/lang/StringBuilder;
            pop
        24: .line 674
            aload 4 /* builder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 2 /* result */
        end local 5 // int pos_end
        end local 4 // java.lang.StringBuilder builder
        25: .line 676
      StackMap locals:
      StackMap stack:
            aload 2 /* result */
            areturn
        end local 3 // int pos_start
        end local 2 // java.lang.String result
        end local 1 // java.lang.String str
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   26     0         this  Lorg/apache/juli/ClassLoaderLogManager;
            0   26     1          str  Ljava/lang/String;
            1   26     2       result  Ljava/lang/String;
            2   26     3    pos_start  I
            4   25     4      builder  Ljava/lang/StringBuilder;
            5   25     5      pos_end  I
           12   22     6     propName  Ljava/lang/String;
           13   22     7  replacement  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      str   

  private java.lang.String replaceWebApplicationProperties(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.juli.ClassLoaderLogManager this
        start local 1 // java.lang.String propName
         0: .line 681
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getContextClassLoader:()Ljava/lang/ClassLoader;
            astore 2 /* cl */
        start local 2 // java.lang.ClassLoader cl
         1: .line 682
            aload 2 /* cl */
            instanceof org.apache.juli.WebappProperties
            ifeq 10
         2: .line 683
            aload 2 /* cl */
            checkcast org.apache.juli.WebappProperties
            astore 3 /* wProps */
        start local 3 // org.apache.juli.WebappProperties wProps
         3: .line 684
            ldc "classloader.webappName"
            aload 1 /* propName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 5
         4: .line 685
            aload 3 /* wProps */
            invokeinterface org.apache.juli.WebappProperties.getWebappName:()Ljava/lang/String;
            areturn
         5: .line 686
      StackMap locals: java.lang.ClassLoader org.apache.juli.WebappProperties
      StackMap stack:
            ldc "classloader.hostName"
            aload 1 /* propName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 7
         6: .line 687
            aload 3 /* wProps */
            invokeinterface org.apache.juli.WebappProperties.getHostName:()Ljava/lang/String;
            areturn
         7: .line 688
      StackMap locals:
      StackMap stack:
            ldc "classloader.serviceName"
            aload 1 /* propName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 9
         8: .line 689
            aload 3 /* wProps */
            invokeinterface org.apache.juli.WebappProperties.getServiceName:()Ljava/lang/String;
            areturn
         9: .line 691
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 3 // org.apache.juli.WebappProperties wProps
        10: .line 694
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // java.lang.ClassLoader cl
        end local 1 // java.lang.String propName
        end local 0 // org.apache.juli.ClassLoaderLogManager this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lorg/apache/juli/ClassLoaderLogManager;
            0   11     1  propName  Ljava/lang/String;
            1   11     2        cl  Ljava/lang/ClassLoader;
            3   10     3    wProps  Lorg/apache/juli/WebappProperties;
    MethodParameters:
          Name  Flags
      propName  
}
SourceFile: "ClassLoaderLogManager.java"
NestMembers:
  org.apache.juli.ClassLoaderLogManager$1  org.apache.juli.ClassLoaderLogManager$2  org.apache.juli.ClassLoaderLogManager$3  org.apache.juli.ClassLoaderLogManager$4  org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo  org.apache.juli.ClassLoaderLogManager$Cleaner  org.apache.juli.ClassLoaderLogManager$LogNode  org.apache.juli.ClassLoaderLogManager$RootLogger
InnerClasses:
  org.apache.juli.ClassLoaderLogManager$1
  org.apache.juli.ClassLoaderLogManager$2
  org.apache.juli.ClassLoaderLogManager$3
  org.apache.juli.ClassLoaderLogManager$4
  protected final ClassLoaderLogInfo = org.apache.juli.ClassLoaderLogManager$ClassLoaderLogInfo of org.apache.juli.ClassLoaderLogManager
  private final Cleaner = org.apache.juli.ClassLoaderLogManager$Cleaner of org.apache.juli.ClassLoaderLogManager
  protected final LogNode = org.apache.juli.ClassLoaderLogManager$LogNode of org.apache.juli.ClassLoaderLogManager
  protected RootLogger = org.apache.juli.ClassLoaderLogManager$RootLogger of org.apache.juli.ClassLoaderLogManager