public class ch.qos.logback.classic.selector.ContextJNDISelector implements ch.qos.logback.classic.selector.ContextSelector
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: ch.qos.logback.classic.selector.ContextJNDISelector
super_class: java.lang.Object
{
private final java.util.Map<java.lang.String, ch.qos.logback.classic.LoggerContext> synchronizedContextMap;
descriptor: Ljava/util/Map;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Map<Ljava/lang/String;Lch/qos/logback/classic/LoggerContext;>;
private final ch.qos.logback.classic.LoggerContext defaultContext;
descriptor: Lch/qos/logback/classic/LoggerContext;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private static final java.lang.ThreadLocal<ch.qos.logback.classic.LoggerContext> threadLocal;
descriptor: Ljava/lang/ThreadLocal;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/lang/ThreadLocal<Lch/qos/logback/classic/LoggerContext;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new java.lang.ThreadLocal
dup
invokespecial java.lang.ThreadLocal.<init>:()V
putstatic ch.qos.logback.classic.selector.ContextJNDISelector.threadLocal:Ljava/lang/ThreadLocal;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(ch.qos.logback.classic.LoggerContext);
descriptor: (Lch/qos/logback/classic/LoggerContext;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.HashMap
dup
invokespecial java.util.HashMap.<init>:()V
invokestatic java.util.Collections.synchronizedMap:(Ljava/util/Map;)Ljava/util/Map;
putfield ch.qos.logback.classic.selector.ContextJNDISelector.synchronizedContextMap:Ljava/util/Map;
2: aload 0
aload 1
putfield ch.qos.logback.classic.selector.ContextJNDISelector.defaultContext:Lch/qos/logback/classic/LoggerContext;
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
0 4 1 context Lch/qos/logback/classic/LoggerContext;
MethodParameters:
Name Flags
context
public ch.qos.logback.classic.LoggerContext getDefaultLoggerContext();
descriptor: ()Lch/qos/logback/classic/LoggerContext;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield ch.qos.logback.classic.selector.ContextJNDISelector.defaultContext:Lch/qos/logback/classic/LoggerContext;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
public ch.qos.logback.classic.LoggerContext detachLoggerContext(java.lang.String);
descriptor: (Ljava/lang/String;)Lch/qos/logback/classic/LoggerContext;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield ch.qos.logback.classic.selector.ContextJNDISelector.synchronizedContextMap:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast ch.qos.logback.classic.LoggerContext
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
0 1 1 loggerContextName Ljava/lang/String;
MethodParameters:
Name Flags
loggerContextName
public ch.qos.logback.classic.LoggerContext getLoggerContext();
descriptor: ()Lch/qos/logback/classic/LoggerContext;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=1
start local 0 0: aconst_null
astore 1
start local 1 1: aconst_null
astore 2
start local 2 2: getstatic ch.qos.logback.classic.selector.ContextJNDISelector.threadLocal:Ljava/lang/ThreadLocal;
invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
checkcast ch.qos.logback.classic.LoggerContext
astore 3
start local 3 3: aload 3
ifnull 5
4: aload 3
areturn
5: StackMap locals: java.lang.String javax.naming.Context ch.qos.logback.classic.LoggerContext
StackMap stack:
invokestatic ch.qos.logback.classic.util.JNDIUtil.getInitialContext:()Ljavax/naming/Context;
astore 2
6: aload 2
ldc "java:comp/env/logback/context-name"
invokestatic ch.qos.logback.classic.util.JNDIUtil.lookup:(Ljavax/naming/Context;Ljava/lang/String;)Ljava/lang/String;
astore 1
7: goto 9
StackMap locals:
StackMap stack: javax.naming.NamingException
8: pop
9: StackMap locals:
StackMap stack:
aload 1
ifnonnull 11
10: aload 0
getfield ch.qos.logback.classic.selector.ContextJNDISelector.defaultContext:Lch/qos/logback/classic/LoggerContext;
areturn
11: StackMap locals:
StackMap stack:
aload 0
getfield ch.qos.logback.classic.selector.ContextJNDISelector.synchronizedContextMap:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast ch.qos.logback.classic.LoggerContext
astore 4
start local 4 12: aload 4
ifnonnull 25
13: new ch.qos.logback.classic.LoggerContext
dup
invokespecial ch.qos.logback.classic.LoggerContext.<init>:()V
astore 4
14: aload 4
aload 1
invokevirtual ch.qos.logback.classic.LoggerContext.setName:(Ljava/lang/String;)V
15: aload 0
getfield ch.qos.logback.classic.selector.ContextJNDISelector.synchronizedContextMap:Ljava/util/Map;
aload 1
aload 4
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
16: aload 0
aload 2
aload 4
invokevirtual ch.qos.logback.classic.selector.ContextJNDISelector.findConfigFileURL:(Ljavax/naming/Context;Lch/qos/logback/classic/LoggerContext;)Ljava/net/URL;
astore 5
start local 5 17: aload 5
ifnull 20
18: aload 0
aload 4
aload 5
invokevirtual ch.qos.logback.classic.selector.ContextJNDISelector.configureLoggerContextByURL:(Lch/qos/logback/classic/LoggerContext;Ljava/net/URL;)V
19: goto 23
20: StackMap locals: ch.qos.logback.classic.LoggerContext java.net.URL
StackMap stack:
new ch.qos.logback.classic.util.ContextInitializer
dup
aload 4
invokespecial ch.qos.logback.classic.util.ContextInitializer.<init>:(Lch/qos/logback/classic/LoggerContext;)V
invokevirtual ch.qos.logback.classic.util.ContextInitializer.autoConfig:()V
21: goto 23
StackMap locals:
StackMap stack: ch.qos.logback.core.joran.spi.JoranException
22: pop
23: StackMap locals:
StackMap stack:
aload 4
invokestatic ch.qos.logback.core.status.StatusUtil.contextHasStatusListener:(Lch/qos/logback/core/Context;)Z
ifne 25
24: aload 4
invokestatic ch.qos.logback.core.util.StatusPrinter.printInCaseOfErrorsOrWarnings:(Lch/qos/logback/core/Context;)V
end local 5 25: StackMap locals:
StackMap stack:
aload 4
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 26 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
1 26 1 contextName Ljava/lang/String;
2 26 2 ctx Ljavax/naming/Context;
3 26 3 lc Lch/qos/logback/classic/LoggerContext;
12 26 4 loggerContext Lch/qos/logback/classic/LoggerContext;
17 25 5 url Ljava/net/URL;
Exception table:
from to target type
5 7 8 Class javax.naming.NamingException
20 21 22 Class ch.qos.logback.core.joran.spi.JoranException
private java.lang.String conventionalConfigFileName(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: new java.lang.StringBuilder
dup
ldc "logback-"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc ".xml"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
0 1 1 contextName Ljava/lang/String;
MethodParameters:
Name Flags
contextName
private java.net.URL findConfigFileURL(javax.naming.Context, ch.qos.logback.classic.LoggerContext);
descriptor: (Ljavax/naming/Context;Lch/qos/logback/classic/LoggerContext;)Ljava/net/URL;
flags: (0x0002) ACC_PRIVATE
Code:
stack=6, locals=7, args_size=3
start local 0 start local 1 start local 2 0: aload 2
invokevirtual ch.qos.logback.classic.LoggerContext.getStatusManager:()Lch/qos/logback/core/status/StatusManager;
astore 3
start local 3 1: aload 1
ldc "java:comp/env/logback/configuration-resource"
invokestatic ch.qos.logback.classic.util.JNDIUtil.lookup:(Ljavax/naming/Context;Ljava/lang/String;)Ljava/lang/String;
astore 4
start local 4 2: aload 4
ifnull 11
3: aload 3
new ch.qos.logback.core.status.InfoStatus
dup
new java.lang.StringBuilder
dup
ldc "Searching for ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "]"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 0
invokespecial ch.qos.logback.core.status.InfoStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
invokeinterface ch.qos.logback.core.status.StatusManager.add:(Lch/qos/logback/core/status/Status;)V
4: aload 0
aload 3
aload 4
invokevirtual ch.qos.logback.classic.selector.ContextJNDISelector.urlByResourceName:(Lch/qos/logback/core/status/StatusManager;Ljava/lang/String;)Ljava/net/URL;
astore 5
start local 5 5: aload 5
ifnonnull 10
6: new java.lang.StringBuilder
dup
ldc "The jndi resource ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "] for context ["
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 2
invokevirtual ch.qos.logback.classic.LoggerContext.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
7: ldc "] does not lead to a valid file"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
8: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
astore 6
start local 6 9: aload 3
new ch.qos.logback.core.status.WarnStatus
dup
aload 6
aload 0
invokespecial ch.qos.logback.core.status.WarnStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
invokeinterface ch.qos.logback.core.status.StatusManager.add:(Lch/qos/logback/core/status/Status;)V
end local 6 10: StackMap locals: ch.qos.logback.core.status.StatusManager java.lang.String java.net.URL
StackMap stack:
aload 5
areturn
end local 5 11: StackMap locals:
StackMap stack:
aload 0
aload 2
invokevirtual ch.qos.logback.classic.LoggerContext.getName:()Ljava/lang/String;
invokevirtual ch.qos.logback.classic.selector.ContextJNDISelector.conventionalConfigFileName:(Ljava/lang/String;)Ljava/lang/String;
astore 5
start local 5 12: aload 0
aload 3
aload 5
invokevirtual ch.qos.logback.classic.selector.ContextJNDISelector.urlByResourceName:(Lch/qos/logback/core/status/StatusManager;Ljava/lang/String;)Ljava/net/URL;
areturn
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 13 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
0 13 1 ctx Ljavax/naming/Context;
0 13 2 loggerContext Lch/qos/logback/classic/LoggerContext;
1 13 3 sm Lch/qos/logback/core/status/StatusManager;
2 13 4 jndiEntryForConfigResource Ljava/lang/String;
5 11 5 url Ljava/net/URL;
9 10 6 msg Ljava/lang/String;
12 13 5 resourceByConvention Ljava/lang/String;
MethodParameters:
Name Flags
ctx
loggerContext
private java.net.URL urlByResourceName(ch.qos.logback.core.status.StatusManager, java.lang.String);
descriptor: (Lch/qos/logback/core/status/StatusManager;Ljava/lang/String;)Ljava/net/URL;
flags: (0x0002) ACC_PRIVATE
Code:
stack=6, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 1
new ch.qos.logback.core.status.InfoStatus
dup
new java.lang.StringBuilder
dup
ldc "Searching for ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "]"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 0
invokespecial ch.qos.logback.core.status.InfoStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
invokeinterface ch.qos.logback.core.status.StatusManager.add:(Lch/qos/logback/core/status/Status;)V
1: aload 2
invokestatic ch.qos.logback.core.util.Loader.getTCL:()Ljava/lang/ClassLoader;
invokestatic ch.qos.logback.core.util.Loader.getResource:(Ljava/lang/String;Ljava/lang/ClassLoader;)Ljava/net/URL;
astore 3
start local 3 2: aload 3
ifnull 4
3: aload 3
areturn
4: StackMap locals: java.net.URL
StackMap stack:
aload 2
invokestatic ch.qos.logback.core.util.Loader.getResourceBySelfClassLoader:(Ljava/lang/String;)Ljava/net/URL;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
0 5 1 sm Lch/qos/logback/core/status/StatusManager;
0 5 2 resourceName Ljava/lang/String;
2 5 3 url Ljava/net/URL;
MethodParameters:
Name Flags
sm
resourceName
private void configureLoggerContextByURL(ch.qos.logback.classic.LoggerContext, java.net.URL);
descriptor: (Lch/qos/logback/classic/LoggerContext;Ljava/net/URL;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=4, args_size=3
start local 0 start local 1 start local 2 0: new ch.qos.logback.classic.joran.JoranConfigurator
dup
invokespecial ch.qos.logback.classic.joran.JoranConfigurator.<init>:()V
astore 3
start local 3 1: aload 1
invokevirtual ch.qos.logback.classic.LoggerContext.reset:()V
2: aload 3
aload 1
invokevirtual ch.qos.logback.classic.joran.JoranConfigurator.setContext:(Lch/qos/logback/core/Context;)V
3: aload 3
aload 2
invokevirtual ch.qos.logback.classic.joran.JoranConfigurator.doConfigure:(Ljava/net/URL;)V
end local 3 4: goto 6
StackMap locals:
StackMap stack: ch.qos.logback.core.joran.spi.JoranException
5: pop
6: StackMap locals:
StackMap stack:
aload 1
invokestatic ch.qos.logback.core.util.StatusPrinter.printInCaseOfErrorsOrWarnings:(Lch/qos/logback/core/Context;)V
7: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
0 8 1 context Lch/qos/logback/classic/LoggerContext;
0 8 2 url Ljava/net/URL;
1 4 3 configurator Lch/qos/logback/classic/joran/JoranConfigurator;
Exception table:
from to target type
0 4 5 Class ch.qos.logback.core.joran.spi.JoranException
MethodParameters:
Name Flags
context
url
public java.util.List<java.lang.String> getContextNames();
descriptor: ()Ljava/util/List;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 1
start local 1 1: aload 1
aload 0
getfield ch.qos.logback.classic.selector.ContextJNDISelector.synchronizedContextMap:Ljava/util/Map;
invokeinterface java.util.Map.keySet:()Ljava/util/Set;
invokeinterface java.util.List.addAll:(Ljava/util/Collection;)Z
pop
2: aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
1 3 1 list Ljava/util/List<Ljava/lang/String;>;
Signature: ()Ljava/util/List<Ljava/lang/String;>;
public ch.qos.logback.classic.LoggerContext getLoggerContext(java.lang.String);
descriptor: (Ljava/lang/String;)Lch/qos/logback/classic/LoggerContext;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield ch.qos.logback.classic.selector.ContextJNDISelector.synchronizedContextMap:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast ch.qos.logback.classic.LoggerContext
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
0 1 1 name Ljava/lang/String;
MethodParameters:
Name Flags
name
public int getCount();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield ch.qos.logback.classic.selector.ContextJNDISelector.synchronizedContextMap:Ljava/util/Map;
invokeinterface java.util.Map.size:()I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
public void setLocalContext(ch.qos.logback.classic.LoggerContext);
descriptor: (Lch/qos/logback/classic/LoggerContext;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: getstatic ch.qos.logback.classic.selector.ContextJNDISelector.threadLocal:Ljava/lang/ThreadLocal;
aload 1
invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
0 2 1 context Lch/qos/logback/classic/LoggerContext;
MethodParameters:
Name Flags
context
public void removeLocalContext();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: getstatic ch.qos.logback.classic.selector.ContextJNDISelector.threadLocal:Ljava/lang/ThreadLocal;
invokevirtual java.lang.ThreadLocal.remove:()V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lch/qos/logback/classic/selector/ContextJNDISelector;
}
SourceFile: "ContextJNDISelector.java"