public class org.apache.logging.log4j.core.selector.ClassLoaderContextSelector implements org.apache.logging.log4j.core.selector.ContextSelector
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.logging.log4j.core.selector.ClassLoaderContextSelector
super_class: java.lang.Object
{
private static final java.util.concurrent.atomic.AtomicReference<org.apache.logging.log4j.core.LoggerContext> DEFAULT_CONTEXT;
descriptor: Ljava/util/concurrent/atomic/AtomicReference;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicReference<Lorg/apache/logging/log4j/core/LoggerContext;>;
protected static final org.apache.logging.log4j.status.StatusLogger LOGGER;
descriptor: Lorg/apache/logging/log4j/status/StatusLogger;
flags: (0x001c) ACC_PROTECTED, ACC_STATIC, ACC_FINAL
protected static final java.util.concurrent.ConcurrentMap<java.lang.String, java.util.concurrent.atomic.AtomicReference<java.lang.ref.WeakReference<org.apache.logging.log4j.core.LoggerContext>>> CONTEXT_MAP;
descriptor: Ljava/util/concurrent/ConcurrentMap;
flags: (0x001c) ACC_PROTECTED, ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/lang/String;Ljava/util/concurrent/atomic/AtomicReference<Ljava/lang/ref/WeakReference<Lorg/apache/logging/log4j/core/LoggerContext;>;>;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new java.util.concurrent.atomic.AtomicReference
dup
invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
putstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.DEFAULT_CONTEXT:Ljava/util/concurrent/atomic/AtomicReference;
1: invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
putstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
2: new java.util.concurrent.ConcurrentHashMap
dup
invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
3: putstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
4: 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 0: aload 0
invokespecial java.lang.Object.<init>:()V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
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 start local 1 start local 2 start local 3 0: aload 0
aload 1
aload 2
iload 3
aconst_null
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.getContext:(Ljava/lang/String;Ljava/lang/ClassLoader;ZLjava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
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=3, locals=7, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: iload 3
ifeq 5
1: 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
start local 5 2: aload 5
ifnull 4
3: aload 5
areturn
4: StackMap locals: org.apache.logging.log4j.core.LoggerContext
StackMap stack:
aload 0
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.getDefault:()Lorg/apache/logging/log4j/core/LoggerContext;
areturn
end local 5 5: StackMap locals:
StackMap stack:
aload 2
ifnull 7
6: aload 0
aload 2
aload 4
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.locateContext:(Ljava/lang/ClassLoader;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
areturn
7: StackMap locals:
StackMap stack:
aload 1
invokestatic org.apache.logging.log4j.util.StackLocatorUtil.getCallerClass:(Ljava/lang/String;)Ljava/lang/Class;
astore 5
start local 5 8: aload 5
ifnull 10
9: aload 0
aload 5
invokevirtual java.lang.Class.getClassLoader:()Ljava/lang/ClassLoader;
aload 4
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.locateContext:(Ljava/lang/ClassLoader;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
areturn
10: StackMap locals: java.lang.Class
StackMap stack:
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 6
start local 6 11: aload 6
ifnull 13
12: aload 6
areturn
13: StackMap locals: org.apache.logging.log4j.core.LoggerContext
StackMap stack:
aload 0
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.getDefault:()Lorg/apache/logging/log4j/core/LoggerContext;
areturn
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
0 14 1 fqcn Ljava/lang/String;
0 14 2 loader Ljava/lang/ClassLoader;
0 14 3 currentContext Z
0 14 4 configLocation Ljava/net/URI;
2 5 5 ctx Lorg/apache/logging/log4j/core/LoggerContext;
8 14 5 clazz Ljava/lang/Class<*>;
11 14 6 lc Lorg/apache/logging/log4j/core/LoggerContext;
MethodParameters:
Name Flags
fqcn final
loader final
currentContext 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=5, args_size=2
start local 0 start local 1 0: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.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 5
StackMap locals: org.apache.logging.log4j.core.selector.ClassLoaderContextSelector 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
start local 2 2: aload 2
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast java.util.concurrent.atomic.AtomicReference
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.lang.ref.WeakReference
invokevirtual java.lang.ref.WeakReference.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.LoggerContext
astore 4
start local 4 3: aload 4
aload 1
if_acmpne 5
4: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
aload 2
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
pop
end local 4 end local 2 5: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 1
6: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
0 7 1 context Lorg/apache/logging/log4j/core/LoggerContext;
2 5 2 entry Ljava/util/Map$Entry<Ljava/lang/String;Ljava/util/concurrent/atomic/AtomicReference<Ljava/lang/ref/WeakReference<Lorg/apache/logging/log4j/core/LoggerContext;>;>;>;
3 5 4 ctx Lorg/apache/logging/log4j/core/LoggerContext;
MethodParameters:
Name Flags
context final
public java.util.List<org.apache.logging.log4j.core.LoggerContext> getLoggerContexts();
descriptor: ()Ljava/util/List;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=6, args_size=1
start local 0 0: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 1
start local 1 1: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
invokeinterface java.util.concurrent.ConcurrentMap.values:()Ljava/util/Collection;
astore 2
start local 2 2: aload 2
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 4
goto 7
StackMap locals: org.apache.logging.log4j.core.selector.ClassLoaderContextSelector java.util.List java.util.Collection top java.util.Iterator
StackMap stack:
3: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.util.concurrent.atomic.AtomicReference
astore 3
start local 3 4: aload 3
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.lang.ref.WeakReference
invokevirtual java.lang.ref.WeakReference.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.LoggerContext
astore 5
start local 5 5: aload 5
ifnull 7
6: aload 1
aload 5
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 5 end local 3 7: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 3
8: aload 1
invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
1 9 1 list Ljava/util/List<Lorg/apache/logging/log4j/core/LoggerContext;>;
2 9 2 coll Ljava/util/Collection<Ljava/util/concurrent/atomic/AtomicReference<Ljava/lang/ref/WeakReference<Lorg/apache/logging/log4j/core/LoggerContext;>;>;>;
4 7 3 ref Ljava/util/concurrent/atomic/AtomicReference<Ljava/lang/ref/WeakReference<Lorg/apache/logging/log4j/core/LoggerContext;>;>;
5 7 5 ctx Lorg/apache/logging/log4j/core/LoggerContext;
Signature: ()Ljava/util/List<Lorg/apache/logging/log4j/core/LoggerContext;>;
private org.apache.logging.log4j.core.LoggerContext locateContext(java.lang.ClassLoader, java.net.URI);
descriptor: (Ljava/lang/ClassLoader;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=9, args_size=3
start local 0 start local 1 start local 2 0: aload 1
ifnull 1
aload 1
goto 2
StackMap locals:
StackMap stack:
1: invokestatic java.lang.ClassLoader.getSystemClassLoader:()Ljava/lang/ClassLoader;
StackMap locals:
StackMap stack: java.lang.ClassLoader
2: astore 3
start local 3 3: aload 0
aload 3
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.toContextMapKey:(Ljava/lang/ClassLoader;)Ljava/lang/String;
astore 4
start local 4 4: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
aload 4
invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.util.concurrent.atomic.AtomicReference
astore 5
start local 5 5: aload 5
ifnonnull 23
6: aload 2
ifnonnull 17
7: aload 3
invokevirtual java.lang.ClassLoader.getParent:()Ljava/lang/ClassLoader;
astore 6
start local 6 8: goto 16
9: StackMap locals: org.apache.logging.log4j.core.selector.ClassLoaderContextSelector java.lang.ClassLoader java.net.URI java.lang.ClassLoader java.lang.String java.util.concurrent.atomic.AtomicReference java.lang.ClassLoader
StackMap stack:
getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
aload 0
aload 6
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.toContextMapKey:(Ljava/lang/ClassLoader;)Ljava/lang/String;
invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.util.concurrent.atomic.AtomicReference
astore 5
10: aload 5
ifnull 15
11: aload 5
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.lang.ref.WeakReference
astore 7
start local 7 12: aload 7
invokevirtual java.lang.ref.WeakReference.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.LoggerContext
astore 8
start local 8 13: aload 8
ifnull 15
14: aload 8
areturn
end local 8 end local 7 15: StackMap locals:
StackMap stack:
aload 6
invokevirtual java.lang.ClassLoader.getParent:()Ljava/lang/ClassLoader;
astore 6
16: StackMap locals:
StackMap stack:
aload 6
ifnonnull 9
end local 6 17: StackMap locals:
StackMap stack:
aload 0
aload 4
aload 2
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.createContext:(Ljava/lang/String;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
astore 6
start local 6 18: new java.util.concurrent.atomic.AtomicReference
dup
invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
astore 7
start local 7 19: aload 7
new java.lang.ref.WeakReference
dup
aload 6
invokespecial java.lang.ref.WeakReference.<init>:(Ljava/lang/Object;)V
invokevirtual java.util.concurrent.atomic.AtomicReference.set:(Ljava/lang/Object;)V
20: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
aload 4
aload 7
invokeinterface java.util.concurrent.ConcurrentMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
21: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.CONTEXT_MAP:Ljava/util/concurrent/ConcurrentMap;
aload 4
invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.util.concurrent.atomic.AtomicReference
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.lang.ref.WeakReference
invokevirtual java.lang.ref.WeakReference.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.LoggerContext
astore 6
22: aload 6
areturn
end local 7 end local 6 23: StackMap locals:
StackMap stack:
aload 5
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.lang.ref.WeakReference
astore 6
start local 6 24: aload 6
invokevirtual java.lang.ref.WeakReference.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.LoggerContext
astore 7
start local 7 25: aload 7
ifnull 36
26: aload 7
invokevirtual org.apache.logging.log4j.core.LoggerContext.getConfigLocation:()Ljava/net/URI;
ifnonnull 30
aload 2
ifnull 30
27: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
ldc "Setting configuration to {}"
aload 2
invokevirtual org.apache.logging.log4j.status.StatusLogger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
28: aload 7
aload 2
invokevirtual org.apache.logging.log4j.core.LoggerContext.setConfigLocation:(Ljava/net/URI;)V
29: goto 35
StackMap locals: java.lang.ref.WeakReference org.apache.logging.log4j.core.LoggerContext
StackMap stack:
30: aload 7
invokevirtual org.apache.logging.log4j.core.LoggerContext.getConfigLocation:()Ljava/net/URI;
ifnull 35
aload 2
ifnull 35
31: aload 7
invokevirtual org.apache.logging.log4j.core.LoggerContext.getConfigLocation:()Ljava/net/URI;
aload 2
invokevirtual java.net.URI.equals:(Ljava/lang/Object;)Z
ifne 35
32: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
ldc "locateContext called with URI {}. Existing LoggerContext has URI {}"
aload 2
33: aload 7
invokevirtual org.apache.logging.log4j.core.LoggerContext.getConfigLocation:()Ljava/net/URI;
34: invokevirtual org.apache.logging.log4j.status.StatusLogger.warn:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
35: StackMap locals:
StackMap stack:
aload 7
areturn
36: StackMap locals:
StackMap stack:
aload 0
aload 4
aload 2
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.createContext:(Ljava/lang/String;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
astore 7
37: aload 5
aload 6
new java.lang.ref.WeakReference
dup
aload 7
invokespecial java.lang.ref.WeakReference.<init>:(Ljava/lang/Object;)V
invokevirtual java.util.concurrent.atomic.AtomicReference.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Z
pop
38: aload 7
areturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 39 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
0 39 1 loaderOrNull Ljava/lang/ClassLoader;
0 39 2 configLocation Ljava/net/URI;
3 39 3 loader Ljava/lang/ClassLoader;
4 39 4 name Ljava/lang/String;
5 39 5 ref Ljava/util/concurrent/atomic/AtomicReference<Ljava/lang/ref/WeakReference<Lorg/apache/logging/log4j/core/LoggerContext;>;>;
8 17 6 parent Ljava/lang/ClassLoader;
12 15 7 r Ljava/lang/ref/WeakReference<Lorg/apache/logging/log4j/core/LoggerContext;>;
13 15 8 ctx Lorg/apache/logging/log4j/core/LoggerContext;
18 23 6 ctx Lorg/apache/logging/log4j/core/LoggerContext;
19 23 7 r Ljava/util/concurrent/atomic/AtomicReference<Ljava/lang/ref/WeakReference<Lorg/apache/logging/log4j/core/LoggerContext;>;>;
24 39 6 weakRef Ljava/lang/ref/WeakReference<Lorg/apache/logging/log4j/core/LoggerContext;>;
25 39 7 ctx Lorg/apache/logging/log4j/core/LoggerContext;
MethodParameters:
Name Flags
loaderOrNull final
configLocation final
protected org.apache.logging.log4j.core.LoggerContext createContext(java.lang.String, java.net.URI);
descriptor: (Ljava/lang/String;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=3, args_size=3
start local 0 start local 1 start local 2 0: new org.apache.logging.log4j.core.LoggerContext
dup
aload 1
aconst_null
aload 2
invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)V
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
0 1 1 name Ljava/lang/String;
0 1 2 configLocation Ljava/net/URI;
MethodParameters:
Name Flags
name final
configLocation final
protected java.lang.String toContextMapKey(java.lang.ClassLoader);
descriptor: (Ljava/lang/ClassLoader;)Ljava/lang/String;
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokestatic java.lang.System.identityHashCode:(Ljava/lang/Object;)I
invokestatic java.lang.Integer.toHexString:(I)Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
0 1 1 loader Ljava/lang/ClassLoader;
MethodParameters:
Name Flags
loader final
protected org.apache.logging.log4j.core.LoggerContext getDefault();
descriptor: ()Lorg/apache/logging/log4j/core/LoggerContext;
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=2, args_size=1
start local 0 0: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.DEFAULT_CONTEXT:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.LoggerContext
astore 1
start local 1 1: aload 1
ifnull 3
2: aload 1
areturn
3: StackMap locals: org.apache.logging.log4j.core.LoggerContext
StackMap stack:
getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.DEFAULT_CONTEXT:Ljava/util/concurrent/atomic/AtomicReference;
aconst_null
aload 0
aload 0
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.defaultContextName:()Ljava/lang/String;
aconst_null
invokevirtual org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.createContext:(Ljava/lang/String;Ljava/net/URI;)Lorg/apache/logging/log4j/core/LoggerContext;
invokevirtual java.util.concurrent.atomic.AtomicReference.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Z
pop
4: getstatic org.apache.logging.log4j.core.selector.ClassLoaderContextSelector.DEFAULT_CONTEXT:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.LoggerContext
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
1 5 1 ctx Lorg/apache/logging/log4j/core/LoggerContext;
protected java.lang.String defaultContextName();
descriptor: ()Ljava/lang/String;
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: ldc "Default"
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/selector/ClassLoaderContextSelector;
}
SourceFile: "ClassLoaderContextSelector.java"
InnerClasses:
public abstract Entry = java.util.Map$Entry of java.util.Map