public class ch.qos.logback.classic.selector.servlet.ContextDetachingSCL implements javax.servlet.ServletContextListener
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: ch.qos.logback.classic.selector.servlet.ContextDetachingSCL
super_class: java.lang.Object
{
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 // ch.qos.logback.classic.selector.servlet.ContextDetachingSCL this
0: .line 30
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
return
end local 0 // ch.qos.logback.classic.selector.servlet.ContextDetachingSCL this
LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/selector/servlet/ContextDetachingSCL;
public void contextInitialized(javax.servlet.ServletContextEvent);
descriptor: (Ljavax/servlet/ServletContextEvent;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=0, locals=2, args_size=2
start local 0 // ch.qos.logback.classic.selector.servlet.ContextDetachingSCL this
start local 1 // javax.servlet.ServletContextEvent arg0
0: .line 34
return
end local 1 // javax.servlet.ServletContextEvent arg0
end local 0 // ch.qos.logback.classic.selector.servlet.ContextDetachingSCL this
LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/selector/servlet/ContextDetachingSCL;
0 1 1 arg0 Ljavax/servlet/ServletContextEvent;
MethodParameters:
Name Flags
arg0
public void contextDestroyed(javax.servlet.ServletContextEvent);
descriptor: (Ljavax/servlet/ServletContextEvent;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=6, args_size=2
start local 0 // ch.qos.logback.classic.selector.servlet.ContextDetachingSCL this
start local 1 // javax.servlet.ServletContextEvent servletContextEvent
0: .line 37
aconst_null
astore 2 /* loggerContextName */
start local 2 // java.lang.String loggerContextName
1: .line 40
invokestatic ch.qos.logback.classic.util.JNDIUtil.getInitialContext:()Ljavax/naming/Context;
astore 3 /* ctx */
start local 3 // javax.naming.Context ctx
2: .line 41
aload 3 /* ctx */
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 2 /* loggerContextName */
end local 3 // javax.naming.Context ctx
3: .line 42
goto 5
StackMap locals: ch.qos.logback.classic.selector.servlet.ContextDetachingSCL javax.servlet.ServletContextEvent java.lang.String
StackMap stack: javax.naming.NamingException
4: pop
5: .line 45
StackMap locals:
StackMap stack:
aload 2 /* loggerContextName */
ifnull 19
6: .line 46
getstatic java.lang.System.out:Ljava/io/PrintStream;
new java.lang.StringBuilder
dup
ldc "About to detach context named "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2 /* loggerContextName */
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
7: .line 48
invokestatic ch.qos.logback.classic.util.ContextSelectorStaticBinder.getSingleton:()Lch/qos/logback/classic/util/ContextSelectorStaticBinder;
invokevirtual ch.qos.logback.classic.util.ContextSelectorStaticBinder.getContextSelector:()Lch/qos/logback/classic/selector/ContextSelector;
astore 3 /* selector */
start local 3 // ch.qos.logback.classic.selector.ContextSelector selector
8: .line 49
aload 3 /* selector */
ifnonnull 11
9: .line 50
getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Selector is null, cannot detach context. Skipping."
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
10: .line 51
return
11: .line 53
StackMap locals: ch.qos.logback.classic.selector.ContextSelector
StackMap stack:
aload 3 /* selector */
aload 2 /* loggerContextName */
invokeinterface ch.qos.logback.classic.selector.ContextSelector.getLoggerContext:(Ljava/lang/String;)Lch/qos/logback/classic/LoggerContext;
astore 4 /* context */
start local 4 // ch.qos.logback.classic.LoggerContext context
12: .line 54
aload 4 /* context */
ifnull 18
13: .line 55
aload 4 /* context */
ldc "ROOT"
invokevirtual ch.qos.logback.classic.LoggerContext.getLogger:(Ljava/lang/String;)Lch/qos/logback/classic/Logger;
astore 5 /* logger */
start local 5 // org.slf4j.Logger logger
14: .line 56
aload 5 /* logger */
new java.lang.StringBuilder
dup
ldc "Stopping logger context "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2 /* loggerContextName */
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;)V
15: .line 57
aload 3 /* selector */
aload 2 /* loggerContextName */
invokeinterface ch.qos.logback.classic.selector.ContextSelector.detachLoggerContext:(Ljava/lang/String;)Lch/qos/logback/classic/LoggerContext;
pop
16: .line 59
aload 4 /* context */
invokevirtual ch.qos.logback.classic.LoggerContext.stop:()V
end local 5 // org.slf4j.Logger logger
17: .line 60
goto 19
18: .line 61
StackMap locals: ch.qos.logback.classic.LoggerContext
StackMap stack:
getstatic java.lang.System.out:Ljava/io/PrintStream;
new java.lang.StringBuilder
dup
ldc "No context named "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2 /* loggerContextName */
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " was found."
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
end local 4 // ch.qos.logback.classic.LoggerContext context
end local 3 // ch.qos.logback.classic.selector.ContextSelector selector
19: .line 64
StackMap locals:
StackMap stack:
return
end local 2 // java.lang.String loggerContextName
end local 1 // javax.servlet.ServletContextEvent servletContextEvent
end local 0 // ch.qos.logback.classic.selector.servlet.ContextDetachingSCL this
LocalVariableTable:
Start End Slot Name Signature
0 20 0 this Lch/qos/logback/classic/selector/servlet/ContextDetachingSCL;
0 20 1 servletContextEvent Ljavax/servlet/ServletContextEvent;
1 20 2 loggerContextName Ljava/lang/String;
2 3 3 ctx Ljavax/naming/Context;
8 19 3 selector Lch/qos/logback/classic/selector/ContextSelector;
12 19 4 context Lch/qos/logback/classic/LoggerContext;
14 17 5 logger Lorg/slf4j/Logger;
Exception table:
from to target type
1 3 4 Class javax.naming.NamingException
MethodParameters:
Name Flags
servletContextEvent
}
SourceFile: "ContextDetachingSCL.java"