public class org.apache.logging.log4j.core.async.AsyncLoggerContext extends org.apache.logging.log4j.core.LoggerContext
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.async.AsyncLoggerContext
  super_class: org.apache.logging.log4j.core.LoggerContext
{
  private final org.apache.logging.log4j.core.async.AsyncLoggerDisruptor loggerDisruptor;
    descriptor: Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // java.lang.String name
         0: .line 38
            aload 0 /* this */
            aload 1 /* name */
            invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;)V
         1: .line 39
            aload 0 /* this */
            new org.apache.logging.log4j.core.async.AsyncLoggerDisruptor
            dup
            aload 1 /* name */
            invokespecial org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.<init>:(Ljava/lang/String;)V
            putfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
         2: .line 40
            return
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    3     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  final

  public void <init>(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // java.lang.String name
        start local 2 // java.lang.Object externalContext
         0: .line 43
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* externalContext */
            invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
         1: .line 44
            aload 0 /* this */
            new org.apache.logging.log4j.core.async.AsyncLoggerDisruptor
            dup
            aload 1 /* name */
            invokespecial org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.<init>:(Ljava/lang/String;)V
            putfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
         2: .line 45
            return
        end local 2 // java.lang.Object externalContext
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    3     1             name  Ljava/lang/String;
            0    3     2  externalContext  Ljava/lang/Object;
    MethodParameters:
                 Name  Flags
      name             final
      externalContext  final

  public void <init>(java.lang.String, java.lang.Object, java.net.URI);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // java.lang.String name
        start local 2 // java.lang.Object externalContext
        start local 3 // java.net.URI configLocn
         0: .line 48
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* externalContext */
            aload 3 /* configLocn */
            invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/net/URI;)V
         1: .line 49
            aload 0 /* this */
            new org.apache.logging.log4j.core.async.AsyncLoggerDisruptor
            dup
            aload 1 /* name */
            invokespecial org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.<init>:(Ljava/lang/String;)V
            putfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
         2: .line 50
            return
        end local 3 // java.net.URI configLocn
        end local 2 // java.lang.Object externalContext
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    3     1             name  Ljava/lang/String;
            0    3     2  externalContext  Ljava/lang/Object;
            0    3     3       configLocn  Ljava/net/URI;
    MethodParameters:
                 Name  Flags
      name             final
      externalContext  final
      configLocn       final

  public void <init>(java.lang.String, java.lang.Object, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // java.lang.String name
        start local 2 // java.lang.Object externalContext
        start local 3 // java.lang.String configLocn
         0: .line 53
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* externalContext */
            aload 3 /* configLocn */
            invokespecial org.apache.logging.log4j.core.LoggerContext.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;)V
         1: .line 54
            aload 0 /* this */
            new org.apache.logging.log4j.core.async.AsyncLoggerDisruptor
            dup
            aload 1 /* name */
            invokespecial org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.<init>:(Ljava/lang/String;)V
            putfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
         2: .line 55
            return
        end local 3 // java.lang.String configLocn
        end local 2 // java.lang.Object externalContext
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    3     1             name  Ljava/lang/String;
            0    3     2  externalContext  Ljava/lang/Object;
            0    3     3       configLocn  Ljava/lang/String;
    MethodParameters:
                 Name  Flags
      name             final
      externalContext  final
      configLocn       final

  protected org.apache.logging.log4j.core.Logger newInstance(org.apache.logging.log4j.core.LoggerContext, java.lang.String, org.apache.logging.log4j.message.MessageFactory);
    descriptor: (Lorg/apache/logging/log4j/core/LoggerContext;Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;)Lorg/apache/logging/log4j/core/Logger;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // org.apache.logging.log4j.core.LoggerContext ctx
        start local 2 // java.lang.String name
        start local 3 // org.apache.logging.log4j.message.MessageFactory messageFactory
         0: .line 59
            new org.apache.logging.log4j.core.async.AsyncLogger
            dup
            aload 1 /* ctx */
            aload 2 /* name */
            aload 3 /* messageFactory */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
            invokespecial org.apache.logging.log4j.core.async.AsyncLogger.<init>:(Lorg/apache/logging/log4j/core/LoggerContext;Ljava/lang/String;Lorg/apache/logging/log4j/message/MessageFactory;Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;)V
            areturn
        end local 3 // org.apache.logging.log4j.message.MessageFactory messageFactory
        end local 2 // java.lang.String name
        end local 1 // org.apache.logging.log4j.core.LoggerContext ctx
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0            this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    1     1             ctx  Lorg/apache/logging/log4j/core/LoggerContext;
            0    1     2            name  Ljava/lang/String;
            0    1     3  messageFactory  Lorg/apache/logging/log4j/message/MessageFactory;
    MethodParameters:
                Name  Flags
      ctx             final
      name            final
      messageFactory  final

  public void setName(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // java.lang.String name
         0: .line 64
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "AsyncContext["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* name */
            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;
            invokespecial org.apache.logging.log4j.core.LoggerContext.setName:(Ljava/lang/String;)V
         1: .line 65
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
            aload 1 /* name */
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.setContextName:(Ljava/lang/String;)V
         2: .line 66
            return
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    3     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  final

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
         0: .line 75
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.start:()V
         1: .line 76
            aload 0 /* this */
            invokespecial org.apache.logging.log4j.core.LoggerContext.start:()V
         2: .line 77
            return
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;

  public void start(org.apache.logging.log4j.core.config.Configuration);
    descriptor: (Lorg/apache/logging/log4j/core/config/Configuration;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // org.apache.logging.log4j.core.config.Configuration config
         0: .line 86
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerContext.maybeStartHelper:(Lorg/apache/logging/log4j/core/config/Configuration;)V
         1: .line 87
            aload 0 /* this */
            aload 1 /* config */
            invokespecial org.apache.logging.log4j.core.LoggerContext.start:(Lorg/apache/logging/log4j/core/config/Configuration;)V
         2: .line 88
            return
        end local 1 // org.apache.logging.log4j.core.config.Configuration config
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    3     1  config  Lorg/apache/logging/log4j/core/config/Configuration;
    MethodParameters:
        Name  Flags
      config  final

  private void maybeStartHelper(org.apache.logging.log4j.core.config.Configuration);
    descriptor: (Lorg/apache/logging/log4j/core/config/Configuration;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // org.apache.logging.log4j.core.config.Configuration config
         0: .line 94
            aload 1 /* config */
            instanceof org.apache.logging.log4j.core.config.DefaultConfiguration
            ifeq 3
         1: .line 95
            invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
            ldc "[{}] Not starting Disruptor for DefaultConfiguration."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerContext.getName:()Ljava/lang/String;
            invokevirtual org.apache.logging.log4j.status.StatusLogger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
         2: .line 96
            goto 4
         3: .line 97
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.start:()V
         4: .line 99
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.logging.log4j.core.config.Configuration config
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    5     1  config  Lorg/apache/logging/log4j/core/config/Configuration;
    MethodParameters:
        Name  Flags
      config  final

  public boolean stop(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit timeUnit
         0: .line 103
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerContext.setStopping:()V
         1: .line 105
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
            lload 1 /* timeout */
            aload 3 /* timeUnit */
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.stop:(JLjava/util/concurrent/TimeUnit;)Z
            pop
         2: .line 106
            aload 0 /* this */
            lload 1 /* timeout */
            aload 3 /* timeUnit */
            invokespecial org.apache.logging.log4j.core.LoggerContext.stop:(JLjava/util/concurrent/TimeUnit;)Z
            pop
         3: .line 107
            iconst_1
            ireturn
        end local 3 // java.util.concurrent.TimeUnit timeUnit
        end local 1 // long timeout
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    4     1   timeout  J
            0    4     3  timeUnit  Ljava/util/concurrent/TimeUnit;
    MethodParameters:
          Name  Flags
      timeout   final
      timeUnit  final

  public org.apache.logging.log4j.core.jmx.RingBufferAdmin createRingBufferAdmin();
    descriptor: ()Lorg/apache/logging/log4j/core/jmx/RingBufferAdmin;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
         0: .line 117
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerContext.getName:()Ljava/lang/String;
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.createRingBufferAdmin:(Ljava/lang/String;)Lorg/apache/logging/log4j/core/jmx/RingBufferAdmin;
            areturn
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;

  public void setUseThreadLocals(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
        start local 1 // boolean useThreadLocals
         0: .line 125
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.async.AsyncLoggerContext.loggerDisruptor:Lorg/apache/logging/log4j/core/async/AsyncLoggerDisruptor;
            iload 1 /* useThreadLocals */
            invokevirtual org.apache.logging.log4j.core.async.AsyncLoggerDisruptor.setUseThreadLocals:(Z)V
         1: .line 126
            return
        end local 1 // boolean useThreadLocals
        end local 0 // org.apache.logging.log4j.core.async.AsyncLoggerContext this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Lorg/apache/logging/log4j/core/async/AsyncLoggerContext;
            0    2     1  useThreadLocals  Z
    MethodParameters:
                 Name  Flags
      useThreadLocals  final
}
SourceFile: "AsyncLoggerContext.java"