public class org.apache.logging.log4j.core.selector.JndiContextSelector implements org.apache.logging.log4j.core.selector.NamedContextSelector
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.selector.JndiContextSelector
  super_class: java.lang.Object
{
  private static final org.apache.logging.log4j.core.LoggerContext CONTEXT;
    descriptor: Lorg/apache/logging/log4j/core/LoggerContext;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.util.concurrent.ConcurrentMap<java.lang.String, org.apache.logging.log4j.core.LoggerContext> CONTEXT_MAP;
    descriptor: Ljava/util/concurrent/ConcurrentMap;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/lang/String;Lorg/apache/logging/log4j/core/LoggerContext;>;

  private static final org.apache.logging.log4j.status.StatusLogger LOGGER;
    descriptor: Lorg/apache/logging/log4j/status/StatusLogger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 88
            new org.apache.logging.log4j.core.LoggerContext
            dup
            ldc "Default"
            invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;)V
            putstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT:Lorg/apache/logging/log4j/core/LoggerContext;
         1: .line 91
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
         2: .line 90
            putstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
         3: .line 93
            invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
            putstatic org.apache.logging.log4j.core.selector.JndiContextSelector.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
         0: .line 86
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/selector/JndiContextSelector;

  public org.apache.logging.log4j.core.LoggerContext getContext(java.lang.String, java.lang.ClassLoader, boolean);
    descriptor: (Ljava/lang/String;Ljava/lang/ClassLoader;Z)Lorg/apache/logging/log4j/core/LoggerContext;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
        start local 1 // java.lang.String fqcn
        start local 2 // java.lang.ClassLoader loader
        start local 3 // boolean currentContext
         0: .line 97
            aload 0 /* this */
            aload 1 /* fqcn */
            aload 2 /* loader */
            iload 3 /* currentContext */
            aconst_null
            invokevirtual org.apache.logging.log4j.core.selector.JndiContextSelector.getContext:(Ljava/lang/String;Ljava/lang/ClassLoader;ZLjava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
            areturn
        end local 3 // boolean currentContext
        end local 2 // java.lang.ClassLoader loader
        end local 1 // java.lang.String fqcn
        end local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0            this  Lorg/apache/logging/log4j/core/selector/JndiContextSelector;
            0    1     1            fqcn  Ljava/lang/String;
            0    1     2          loader  Ljava/lang/ClassLoader;
            0    1     3  currentContext  Z
    MethodParameters:
                Name  Flags
      fqcn            final
      loader          final
      currentContext  final

  public org.apache.logging.log4j.core.LoggerContext getContext(java.lang.String, java.lang.ClassLoader, boolean, java.net.URI);
    descriptor: (Ljava/lang/String;Ljava/lang/ClassLoader;ZLjava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=10, args_size=5
        start local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
        start local 1 // java.lang.String fqcn
        start local 2 // java.lang.ClassLoader loader
        start local 3 // boolean currentContext
        start local 4 // java.net.URI configLocation
         0: .line 104
            getstatic org.apache.logging.log4j.core.impl.ContextAnchor.THREAD_CONTEXT:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.LoggerContext
            astore 5 /* lc */
        start local 5 // org.apache.logging.log4j.core.LoggerContext lc
         1: .line 105
            aload 5 /* lc */
            ifnull 3
         2: .line 106
            aload 5 /* lc */
            areturn
         3: .line 109
      StackMap locals: org.apache.logging.log4j.core.LoggerContext
      StackMap stack:
            aconst_null
            astore 6 /* loggingContextName */
        start local 6 // java.lang.String loggingContextName
         4: .line 111
            aconst_null
            astore 7
            aconst_null
            astore 8
         5: invokestatic org.apache.logging.log4j.core.net.JndiManager.getDefaultManager:()Lorg/apache/logging/log4j/core/net/JndiManager;
            astore 9 /* jndiManager */
        start local 9 // org.apache.logging.log4j.core.net.JndiManager jndiManager
         6: .line 112
            aload 9 /* jndiManager */
            ldc "java:comp/env/log4j/context-name"
            invokevirtual org.apache.logging.log4j.core.net.JndiManager.lookup:(Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 6 /* loggingContextName */
         7: .line 113
            aload 9 /* jndiManager */
            ifnull 15
            aload 9 /* jndiManager */
            invokevirtual org.apache.logging.log4j.core.net.JndiManager.close:()V
            goto 15
      StackMap locals: org.apache.logging.log4j.core.selector.JndiContextSelector java.lang.String java.lang.ClassLoader int java.net.URI org.apache.logging.log4j.core.LoggerContext java.lang.String java.lang.Throwable java.lang.Throwable org.apache.logging.log4j.core.net.JndiManager
      StackMap stack: java.lang.Throwable
         8: astore 7
            aload 9 /* jndiManager */
            ifnull 9
            aload 9 /* jndiManager */
            invokevirtual org.apache.logging.log4j.core.net.JndiManager.close:()V
        end local 9 // org.apache.logging.log4j.core.net.JndiManager jndiManager
      StackMap locals:
      StackMap stack:
         9: aload 7
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        10: astore 8
            aload 7
            ifnonnull 11
            aload 8
            astore 7
            goto 12
      StackMap locals:
      StackMap stack:
        11: aload 7
            aload 8
            if_acmpeq 12
            aload 7
            aload 8
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        12: aload 7
            athrow
      StackMap locals: org.apache.logging.log4j.core.selector.JndiContextSelector java.lang.String java.lang.ClassLoader int java.net.URI org.apache.logging.log4j.core.LoggerContext java.lang.String
      StackMap stack: javax.naming.NamingException
        13: astore 7 /* ne */
        start local 7 // javax.naming.NamingException ne
        14: .line 114
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
            ldc "Unable to lookup {}"
            ldc "java:comp/env/log4j/context-name"
            aload 7 /* ne */
            invokevirtual org.apache.logging.log4j.status.StatusLogger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        end local 7 // javax.naming.NamingException ne
        15: .line 117
      StackMap locals:
      StackMap stack:
            aload 6 /* loggingContextName */
            ifnonnull 16
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT:Lorg/apache/logging/log4j/core/LoggerContext;
            goto 17
      StackMap locals:
      StackMap stack:
        16: aload 0 /* this */
            aload 6 /* loggingContextName */
            aconst_null
            aload 4 /* configLocation */
            invokevirtual org.apache.logging.log4j.core.selector.JndiContextSelector.locateContext:(Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
      StackMap locals:
      StackMap stack: org.apache.logging.log4j.core.LoggerContext
        17: areturn
        end local 6 // java.lang.String loggingContextName
        end local 5 // org.apache.logging.log4j.core.LoggerContext lc
        end local 4 // java.net.URI configLocation
        end local 3 // boolean currentContext
        end local 2 // java.lang.ClassLoader loader
        end local 1 // java.lang.String fqcn
        end local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   18     0                this  Lorg/apache/logging/log4j/core/selector/JndiContextSelector;
            0   18     1                fqcn  Ljava/lang/String;
            0   18     2              loader  Ljava/lang/ClassLoader;
            0   18     3      currentContext  Z
            0   18     4      configLocation  Ljava/net/URI;
            1   18     5                  lc  Lorg/apache/logging/log4j/core/LoggerContext;
            4   18     6  loggingContextName  Ljava/lang/String;
            6    9     9         jndiManager  Lorg/apache/logging/log4j/core/net/JndiManager;
           14   15     7                  ne  Ljavax/naming/NamingException;
      Exception table:
        from    to  target  type
           6     7       8  any
           5    10      10  any
           4    13      13  Class javax.naming.NamingException
    MethodParameters:
                Name  Flags
      fqcn            final
      loader          final
      currentContext  final
      configLocation  final

  public org.apache.logging.log4j.core.LoggerContext locateContext(java.lang.String, java.lang.Object, java.net.URI);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
        start local 1 // java.lang.String name
        start local 2 // java.lang.Object externalContext
        start local 3 // java.net.URI configLocation
         0: .line 122
            aload 1 /* name */
            ifnonnull 3
         1: .line 123
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
            ldc "A context name is required to locate a LoggerContext"
            invokevirtual org.apache.logging.log4j.status.StatusLogger.error:(Ljava/lang/String;)V
         2: .line 124
            aconst_null
            areturn
         3: .line 126
      StackMap locals:
      StackMap stack:
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* name */
            invokeinterface java.util.concurrent.ConcurrentMap.containsKey:(Ljava/lang/Object;)Z
            ifne 6
         4: .line 127
            new org.apache.logging.log4j.core.LoggerContext
            dup
            aload 1 /* name */
            aload 2 /* externalContext */
            aload 3 /* configLocation */
            invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)V
            astore 4 /* ctx */
        start local 4 // org.apache.logging.log4j.core.LoggerContext ctx
         5: .line 128
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* name */
            aload 4 /* ctx */
            invokeinterface java.util.concurrent.ConcurrentMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 4 // org.apache.logging.log4j.core.LoggerContext ctx
         6: .line 130
      StackMap locals:
      StackMap stack:
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* name */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.LoggerContext
            areturn
        end local 3 // java.net.URI configLocation
        end local 2 // java.lang.Object externalContext
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    7     0             this  Lorg/apache/logging/log4j/core/selector/JndiContextSelector;
            0    7     1             name  Ljava/lang/String;
            0    7     2  externalContext  Ljava/lang/Object;
            0    7     3   configLocation  Ljava/net/URI;
            5    6     4              ctx  Lorg/apache/logging/log4j/core/LoggerContext;
    MethodParameters:
                 Name  Flags
      name             final
      externalContext  final
      configLocation   final

  public void removeContext(org.apache.logging.log4j.core.LoggerContext);
    descriptor: (Lorg/apache/logging/log4j/core/LoggerContext;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
        start local 1 // org.apache.logging.log4j.core.LoggerContext context
         0: .line 136
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.logging.log4j.core.selector.JndiContextSelector org.apache.logging.log4j.core.LoggerContext top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         2: .line 137
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.LoggerContext
            aload 1 /* context */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 4
         3: .line 138
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 136
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         5: .line 141
            return
        end local 1 // org.apache.logging.log4j.core.LoggerContext context
        end local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0     this  Lorg/apache/logging/log4j/core/selector/JndiContextSelector;
            0    6     1  context  Lorg/apache/logging/log4j/core/LoggerContext;
            2    4     2    entry  Ljava/util/Map$Entry<Ljava/lang/String;Lorg/apache/logging/log4j/core/LoggerContext;>;
    MethodParameters:
         Name  Flags
      context  final

  public org.apache.logging.log4j.core.LoggerContext removeContext(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/apache/logging/log4j/core/LoggerContext;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
        start local 1 // java.lang.String name
         0: .line 145
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* name */
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.LoggerContext
            areturn
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/selector/JndiContextSelector;
            0    1     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  final

  public java.util.List<org.apache.logging.log4j.core.LoggerContext> getLoggerContexts();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
         0: .line 150
            new java.util.ArrayList
            dup
            getstatic org.apache.logging.log4j.core.selector.JndiContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.values:()Ljava/util/Collection;
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
            areturn
        end local 0 // org.apache.logging.log4j.core.selector.JndiContextSelector this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/selector/JndiContextSelector;
    Signature: ()Ljava/util/List<Lorg/apache/logging/log4j/core/LoggerContext;>;
}
SourceFile: "JndiContextSelector.java"
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map