final class org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl extends org.apache.logging.log4j.core.appender.routing.RoutingAppender$RouteAppenderControl
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl
  super_class: org.apache.logging.log4j.core.appender.routing.RoutingAppender$RouteAppenderControl
{
  private volatile boolean pendingDeletion;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private final java.util.concurrent.atomic.AtomicInteger depth;
    descriptor: Ljava/util/concurrent/atomic/AtomicInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  void <init>(org.apache.logging.log4j.core.Appender);
    descriptor: (Lorg/apache/logging/log4j/core/Appender;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl this
        start local 1 // org.apache.logging.log4j.core.Appender appender
         0: .line 441
            aload 0 /* this */
            aload 1 /* appender */
            invokespecial org.apache.logging.log4j.core.appender.routing.RoutingAppender$RouteAppenderControl.<init>:(Lorg/apache/logging/log4j/core/Appender;)V
         1: .line 437
            aload 0 /* this */
            iconst_0
            putfield org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.pendingDeletion:Z
         2: .line 438
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicInteger
            dup
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
            putfield org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.depth:Ljava/util/concurrent/atomic/AtomicInteger;
         3: .line 442
            return
        end local 1 // org.apache.logging.log4j.core.Appender appender
        end local 0 // org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender$CreatedRouteAppenderControl;
            0    4     1  appender  Lorg/apache/logging/log4j/core/Appender;
    MethodParameters:
          Name  Flags
      appender  

  void checkout();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl this
         0: .line 446
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.pendingDeletion:Z
            ifeq 2
         1: .line 447
            getstatic org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "CreatedRouteAppenderControl.checkout invoked on a RouteAppenderControl that is pending deletion"
            invokeinterface org.apache.logging.log4j.Logger.warn:(Ljava/lang/String;)V
         2: .line 450
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.depth:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.incrementAndGet:()I
            pop
         3: .line 451
            return
        end local 0 // org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender$CreatedRouteAppenderControl;

  void release();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl this
         0: .line 455
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.depth:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.decrementAndGet:()I
            pop
         1: .line 456
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.tryStopAppender:()V
         2: .line 457
            return
        end local 0 // org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender$CreatedRouteAppenderControl;

  void tryStopAppender();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl this
         0: .line 460
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.pendingDeletion:Z
            ifeq 5
         1: .line 464
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.depth:Ljava/util/concurrent/atomic/AtomicInteger;
            iconst_0
            ldc -100000
            invokevirtual java.util.concurrent.atomic.AtomicInteger.compareAndSet:(II)Z
            ifeq 5
         2: .line 465
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.getAppender:()Lorg/apache/logging/log4j/core/Appender;
            astore 1 /* appender */
        start local 1 // org.apache.logging.log4j.core.Appender appender
         3: .line 466
            getstatic org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Stopping appender {}"
            aload 1 /* appender */
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
         4: .line 467
            aload 1 /* appender */
            invokeinterface org.apache.logging.log4j.core.Appender.stop:()V
        end local 1 // org.apache.logging.log4j.core.Appender appender
         5: .line 469
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender$CreatedRouteAppenderControl;
            3    5     1  appender  Lorg/apache/logging/log4j/core/Appender;
}
SourceFile: "RoutingAppender.java"
NestHost: org.apache.logging.log4j.core.appender.routing.RoutingAppender
InnerClasses:
  private final CreatedRouteAppenderControl = org.apache.logging.log4j.core.appender.routing.RoutingAppender$CreatedRouteAppenderControl of org.apache.logging.log4j.core.appender.routing.RoutingAppender
  private abstract RouteAppenderControl = org.apache.logging.log4j.core.appender.routing.RoutingAppender$RouteAppenderControl of org.apache.logging.log4j.core.appender.routing.RoutingAppender