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"