public class org.apache.logging.log4j.core.LoggerContext extends org.apache.logging.log4j.core.AbstractLifeCycle implements org.apache.logging.log4j.spi.LoggerContext, java.lang.AutoCloseable, org.apache.logging.log4j.spi.Terminable, org.apache.logging.log4j.core.config.ConfigurationListener, org.apache.logging.log4j.spi.LoggerContextShutdownEnabled
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.LoggerContext
  super_class: org.apache.logging.log4j.core.AbstractLifeCycle
{
  public static final java.lang.String PROPERTY_CONFIG;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "config"

  private static final org.apache.logging.log4j.core.config.Configuration NULL_CONFIGURATION;
    descriptor: Lorg/apache/logging/log4j/core/config/Configuration;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final org.apache.logging.log4j.spi.LoggerRegistry<org.apache.logging.log4j.core.Logger> loggerRegistry;
    descriptor: Lorg/apache/logging/log4j/spi/LoggerRegistry;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lorg/apache/logging/log4j/spi/LoggerRegistry<Lorg/apache/logging/log4j/core/Logger;>;

  private final java.util.concurrent.CopyOnWriteArrayList<java.beans.PropertyChangeListener> propertyChangeListeners;
    descriptor: Ljava/util/concurrent/CopyOnWriteArrayList;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/CopyOnWriteArrayList<Ljava/beans/PropertyChangeListener;>;

  private volatile java.util.List<org.apache.logging.log4j.spi.LoggerContextShutdownAware> listeners;
    descriptor: Ljava/util/List;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
    Signature: Ljava/util/List<Lorg/apache/logging/log4j/spi/LoggerContextShutdownAware;>;

  private volatile org.apache.logging.log4j.core.config.Configuration configuration;
    descriptor: Lorg/apache/logging/log4j/core/config/Configuration;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private static final java.lang.String EXTERNAL_CONTEXT_KEY;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "__EXTERNAL_CONTEXT_KEY__"

  private java.util.concurrent.ConcurrentMap<java.lang.String, java.lang.Object> externalMap;
    descriptor: Ljava/util/concurrent/ConcurrentMap;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/lang/String;Ljava/lang/Object;>;

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

  private volatile java.net.URI configLocation;
    descriptor: Ljava/net/URI;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private org.apache.logging.log4j.core.util.Cancellable shutdownCallback;
    descriptor: Lorg/apache/logging/log4j/core/util/Cancellable;
    flags: (0x0002) ACC_PRIVATE

  private final java.util.concurrent.locks.Lock configLock;
    descriptor: Ljava/util/concurrent/locks/Lock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 77
            ldc Lorg/apache/logging/log4j/core/util/ExecutorServices;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic org.apache.logging.log4j.core.util.Loader.loadClass:(Ljava/lang/String;)Ljava/lang/Class;
            pop
         1: .line 78
            goto 4
      StackMap locals:
      StackMap stack: java.lang.Exception
         2: astore 0 /* e */
        start local 0 // java.lang.Exception e
         3: .line 79
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Failed to preload ExecutorServices class."
            aload 0 /* e */
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 0 // java.lang.Exception e
         4: .line 88
      StackMap locals:
      StackMap stack:
            new org.apache.logging.log4j.core.config.NullConfiguration
            dup
            invokespecial org.apache.logging.log4j.core.config.NullConfiguration.<init>:()V
            putstatic org.apache.logging.log4j.core.LoggerContext.NULL_CONFIGURATION:Lorg/apache/logging/log4j/core/config/Configuration;
         5: .line 99
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            3    4     0     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.Exception

  public void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
         0: .line 113
            aload 0 /* this */
            aload 1 /* name */
            aconst_null
            aconst_null
            invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)V
         1: .line 114
            return
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    2     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  final

  public void <init>(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
        start local 2 // java.lang.Object externalContext
         0: .line 123
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* externalContext */
            aconst_null
            invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)V
         1: .line 124
            return
        end local 2 // java.lang.Object externalContext
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    2     1             name  Ljava/lang/String;
            0    2     2  externalContext  Ljava/lang/Object;
    MethodParameters:
                 Name  Flags
      name             final
      externalContext  final

  public void <init>(java.lang.String, java.lang.Object, java.net.URI);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
        start local 2 // java.lang.Object externalContext
        start local 3 // java.net.URI configLocn
         0: .line 133
            aload 0 /* this */
            invokespecial org.apache.logging.log4j.core.AbstractLifeCycle.<init>:()V
         1: .line 90
            aload 0 /* this */
            new org.apache.logging.log4j.spi.LoggerRegistry
            dup
            invokespecial org.apache.logging.log4j.spi.LoggerRegistry.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
         2: .line 91
            aload 0 /* this */
            new java.util.concurrent.CopyOnWriteArrayList
            dup
            invokespecial java.util.concurrent.CopyOnWriteArrayList.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.propertyChangeListeners:Ljava/util/concurrent/CopyOnWriteArrayList;
         3: .line 98
            aload 0 /* this */
            new org.apache.logging.log4j.core.config.DefaultConfiguration
            dup
            invokespecial org.apache.logging.log4j.core.config.DefaultConfiguration.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
         4: .line 100
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
         5: .line 105
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
         6: .line 134
            aload 0 /* this */
            aload 1 /* name */
            putfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
         7: .line 135
            aload 2 /* externalContext */
            ifnonnull 10
         8: .line 136
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            ldc "__EXTERNAL_CONTEXT_KEY__"
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         9: .line 137
            goto 11
        10: .line 138
      StackMap locals: org.apache.logging.log4j.core.LoggerContext java.lang.String java.lang.Object java.net.URI
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            ldc "__EXTERNAL_CONTEXT_KEY__"
            aload 2 /* externalContext */
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        11: .line 140
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* configLocn */
            putfield org.apache.logging.log4j.core.LoggerContext.configLocation:Ljava/net/URI;
        12: .line 141
            invokedynamic run()Ljava/lang/Runnable;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()V
                  org/apache/logging/log4j/core/impl/ThreadContextDataInjector.initServiceProviders()V (6)
                  ()V
            invokestatic java.util.concurrent.CompletableFuture.runAsync:(Ljava/lang/Runnable;)Ljava/util/concurrent/CompletableFuture;
            pop
        13: .line 142
            return
        end local 3 // java.net.URI configLocn
        end local 2 // java.lang.Object externalContext
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   14     0             this  Lorg/apache/logging/log4j/core/LoggerContext;
            0   14     1             name  Ljava/lang/String;
            0   14     2  externalContext  Ljava/lang/Object;
            0   14     3       configLocn  Ljava/net/URI;
    MethodParameters:
                 Name  Flags
      name             final
      externalContext  final
      configLocn       final

  public void <init>(java.lang.String, java.lang.Object, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=4
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
        start local 2 // java.lang.Object externalContext
        start local 3 // java.lang.String configLocn
         0: .line 152
            aload 0 /* this */
            invokespecial org.apache.logging.log4j.core.AbstractLifeCycle.<init>:()V
         1: .line 90
            aload 0 /* this */
            new org.apache.logging.log4j.spi.LoggerRegistry
            dup
            invokespecial org.apache.logging.log4j.spi.LoggerRegistry.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
         2: .line 91
            aload 0 /* this */
            new java.util.concurrent.CopyOnWriteArrayList
            dup
            invokespecial java.util.concurrent.CopyOnWriteArrayList.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.propertyChangeListeners:Ljava/util/concurrent/CopyOnWriteArrayList;
         3: .line 98
            aload 0 /* this */
            new org.apache.logging.log4j.core.config.DefaultConfiguration
            dup
            invokespecial org.apache.logging.log4j.core.config.DefaultConfiguration.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
         4: .line 100
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
         5: .line 105
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
         6: .line 153
            aload 0 /* this */
            aload 1 /* name */
            putfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
         7: .line 154
            aload 2 /* externalContext */
            ifnonnull 10
         8: .line 155
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            ldc "__EXTERNAL_CONTEXT_KEY__"
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         9: .line 156
            goto 11
        10: .line 157
      StackMap locals: org.apache.logging.log4j.core.LoggerContext java.lang.String java.lang.Object java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            ldc "__EXTERNAL_CONTEXT_KEY__"
            aload 2 /* externalContext */
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        11: .line 159
      StackMap locals:
      StackMap stack:
            aload 3 /* configLocn */
            ifnull 18
        12: .line 162
            new java.io.File
            dup
            aload 3 /* configLocn */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            invokevirtual java.io.File.toURI:()Ljava/net/URI;
            astore 4 /* uri */
        start local 4 // java.net.URI uri
        13: .line 163
            goto 16
        end local 4 // java.net.URI uri
      StackMap locals:
      StackMap stack: java.lang.Exception
        14: pop
        15: .line 164
            aconst_null
            astore 4 /* uri */
        start local 4 // java.net.URI uri
        16: .line 166
      StackMap locals: java.net.URI
      StackMap stack:
            aload 0 /* this */
            aload 4 /* uri */
            putfield org.apache.logging.log4j.core.LoggerContext.configLocation:Ljava/net/URI;
        end local 4 // java.net.URI uri
        17: .line 167
            goto 19
        18: .line 168
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield org.apache.logging.log4j.core.LoggerContext.configLocation:Ljava/net/URI;
        19: .line 170
      StackMap locals:
      StackMap stack:
            invokedynamic run()Ljava/lang/Runnable;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()V
                  org/apache/logging/log4j/core/impl/ThreadContextDataInjector.initServiceProviders()V (6)
                  ()V
            invokestatic java.util.concurrent.CompletableFuture.runAsync:(Ljava/lang/Runnable;)Ljava/util/concurrent/CompletableFuture;
            pop
        20: .line 171
            return
        end local 3 // java.lang.String configLocn
        end local 2 // java.lang.Object externalContext
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   21     0             this  Lorg/apache/logging/log4j/core/LoggerContext;
            0   21     1             name  Ljava/lang/String;
            0   21     2  externalContext  Ljava/lang/Object;
            0   21     3       configLocn  Ljava/lang/String;
           13   14     4              uri  Ljava/net/URI;
           16   17     4              uri  Ljava/net/URI;
      Exception table:
        from    to  target  type
          12    13      14  Class java.lang.Exception
    MethodParameters:
                 Name  Flags
      name             final
      externalContext  final
      configLocn       final

  public void addShutdownListener(org.apache.logging.log4j.spi.LoggerContextShutdownAware);
    descriptor: (Lorg/apache/logging/log4j/spi/LoggerContextShutdownAware;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.spi.LoggerContextShutdownAware listener
         0: .line 174
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.listeners:Ljava/util/List;
            ifnonnull 8
         1: .line 175
            aload 0 /* this */
            dup
            astore 2
            monitorenter
         2: .line 176
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.listeners:Ljava/util/List;
            ifnonnull 4
         3: .line 177
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            invokestatic java.util.Collections.synchronizedList:(Ljava/util/List;)Ljava/util/List;
            putfield org.apache.logging.log4j.core.LoggerContext.listeners:Ljava/util/List;
         4: .line 175
      StackMap locals: org.apache.logging.log4j.core.LoggerContext
      StackMap stack:
            aload 2
            monitorexit
         5: goto 8
      StackMap locals:
      StackMap stack: java.lang.Throwable
         6: aload 2
            monitorexit
         7: athrow
         8: .line 181
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.listeners:Ljava/util/List;
            aload 1 /* listener */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         9: .line 182
            return
        end local 1 // org.apache.logging.log4j.spi.LoggerContextShutdownAware listener
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   10     0      this  Lorg/apache/logging/log4j/core/LoggerContext;
            0   10     1  listener  Lorg/apache/logging/log4j/spi/LoggerContextShutdownAware;
      Exception table:
        from    to  target  type
           2     5       6  any
           6     7       6  any
    MethodParameters:
          Name  Flags
      listener  

  public java.util.List<org.apache.logging.log4j.spi.LoggerContextShutdownAware> getListeners();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 185
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.listeners:Ljava/util/List;
            areturn
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
    Signature: ()Ljava/util/List<Lorg/apache/logging/log4j/spi/LoggerContextShutdownAware;>;

  public static org.apache.logging.log4j.core.LoggerContext getContext();
    descriptor: ()Lorg/apache/logging/log4j/core/LoggerContext;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 207
            invokestatic org.apache.logging.log4j.LogManager.getContext:()Lorg/apache/logging/log4j/spi/LoggerContext;
            checkcast org.apache.logging.log4j.core.LoggerContext
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static org.apache.logging.log4j.core.LoggerContext getContext(boolean);
    descriptor: (Z)Lorg/apache/logging/log4j/core/LoggerContext;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // boolean currentContext
         0: .line 228
            iload 0 /* currentContext */
            invokestatic org.apache.logging.log4j.LogManager.getContext:(Z)Lorg/apache/logging/log4j/spi/LoggerContext;
            checkcast org.apache.logging.log4j.core.LoggerContext
            areturn
        end local 0 // boolean currentContext
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0  currentContext  Z
    MethodParameters:
                Name  Flags
      currentContext  final

  public static org.apache.logging.log4j.core.LoggerContext getContext(java.lang.ClassLoader, boolean, java.net.URI);
    descriptor: (Ljava/lang/ClassLoader;ZLjava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // java.lang.ClassLoader loader
        start local 1 // boolean currentContext
        start local 2 // java.net.URI configLocation
         0: .line 253
            aload 0 /* loader */
            iload 1 /* currentContext */
            aload 2 /* configLocation */
            invokestatic org.apache.logging.log4j.LogManager.getContext:(Ljava/lang/ClassLoader;ZLjava/net/URI;)Lorg/apache/logging/log4j/spi/LoggerContext;
            checkcast org.apache.logging.log4j.core.LoggerContext
            areturn
        end local 2 // java.net.URI configLocation
        end local 1 // boolean currentContext
        end local 0 // java.lang.ClassLoader loader
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0          loader  Ljava/lang/ClassLoader;
            0    1     1  currentContext  Z
            0    1     2  configLocation  Ljava/net/URI;
    MethodParameters:
                Name  Flags
      loader          final
      currentContext  final
      configLocation  final

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 258
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Starting LoggerContext[name={}, {}]..."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getName:()Ljava/lang/String;
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 259
            invokestatic org.apache.logging.log4j.util.PropertiesUtil.getProperties:()Lorg/apache/logging/log4j/util/PropertiesUtil;
            ldc "log4j.LoggerContext.stacktrace.on.start"
            iconst_0
            invokevirtual org.apache.logging.log4j.util.PropertiesUtil.getBooleanProperty:(Ljava/lang/String;Z)Z
            ifeq 5
         2: .line 260
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Stack trace to locate invoker"
         3: .line 261
            new java.lang.Exception
            dup
            ldc "Not a real error, showing stack trace to locate invoker"
            invokespecial java.lang.Exception.<init>:(Ljava/lang/String;)V
         4: .line 260
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Throwable;)V
         5: .line 263
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.tryLock:()Z
            ifeq 17
         6: .line 265
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.isInitialized:()Z
            ifne 7
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.isStopped:()Z
            ifeq 16
         7: .line 266
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setStarting:()V
         8: .line 267
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.reconfigure:()V
         9: .line 268
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            invokeinterface org.apache.logging.log4j.core.config.Configuration.isShutdownHookEnabled:()Z
            ifeq 11
        10: .line 269
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setUpShutdownHook:()V
        11: .line 271
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setStarted:()V
        12: .line 273
            goto 16
      StackMap locals:
      StackMap stack: java.lang.Throwable
        13: astore 1
        14: .line 274
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        15: .line 275
            aload 1
            athrow
        16: .line 274
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        17: .line 277
      StackMap locals:
      StackMap stack:
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "LoggerContext[name={}, {}] started OK."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getName:()Ljava/lang/String;
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        18: .line 278
            return
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   19     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
      Exception table:
        from    to  target  type
           6    13      13  any

  public void start(org.apache.logging.log4j.core.config.Configuration);
    descriptor: (Lorg/apache/logging/log4j/core/config/Configuration;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.core.config.Configuration config
         0: .line 286
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Starting LoggerContext[name={}, {}] with configuration {}..."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getName:()Ljava/lang/String;
            aload 0 /* this */
            aload 1 /* config */
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 287
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.tryLock:()Z
            ifeq 11
         2: .line 289
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.isInitialized:()Z
            ifne 3
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.isStopped:()Z
            ifeq 10
         3: .line 290
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            invokeinterface org.apache.logging.log4j.core.config.Configuration.isShutdownHookEnabled:()Z
            ifeq 5
         4: .line 291
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setUpShutdownHook:()V
         5: .line 293
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setStarted:()V
         6: .line 295
            goto 10
      StackMap locals:
      StackMap stack: java.lang.Throwable
         7: astore 2
         8: .line 296
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         9: .line 297
            aload 2
            athrow
        10: .line 296
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        11: .line 299
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setConfiguration:(Lorg/apache/logging/log4j/core/config/Configuration;)Lorg/apache/logging/log4j/core/config/Configuration;
            pop
        12: .line 300
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "LoggerContext[name={}, {}] started OK with configuration {}."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getName:()Ljava/lang/String;
            aload 0 /* this */
            aload 1 /* config */
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        13: .line 301
            return
        end local 1 // org.apache.logging.log4j.core.config.Configuration config
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   14     0    this  Lorg/apache/logging/log4j/core/LoggerContext;
            0   14     1  config  Lorg/apache/logging/log4j/core/config/Configuration;
      Exception table:
        from    to  target  type
           2     7       7  any
    MethodParameters:
        Name  Flags
      config  final

  private void setUpShutdownHook();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=4, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 304
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.shutdownCallback:Lorg/apache/logging/log4j/core/util/Cancellable;
            ifnonnull 15
         1: .line 305
            invokestatic org.apache.logging.log4j.LogManager.getFactory:()Lorg/apache/logging/log4j/spi/LoggerContextFactory;
            astore 1 /* factory */
        start local 1 // org.apache.logging.log4j.spi.LoggerContextFactory factory
         2: .line 306
            aload 1 /* factory */
            instanceof org.apache.logging.log4j.core.util.ShutdownCallbackRegistry
            ifeq 15
         3: .line 307
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            getstatic org.apache.logging.log4j.core.util.ShutdownCallbackRegistry.SHUTDOWN_HOOK_MARKER:Lorg/apache/logging/log4j/Marker;
            ldc "Shutdown hook enabled. Registering a new one."
            invokeinterface org.apache.logging.log4j.Logger.debug:(Lorg/apache/logging/log4j/Marker;Ljava/lang/String;)V
         4: .line 309
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            invokeinterface org.apache.logging.log4j.core.config.Configuration.getShutdownTimeoutMillis:()J
            lstore 2 /* shutdownTimeoutMillis */
        start local 2 // long shutdownTimeoutMillis
         5: .line 310
            aload 0 /* this */
            aload 1 /* factory */
            checkcast org.apache.logging.log4j.core.util.ShutdownCallbackRegistry
            new org.apache.logging.log4j.core.LoggerContext$1
            dup
            aload 0 /* this */
            lload 2 /* shutdownTimeoutMillis */
            invokespecial org.apache.logging.log4j.core.LoggerContext$1.<init>:(Lorg/apache/logging/log4j/core/LoggerContext;J)V
            invokeinterface org.apache.logging.log4j.core.util.ShutdownCallbackRegistry.addShutdownCallback:(Ljava/lang/Runnable;)Lorg/apache/logging/log4j/core/util/Cancellable;
            putfield org.apache.logging.log4j.core.LoggerContext.shutdownCallback:Lorg/apache/logging/log4j/core/util/Cancellable;
        end local 2 // long shutdownTimeoutMillis
         6: .line 325
            goto 15
      StackMap locals: org.apache.logging.log4j.core.LoggerContext org.apache.logging.log4j.spi.LoggerContextFactory
      StackMap stack: java.lang.IllegalStateException
         7: astore 2 /* e */
        start local 2 // java.lang.IllegalStateException e
         8: .line 326
            new java.lang.IllegalStateException
            dup
         9: .line 327
            ldc "Unable to register Log4j shutdown hook because JVM is shutting down."
            aload 2 /* e */
        10: .line 326
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.lang.IllegalStateException e
        11: .line 328
      StackMap locals:
      StackMap stack: java.lang.SecurityException
            astore 2 /* e */
        start local 2 // java.lang.SecurityException e
        12: .line 329
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            getstatic org.apache.logging.log4j.core.util.ShutdownCallbackRegistry.SHUTDOWN_HOOK_MARKER:Lorg/apache/logging/log4j/Marker;
            ldc "Unable to register shutdown hook due to security restrictions"
        13: .line 330
            aload 2 /* e */
        14: .line 329
            invokeinterface org.apache.logging.log4j.Logger.error:(Lorg/apache/logging/log4j/Marker;Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 2 // java.lang.SecurityException e
        end local 1 // org.apache.logging.log4j.spi.LoggerContextFactory factory
        15: .line 334
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   16     0                   this  Lorg/apache/logging/log4j/core/LoggerContext;
            2   15     1                factory  Lorg/apache/logging/log4j/spi/LoggerContextFactory;
            5    6     2  shutdownTimeoutMillis  J
            8   11     2                      e  Ljava/lang/IllegalStateException;
           12   15     2                      e  Ljava/lang/SecurityException;
      Exception table:
        from    to  target  type
           4     6       7  Class java.lang.IllegalStateException
           4     6      11  Class java.lang.SecurityException

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 338
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.stop:()V
         1: .line 339
            return
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public void terminate();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 343
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.stop:()V
         1: .line 344
            return
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public boolean stop(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit timeUnit
         0: .line 367
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Stopping LoggerContext[name={}, {}]..."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getName:()Ljava/lang/String;
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 368
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 370
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.isStopped:()Z
            ifeq 6
         3: .line 396
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         4: .line 397
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setStopped:()V
         5: .line 371
            iconst_1
            ireturn
         6: .line 374
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setStopping:()V
         7: .line 376
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getName:()Ljava/lang/String;
            invokestatic org.apache.logging.log4j.core.jmx.Server.unregisterLoggerContext:(Ljava/lang/String;)V
         8: .line 377
            goto 11
      StackMap locals:
      StackMap stack: java.lang.Throwable
         9: astore 4 /* e */
        start local 4 // java.lang.Throwable e
        10: .line 379
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Unable to unregister MBeans"
            aload 4 /* e */
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 4 // java.lang.Throwable e
        11: .line 381
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.shutdownCallback:Lorg/apache/logging/log4j/core/util/Cancellable;
            ifnull 14
        12: .line 382
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.shutdownCallback:Lorg/apache/logging/log4j/core/util/Cancellable;
            invokeinterface org.apache.logging.log4j.core.util.Cancellable.cancel:()V
        13: .line 383
            aload 0 /* this */
            aconst_null
            putfield org.apache.logging.log4j.core.LoggerContext.shutdownCallback:Lorg/apache/logging/log4j/core/util/Cancellable;
        14: .line 385
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            astore 4 /* prev */
        start local 4 // org.apache.logging.log4j.core.config.Configuration prev
        15: .line 386
            aload 0 /* this */
            getstatic org.apache.logging.log4j.core.LoggerContext.NULL_CONFIGURATION:Lorg/apache/logging/log4j/core/config/Configuration;
            putfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
        16: .line 387
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.updateLoggers:()V
        17: .line 388
            aload 4 /* prev */
            instanceof org.apache.logging.log4j.core.LifeCycle2
            ifeq 20
        18: .line 389
            aload 4 /* prev */
            checkcast org.apache.logging.log4j.core.LifeCycle2
            lload 1 /* timeout */
            aload 3 /* timeUnit */
            invokeinterface org.apache.logging.log4j.core.LifeCycle2.stop:(JLjava/util/concurrent/TimeUnit;)Z
            pop
        19: .line 390
            goto 21
        20: .line 391
      StackMap locals: org.apache.logging.log4j.core.config.Configuration
      StackMap stack:
            aload 4 /* prev */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.stop:()V
        21: .line 393
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.clear:()V
        22: .line 394
            invokestatic org.apache.logging.log4j.LogManager.getFactory:()Lorg/apache/logging/log4j/spi/LoggerContextFactory;
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.spi.LoggerContextFactory.removeContext:(Lorg/apache/logging/log4j/spi/LoggerContext;)V
        end local 4 // org.apache.logging.log4j.core.config.Configuration prev
        23: .line 395
            goto 28
      StackMap locals: org.apache.logging.log4j.core.LoggerContext long java.util.concurrent.TimeUnit
      StackMap stack: java.lang.Throwable
        24: astore 5
        25: .line 396
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        26: .line 397
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setStopped:()V
        27: .line 398
            aload 5
            athrow
        28: .line 396
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        29: .line 397
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setStopped:()V
        30: .line 399
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.listeners:Ljava/util/List;
            ifnull 37
        31: .line 400
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.listeners:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 36
      StackMap locals: org.apache.logging.log4j.core.LoggerContext long java.util.concurrent.TimeUnit top java.util.Iterator
      StackMap stack:
        32: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.logging.log4j.spi.LoggerContextShutdownAware
            astore 4 /* listener */
        start local 4 // org.apache.logging.log4j.spi.LoggerContextShutdownAware listener
        33: .line 402
            aload 4 /* listener */
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.spi.LoggerContextShutdownAware.contextShutdown:(Lorg/apache/logging/log4j/spi/LoggerContext;)V
        34: .line 403
            goto 36
      StackMap locals: org.apache.logging.log4j.core.LoggerContext long java.util.concurrent.TimeUnit org.apache.logging.log4j.spi.LoggerContextShutdownAware java.util.Iterator
      StackMap stack: java.lang.Exception
        35: pop
        end local 4 // org.apache.logging.log4j.spi.LoggerContextShutdownAware listener
        36: .line 400
      StackMap locals: org.apache.logging.log4j.core.LoggerContext long java.util.concurrent.TimeUnit top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 32
        37: .line 408
      StackMap locals: org.apache.logging.log4j.core.LoggerContext long java.util.concurrent.TimeUnit
      StackMap stack:
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Stopped LoggerContext[name={}, {}] with status {}"
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getName:()Ljava/lang/String;
            aload 0 /* this */
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        38: .line 409
            iconst_1
            ireturn
        end local 3 // java.util.concurrent.TimeUnit timeUnit
        end local 1 // long timeout
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   39     0      this  Lorg/apache/logging/log4j/core/LoggerContext;
            0   39     1   timeout  J
            0   39     3  timeUnit  Ljava/util/concurrent/TimeUnit;
           10   11     4         e  Ljava/lang/Throwable;
           15   23     4      prev  Lorg/apache/logging/log4j/core/config/Configuration;
           33   36     4  listener  Lorg/apache/logging/log4j/spi/LoggerContextShutdownAware;
      Exception table:
        from    to  target  type
           7     8       9  Class java.lang.LinkageError
           7     8       9  Class java.lang.Exception
           2     3      24  any
           6    24      24  any
          33    34      35  Class java.lang.Exception
    MethodParameters:
          Name  Flags
      timeout   final
      timeUnit  final

  public java.lang.String getName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 418
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            areturn
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public org.apache.logging.log4j.core.Logger getRootLogger();
    descriptor: ()Lorg/apache/logging/log4j/core/Logger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 427
            aload 0 /* this */
            ldc ""
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getLogger:(Ljava/lang/String;)Lorg/apache/logging/log4j/core/Logger;
            areturn
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public void setName(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
         0: .line 437
            aload 0 /* this */
            aload 1 /* name */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            putfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
         1: .line 438
            return
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    2     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  final

  public java.lang.Object getObject(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String key
         0: .line 442
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 1 // java.lang.String key
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1   key  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      key   

  public java.lang.Object putObject(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String key
        start local 2 // java.lang.Object value
         0: .line 447
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            aload 2 /* value */
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 2 // java.lang.Object value
        end local 1 // java.lang.String key
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1    key  Ljava/lang/String;
            0    1     2  value  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      key    
      value  

  public java.lang.Object putObjectIfAbsent(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String key
        start local 2 // java.lang.Object value
         0: .line 452
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            aload 2 /* value */
            invokeinterface java.util.concurrent.ConcurrentMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 2 // java.lang.Object value
        end local 1 // java.lang.String key
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1    key  Ljava/lang/String;
            0    1     2  value  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      key    
      value  

  public java.lang.Object removeObject(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String key
         0: .line 457
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 1 // java.lang.String key
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1   key  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      key   

  public boolean removeObject(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String key
        start local 2 // java.lang.Object value
         0: .line 462
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            aload 2 /* value */
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;Ljava/lang/Object;)Z
            ireturn
        end local 2 // java.lang.Object value
        end local 1 // java.lang.String key
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1    key  Ljava/lang/String;
            0    1     2  value  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      key    
      value  

  public void setExternalContext(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.Object context
         0: .line 471
            aload 1 /* context */
            ifnull 3
         1: .line 472
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            ldc "__EXTERNAL_CONTEXT_KEY__"
            aload 1 /* context */
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 473
            goto 4
         3: .line 474
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            ldc "__EXTERNAL_CONTEXT_KEY__"
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         4: .line 476
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object context
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    5     1  context  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      context  final

  public java.lang.Object getExternalContext();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 485
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            ldc "__EXTERNAL_CONTEXT_KEY__"
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public org.apache.logging.log4j.core.Logger getLogger(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/apache/logging/log4j/core/Logger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
         0: .line 496
            aload 0 /* this */
            aload 1 /* name */
            aconst_null
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getLogger:(Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/core/Logger;
            areturn
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  final

  public java.util.Collection<org.apache.logging.log4j.core.Logger> getLoggers();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 509
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
            invokevirtual org.apache.logging.log4j.spi.LoggerRegistry.getLoggers:()Ljava/util/Collection;
            areturn
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
    Signature: ()Ljava/util/Collection<Lorg/apache/logging/log4j/core/Logger;>;

  public org.apache.logging.log4j.core.Logger getLogger(java.lang.String, org.apache.logging.log4j.message.MessageFactory);
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/core/Logger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
        start local 2 // org.apache.logging.log4j.message.MessageFactory messageFactory
         0: .line 523
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
            aload 1 /* name */
            aload 2 /* messageFactory */
            invokevirtual org.apache.logging.log4j.spi.LoggerRegistry.getLogger:(Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/spi/ExtendedLogger;
            checkcast org.apache.logging.log4j.core.Logger
            astore 3 /* logger */
        start local 3 // org.apache.logging.log4j.core.Logger logger
         1: .line 524
            aload 3 /* logger */
            ifnull 4
         2: .line 525
            aload 3 /* logger */
            aload 2 /* messageFactory */
            invokestatic org.apache.logging.log4j.spi.AbstractLogger.checkMessageFactory:(Lorg/apache/logging/log4j/spi/ExtendedLogger;Lorg/apache/logging/log4j/message/MessageFactory;)V
         3: .line 526
            aload 3 /* logger */
            areturn
         4: .line 529
      StackMap locals: org.apache.logging.log4j.core.Logger
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* messageFactory */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.newInstance:(Lorg/apache/logging/log4j/core/LoggerContext;Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/core/Logger;
            astore 3 /* logger */
         5: .line 530
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
            aload 1 /* name */
            aload 2 /* messageFactory */
            aload 3 /* logger */
            invokevirtual org.apache.logging.log4j.spi.LoggerRegistry.putIfAbsent:(Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;Lorg/apache/logging/log4j/spi/ExtendedLogger;)V
         6: .line 531
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
            aload 1 /* name */
            aload 2 /* messageFactory */
            invokevirtual org.apache.logging.log4j.spi.LoggerRegistry.getLogger:(Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/spi/ExtendedLogger;
            checkcast org.apache.logging.log4j.core.Logger
            areturn
        end local 3 // org.apache.logging.log4j.core.Logger logger
        end local 2 // org.apache.logging.log4j.message.MessageFactory messageFactory
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    7     0            this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    7     1            name  Ljava/lang/String;
            0    7     2  messageFactory  Lorg/apache/logging/log4j/message/MessageFactory;
            1    7     3          logger  Lorg/apache/logging/log4j/core/Logger;
    MethodParameters:
                Name  Flags
      name            final
      messageFactory  final

  public boolean hasLogger(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
         0: .line 542
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
            aload 1 /* name */
            invokevirtual org.apache.logging.log4j.spi.LoggerRegistry.hasLogger:(Ljava/lang/String;)Z
            ireturn
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  final

  public boolean hasLogger(java.lang.String, org.apache.logging.log4j.message.MessageFactory);
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
        start local 2 // org.apache.logging.log4j.message.MessageFactory messageFactory
         0: .line 553
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
            aload 1 /* name */
            aload 2 /* messageFactory */
            invokevirtual org.apache.logging.log4j.spi.LoggerRegistry.hasLogger:(Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Z
            ireturn
        end local 2 // org.apache.logging.log4j.message.MessageFactory messageFactory
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0            this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1            name  Ljava/lang/String;
            0    1     2  messageFactory  Lorg/apache/logging/log4j/message/MessageFactory;
    MethodParameters:
                Name  Flags
      name            final
      messageFactory  final

  public boolean hasLogger(java.lang.String, java.lang.Class<? extends org.apache.logging.log4j.message.MessageFactory>);
    descriptor: (Ljava/lang/String;Ljava/lang/Class;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.lang.String name
        start local 2 // java.lang.Class messageFactoryClass
         0: .line 564
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
            aload 1 /* name */
            aload 2 /* messageFactoryClass */
            invokevirtual org.apache.logging.log4j.spi.LoggerRegistry.hasLogger:(Ljava/lang/String;Ljava/lang/Class;)Z
            ireturn
        end local 2 // java.lang.Class messageFactoryClass
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    1     0                 this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1                 name  Ljava/lang/String;
            0    1     2  messageFactoryClass  Ljava/lang/Class<+Lorg/apache/logging/log4j/message/MessageFactory;>;
    Signature: (Ljava/lang/String;Ljava/lang/Class<+Lorg/apache/logging/log4j/message/MessageFactory;>;)Z
    MethodParameters:
                     Name  Flags
      name                 final
      messageFactoryClass  final

  public org.apache.logging.log4j.core.config.Configuration getConfiguration();
    descriptor: ()Lorg/apache/logging/log4j/core/config/Configuration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 574
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            areturn
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public void addFilter(org.apache.logging.log4j.core.Filter);
    descriptor: (Lorg/apache/logging/log4j/core/Filter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.core.Filter filter
         0: .line 584
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            aload 1 /* filter */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.addFilter:(Lorg/apache/logging/log4j/core/Filter;)V
         1: .line 585
            return
        end local 1 // org.apache.logging.log4j.core.Filter filter
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    2     1  filter  Lorg/apache/logging/log4j/core/Filter;
    MethodParameters:
        Name  Flags
      filter  final

  public void removeFilter(org.apache.logging.log4j.core.Filter);
    descriptor: (Lorg/apache/logging/log4j/core/Filter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.core.Filter filter
         0: .line 593
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            aload 1 /* filter */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.removeFilter:(Lorg/apache/logging/log4j/core/Filter;)V
         1: .line 594
            return
        end local 1 // org.apache.logging.log4j.core.Filter filter
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    2     1  filter  Lorg/apache/logging/log4j/core/Filter;
    MethodParameters:
        Name  Flags
      filter  final

  public org.apache.logging.log4j.core.config.Configuration setConfiguration(org.apache.logging.log4j.core.config.Configuration);
    descriptor: (Lorg/apache/logging/log4j/core/config/Configuration;)Lorg/apache/logging/log4j/core/config/Configuration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=7, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.core.config.Configuration config
         0: .line 603
            aload 1 /* config */
            ifnonnull 3
         1: .line 604
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "No configuration found for context '{}'."
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;)V
         2: .line 606
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            areturn
         3: .line 608
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         4: .line 610
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            astore 2 /* prev */
        start local 2 // org.apache.logging.log4j.core.config.Configuration prev
         5: .line 611
            aload 1 /* config */
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.addListener:(Lorg/apache/logging/log4j/core/config/ConfigurationListener;)V
         6: .line 613
            aload 1 /* config */
            ldc "ContextProperties"
            invokeinterface org.apache.logging.log4j.core.config.Configuration.getComponent:(Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.util.concurrent.ConcurrentMap
            astore 3 /* map */
        start local 3 // java.util.concurrent.ConcurrentMap map
         7: .line 616
            aload 3 /* map */
            ldc "hostName"
            invokestatic org.apache.logging.log4j.core.util.NetUtils.getLocalHostname:()Ljava/lang/String;
            invokeinterface java.util.concurrent.ConcurrentMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 617
            goto 12
      StackMap locals: org.apache.logging.log4j.core.LoggerContext org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.config.Configuration java.util.concurrent.ConcurrentMap
      StackMap stack: java.lang.Exception
         9: astore 4 /* ex */
        start local 4 // java.lang.Exception ex
        10: .line 618
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Ignoring {}, setting hostName to 'unknown'"
            aload 4 /* ex */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
        11: .line 619
            aload 3 /* map */
            ldc "hostName"
            ldc "unknown"
            invokeinterface java.util.concurrent.ConcurrentMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 4 // java.lang.Exception ex
        12: .line 621
      StackMap locals:
      StackMap stack:
            aload 3 /* map */
            ldc "contextName"
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            invokeinterface java.util.concurrent.ConcurrentMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        13: .line 622
            aload 1 /* config */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.start:()V
        14: .line 623
            aload 0 /* this */
            aload 1 /* config */
            putfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
        15: .line 624
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.updateLoggers:()V
        16: .line 625
            aload 2 /* prev */
            ifnull 19
        17: .line 626
            aload 2 /* prev */
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.removeListener:(Lorg/apache/logging/log4j/core/config/ConfigurationListener;)V
        18: .line 627
            aload 2 /* prev */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.stop:()V
        19: .line 630
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.beans.PropertyChangeEvent
            dup
            aload 0 /* this */
            ldc "config"
            aload 2 /* prev */
            aload 1 /* config */
            invokespecial java.beans.PropertyChangeEvent.<init>:(Ljava/lang/Object;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
            invokevirtual org.apache.logging.log4j.core.LoggerContext.firePropertyChangeEvent:(Ljava/beans/PropertyChangeEvent;)V
        20: .line 633
            invokestatic org.apache.logging.log4j.core.jmx.Server.reregisterMBeansAfterReconfigure:()V
        21: .line 634
            goto 24
      StackMap locals:
      StackMap stack: java.lang.Throwable
        22: astore 4 /* e */
        start local 4 // java.lang.Throwable e
        23: .line 636
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Could not reconfigure JMX"
            aload 4 /* e */
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 4 // java.lang.Throwable e
        24: .line 639
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            invokeinterface org.apache.logging.log4j.core.config.Configuration.getNanoClock:()Lorg/apache/logging/log4j/core/util/NanoClock;
            invokestatic org.apache.logging.log4j.core.impl.Log4jLogEvent.setNanoClock:(Lorg/apache/logging/log4j/core/util/NanoClock;)V
        25: .line 641
            aload 2 /* prev */
            astore 6
        26: .line 643
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        27: .line 641
            aload 6
            areturn
        end local 3 // java.util.concurrent.ConcurrentMap map
        end local 2 // org.apache.logging.log4j.core.config.Configuration prev
        28: .line 642
      StackMap locals: org.apache.logging.log4j.core.LoggerContext org.apache.logging.log4j.core.config.Configuration
      StackMap stack: java.lang.Throwable
            astore 5
        29: .line 643
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        30: .line 644
            aload 5
            athrow
        end local 1 // org.apache.logging.log4j.core.config.Configuration config
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   31     0    this  Lorg/apache/logging/log4j/core/LoggerContext;
            0   31     1  config  Lorg/apache/logging/log4j/core/config/Configuration;
            5   28     2    prev  Lorg/apache/logging/log4j/core/config/Configuration;
            7   28     3     map  Ljava/util/concurrent/ConcurrentMap<Ljava/lang/String;Ljava/lang/String;>;
           10   12     4      ex  Ljava/lang/Exception;
           23   24     4       e  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           7     8       9  Class java.lang.Exception
          20    21      22  Class java.lang.LinkageError
          20    21      22  Class java.lang.Exception
           4    26      28  any
    MethodParameters:
        Name  Flags
      config  final

  private void firePropertyChangeEvent(java.beans.PropertyChangeEvent);
    descriptor: (Ljava/beans/PropertyChangeEvent;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.beans.PropertyChangeEvent event
         0: .line 648
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.propertyChangeListeners:Ljava/util/concurrent/CopyOnWriteArrayList;
            invokevirtual java.util.concurrent.CopyOnWriteArrayList.iterator:()Ljava/util/Iterator;
            astore 3
            goto 3
      StackMap locals: org.apache.logging.log4j.core.LoggerContext java.beans.PropertyChangeEvent top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.beans.PropertyChangeListener
            astore 2 /* listener */
        start local 2 // java.beans.PropertyChangeListener listener
         2: .line 649
            aload 2 /* listener */
            aload 1 /* event */
            invokeinterface java.beans.PropertyChangeListener.propertyChange:(Ljava/beans/PropertyChangeEvent;)V
        end local 2 // java.beans.PropertyChangeListener listener
         3: .line 648
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 651
            return
        end local 1 // java.beans.PropertyChangeEvent event
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    5     1     event  Ljava/beans/PropertyChangeEvent;
            2    3     2  listener  Ljava/beans/PropertyChangeListener;
    MethodParameters:
       Name  Flags
      event  final

  public void addPropertyChangeListener(java.beans.PropertyChangeListener);
    descriptor: (Ljava/beans/PropertyChangeListener;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.beans.PropertyChangeListener listener
         0: .line 654
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.propertyChangeListeners:Ljava/util/concurrent/CopyOnWriteArrayList;
            aload 1 /* listener */
            ldc "listener"
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.beans.PropertyChangeListener
            invokevirtual java.util.concurrent.CopyOnWriteArrayList.add:(Ljava/lang/Object;)Z
            pop
         1: .line 655
            return
        end local 1 // java.beans.PropertyChangeListener listener
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    2     1  listener  Ljava/beans/PropertyChangeListener;
    MethodParameters:
          Name  Flags
      listener  final

  public void removePropertyChangeListener(java.beans.PropertyChangeListener);
    descriptor: (Ljava/beans/PropertyChangeListener;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.beans.PropertyChangeListener listener
         0: .line 658
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.propertyChangeListeners:Ljava/util/concurrent/CopyOnWriteArrayList;
            aload 1 /* listener */
            invokevirtual java.util.concurrent.CopyOnWriteArrayList.remove:(Ljava/lang/Object;)Z
            pop
         1: .line 659
            return
        end local 1 // java.beans.PropertyChangeListener listener
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    2     1  listener  Ljava/beans/PropertyChangeListener;
    MethodParameters:
          Name  Flags
      listener  final

  public java.net.URI getConfigLocation();
    descriptor: ()Ljava/net/URI;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 670
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLocation:Ljava/net/URI;
            areturn
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public void setConfigLocation(java.net.URI);
    descriptor: (Ljava/net/URI;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.net.URI configLocation
         0: .line 679
            aload 0 /* this */
            aload 1 /* configLocation */
            putfield org.apache.logging.log4j.core.LoggerContext.configLocation:Ljava/net/URI;
         1: .line 680
            aload 0 /* this */
            aload 1 /* configLocation */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.reconfigure:(Ljava/net/URI;)V
         2: .line 681
            return
        end local 1 // java.net.URI configLocation
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    3     0            this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    3     1  configLocation  Ljava/net/URI;
    MethodParameters:
                Name  Flags
      configLocation  final

  private void reconfigure(java.net.URI);
    descriptor: (Ljava/net/URI;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=6, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // java.net.URI configURI
         0: .line 687
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.externalMap:Ljava/util/concurrent/ConcurrentMap;
            ldc "__EXTERNAL_CONTEXT_KEY__"
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* externalContext */
        start local 2 // java.lang.Object externalContext
         1: .line 688
            ldc Ljava/lang/ClassLoader;
            aload 2 /* externalContext */
            invokevirtual java.lang.Class.isInstance:(Ljava/lang/Object;)Z
            ifeq 2
            aload 2 /* externalContext */
            checkcast java.lang.ClassLoader
            goto 3
      StackMap locals: java.lang.Object
      StackMap stack:
         2: aconst_null
      StackMap locals:
      StackMap stack: java.lang.ClassLoader
         3: astore 3 /* cl */
        start local 3 // java.lang.ClassLoader cl
         4: .line 689
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Reconfiguration started for context[name={}] at URI {} ({}) with optional ClassLoader: {}"
         5: .line 690
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            aload 1 /* configURI */
            aload 0 /* this */
            aload 3 /* cl */
         6: .line 689
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         7: .line 691
            invokestatic org.apache.logging.log4j.core.config.ConfigurationFactory.getInstance:()Lorg/apache/logging/log4j/core/config/ConfigurationFactory;
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            aload 1 /* configURI */
            aload 3 /* cl */
            invokevirtual org.apache.logging.log4j.core.config.ConfigurationFactory.getConfiguration:(Lorg/apache/logging/log4j/core/LoggerContext;Ljava/lang/String;Ljava/net/URI;Ljava/lang/ClassLoader;)Lorg/apache/logging/log4j/core/config/Configuration;
            astore 4 /* instance */
        start local 4 // org.apache.logging.log4j.core.config.Configuration instance
         8: .line 692
            aload 4 /* instance */
            ifnonnull 11
         9: .line 693
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Reconfiguration failed: No configuration found for '{}' at '{}' in '{}'"
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            aload 1 /* configURI */
            aload 3 /* cl */
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        10: .line 694
            goto 18
        11: .line 695
      StackMap locals: java.lang.ClassLoader org.apache.logging.log4j.core.config.Configuration
      StackMap stack:
            aload 0 /* this */
            aload 4 /* instance */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setConfiguration:(Lorg/apache/logging/log4j/core/config/Configuration;)Lorg/apache/logging/log4j/core/config/Configuration;
            pop
        12: .line 700
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            ifnonnull 13
            ldc "?"
            goto 14
      StackMap locals:
      StackMap stack:
        13: aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            invokeinterface org.apache.logging.log4j.core.config.Configuration.getConfigurationSource:()Lorg/apache/logging/log4j/core/config/ConfigurationSource;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
      StackMap locals:
      StackMap stack: java.lang.String
        14: astore 5 /* location */
        start local 5 // java.lang.String location
        15: .line 701
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Reconfiguration complete for context[name={}] at URI {} ({}) with optional ClassLoader: {}"
        16: .line 702
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            aload 5 /* location */
            aload 0 /* this */
            aload 3 /* cl */
        17: .line 701
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        end local 5 // java.lang.String location
        18: .line 704
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.apache.logging.log4j.core.config.Configuration instance
        end local 3 // java.lang.ClassLoader cl
        end local 2 // java.lang.Object externalContext
        end local 1 // java.net.URI configURI
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   19     0             this  Lorg/apache/logging/log4j/core/LoggerContext;
            0   19     1        configURI  Ljava/net/URI;
            1   19     2  externalContext  Ljava/lang/Object;
            4   19     3               cl  Ljava/lang/ClassLoader;
            8   19     4         instance  Lorg/apache/logging/log4j/core/config/Configuration;
           15   18     5         location  Ljava/lang/String;
    MethodParameters:
           Name  Flags
      configURI  final

  public void reconfigure();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 712
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configLocation:Ljava/net/URI;
            invokevirtual org.apache.logging.log4j.core.LoggerContext.reconfigure:(Ljava/net/URI;)V
         1: .line 713
            return
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public void reconfigure(org.apache.logging.log4j.core.config.Configuration);
    descriptor: (Lorg/apache/logging/log4j/core/config/Configuration;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.core.config.Configuration configuration
         0: .line 716
            aload 0 /* this */
            aload 1 /* configuration */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setConfiguration:(Lorg/apache/logging/log4j/core/config/Configuration;)Lorg/apache/logging/log4j/core/config/Configuration;
            pop
         1: .line 717
            aload 1 /* configuration */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.getConfigurationSource:()Lorg/apache/logging/log4j/core/config/ConfigurationSource;
            astore 2 /* source */
        start local 2 // org.apache.logging.log4j.core.config.ConfigurationSource source
         2: .line 718
            aload 2 /* source */
            ifnull 6
         3: .line 719
            aload 2 /* source */
            invokevirtual org.apache.logging.log4j.core.config.ConfigurationSource.getURI:()Ljava/net/URI;
            astore 3 /* uri */
        start local 3 // java.net.URI uri
         4: .line 720
            aload 3 /* uri */
            ifnull 6
         5: .line 721
            aload 0 /* this */
            aload 3 /* uri */
            putfield org.apache.logging.log4j.core.LoggerContext.configLocation:Ljava/net/URI;
        end local 3 // java.net.URI uri
         6: .line 724
      StackMap locals: org.apache.logging.log4j.core.config.ConfigurationSource
      StackMap stack:
            return
        end local 2 // org.apache.logging.log4j.core.config.ConfigurationSource source
        end local 1 // org.apache.logging.log4j.core.config.Configuration configuration
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    7     0           this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    7     1  configuration  Lorg/apache/logging/log4j/core/config/Configuration;
            2    7     2         source  Lorg/apache/logging/log4j/core/config/ConfigurationSource;
            4    6     3            uri  Ljava/net/URI;
    MethodParameters:
               Name  Flags
      configuration  

  public void updateLoggers();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 730
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            invokevirtual org.apache.logging.log4j.core.LoggerContext.updateLoggers:(Lorg/apache/logging/log4j/core/config/Configuration;)V
         1: .line 731
            return
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  public void updateLoggers(org.apache.logging.log4j.core.config.Configuration);
    descriptor: (Lorg/apache/logging/log4j/core/config/Configuration;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=5, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.core.config.Configuration config
         0: .line 739
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
            astore 2 /* old */
        start local 2 // org.apache.logging.log4j.core.config.Configuration old
         1: .line 740
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.loggerRegistry:Lorg/apache/logging/log4j/spi/LoggerRegistry;
            invokevirtual org.apache.logging.log4j.spi.LoggerRegistry.getLoggers:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: org.apache.logging.log4j.core.LoggerContext org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.config.Configuration top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.Logger
            astore 3 /* logger */
        start local 3 // org.apache.logging.log4j.core.Logger logger
         3: .line 741
            aload 3 /* logger */
            aload 1 /* config */
            invokevirtual org.apache.logging.log4j.core.Logger.updateConfiguration:(Lorg/apache/logging/log4j/core/config/Configuration;)V
        end local 3 // org.apache.logging.log4j.core.Logger logger
         4: .line 740
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 743
            aload 0 /* this */
            new java.beans.PropertyChangeEvent
            dup
            aload 0 /* this */
            ldc "config"
            aload 2 /* old */
            aload 1 /* config */
            invokespecial java.beans.PropertyChangeEvent.<init>:(Ljava/lang/Object;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
            invokevirtual org.apache.logging.log4j.core.LoggerContext.firePropertyChangeEvent:(Ljava/beans/PropertyChangeEvent;)V
         6: .line 744
            return
        end local 2 // org.apache.logging.log4j.core.config.Configuration old
        end local 1 // org.apache.logging.log4j.core.config.Configuration config
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0    this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    7     1  config  Lorg/apache/logging/log4j/core/config/Configuration;
            1    7     2     old  Lorg/apache/logging/log4j/core/config/Configuration;
            3    4     3  logger  Lorg/apache/logging/log4j/core/Logger;
    MethodParameters:
        Name  Flags
      config  final

  public synchronized void onChange(org.apache.logging.log4j.core.config.Reconfigurable);
    descriptor: (Lorg/apache/logging/log4j/core/config/Reconfigurable;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=8, locals=5, args_size=2
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.core.config.Reconfigurable reconfigurable
         0: .line 753
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 2 /* startMillis */
        start local 2 // long startMillis
         1: .line 754
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Reconfiguration started for context {} ({})"
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         2: .line 755
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.initApiModule:()V
         3: .line 756
            aload 1 /* reconfigurable */
            invokeinterface org.apache.logging.log4j.core.config.Reconfigurable.reconfigure:()Lorg/apache/logging/log4j/core/config/Configuration;
            astore 4 /* newConfig */
        start local 4 // org.apache.logging.log4j.core.config.Configuration newConfig
         4: .line 757
            aload 4 /* newConfig */
            ifnull 10
         5: .line 758
            aload 0 /* this */
            aload 4 /* newConfig */
            invokevirtual org.apache.logging.log4j.core.LoggerContext.setConfiguration:(Lorg/apache/logging/log4j/core/config/Configuration;)Lorg/apache/logging/log4j/core/config/Configuration;
            pop
         6: .line 759
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Reconfiguration completed for {} ({}) in {} milliseconds."
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            aload 0 /* this */
         7: .line 760
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 2 /* startMillis */
            lsub
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
         8: .line 759
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         9: .line 761
            goto 13
        10: .line 762
      StackMap locals: long org.apache.logging.log4j.core.config.Configuration
      StackMap stack:
            getstatic org.apache.logging.log4j.core.LoggerContext.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Reconfiguration failed for {} ({}) in {} milliseconds."
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.LoggerContext.contextName:Ljava/lang/String;
            aload 0 /* this */
        11: .line 763
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 2 /* startMillis */
            lsub
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
        12: .line 762
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        13: .line 765
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.apache.logging.log4j.core.config.Configuration newConfig
        end local 2 // long startMillis
        end local 1 // org.apache.logging.log4j.core.config.Reconfigurable reconfigurable
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   14     0            this  Lorg/apache/logging/log4j/core/LoggerContext;
            0   14     1  reconfigurable  Lorg/apache/logging/log4j/core/config/Reconfigurable;
            1   14     2     startMillis  J
            4   14     4       newConfig  Lorg/apache/logging/log4j/core/config/Configuration;
    MethodParameters:
                Name  Flags
      reconfigurable  final

  private void initApiModule();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=0, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
         0: .line 768
            invokestatic org.apache.logging.log4j.spi.ThreadContextMapFactory.init:()V
         1: .line 769
            return
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/LoggerContext;

  protected org.apache.logging.log4j.core.Logger newInstance(org.apache.logging.log4j.core.LoggerContext, java.lang.String, org.apache.logging.log4j.message.MessageFactory);
    descriptor: (Lorg/apache/logging/log4j/core/LoggerContext;Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/core/Logger;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // org.apache.logging.log4j.core.LoggerContext this
        start local 1 // org.apache.logging.log4j.core.LoggerContext ctx
        start local 2 // java.lang.String name
        start local 3 // org.apache.logging.log4j.message.MessageFactory messageFactory
         0: .line 773
            new org.apache.logging.log4j.core.Logger
            dup
            aload 1 /* ctx */
            aload 2 /* name */
            aload 3 /* messageFactory */
            invokespecial org.apache.logging.log4j.core.Logger.<init>:(Lorg/apache/logging/log4j/core/LoggerContext;Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)V
            areturn
        end local 3 // org.apache.logging.log4j.message.MessageFactory messageFactory
        end local 2 // java.lang.String name
        end local 1 // org.apache.logging.log4j.core.LoggerContext ctx
        end local 0 // org.apache.logging.log4j.core.LoggerContext this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0            this  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     1             ctx  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     2            name  Ljava/lang/String;
            0    1     3  messageFactory  Lorg/apache/logging/log4j/message/MessageFactory;
    MethodParameters:
                Name  Flags
      ctx             final
      name            final
      messageFactory  final

  public org.apache.logging.log4j.spi.ExtendedLogger getLogger(java.lang.String, org.apache.logging.log4j.message.MessageFactory);
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/spi/ExtendedLogger;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            aload 2
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getLogger:(Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/core/Logger;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public org.apache.logging.log4j.spi.ExtendedLogger getLogger(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/apache/logging/log4j/spi/ExtendedLogger;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            invokevirtual org.apache.logging.log4j.core.LoggerContext.getLogger:(Ljava/lang/String;)Lorg/apache/logging/log4j/core/Logger;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "LoggerContext.java"
NestMembers:
  org.apache.logging.log4j.core.LoggerContext$1
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  org.apache.logging.log4j.core.LoggerContext$1