public class org.apache.logging.log4j.core.AbstractLifeCycle implements org.apache.logging.log4j.core.LifeCycle2
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.AbstractLifeCycle
  super_class: java.lang.Object
{
  public static final int DEFAULT_STOP_TIMEOUT;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  public static final java.util.concurrent.TimeUnit DEFAULT_STOP_TIMEUNIT;
    descriptor: Ljava/util/concurrent/TimeUnit;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  protected static final org.apache.logging.log4j.Logger LOGGER;
    descriptor: Lorg/apache/logging/log4j/Logger;
    flags: (0x001c) ACC_PROTECTED, ACC_STATIC, ACC_FINAL

  private volatile org.apache.logging.log4j.core.LifeCycle$State state;
    descriptor: Lorg/apache/logging/log4j/core/LifeCycle$State;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 33
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            putstatic org.apache.logging.log4j.core.AbstractLifeCycle.DEFAULT_STOP_TIMEUNIT:Ljava/util/concurrent/TimeUnit;
         1: .line 38
            invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
            putstatic org.apache.logging.log4j.core.AbstractLifeCycle.LOGGER:Lorg/apache/logging/log4j/Logger;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 30
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 49
            aload 0 /* this */
            getstatic org.apache.logging.log4j.core.LifeCycle$State.INITIALIZED:Lorg/apache/logging/log4j/core/LifeCycle$State;
            putfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
         2: .line 30
            return
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  protected static org.apache.logging.log4j.Logger getStatusLogger();
    descriptor: ()Lorg/apache/logging/log4j/Logger;
    flags: (0x000c) ACC_PROTECTED, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 46
            getstatic org.apache.logging.log4j.core.AbstractLifeCycle.LOGGER:Lorg/apache/logging/log4j/Logger;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  protected boolean equalsImpl(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
        start local 1 // java.lang.Object obj
         0: .line 52
            aload 0 /* this */
            aload 1 /* obj */
            if_acmpne 2
         1: .line 53
            iconst_1
            ireturn
         2: .line 55
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            ifnonnull 4
         3: .line 56
            iconst_0
            ireturn
         4: .line 58
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            aload 1 /* obj */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            if_acmpeq 6
         5: .line 59
            iconst_0
            ireturn
         6: .line 61
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            checkcast org.apache.logging.log4j.core.LifeCycle
            astore 2 /* other */
        start local 2 // org.apache.logging.log4j.core.LifeCycle other
         7: .line 62
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            aload 2 /* other */
            invokeinterface org.apache.logging.log4j.core.LifeCycle.getState:()Lorg/apache/logging/log4j/core/LifeCycle$State;
            if_acmpeq 9
         8: .line 63
            iconst_0
            ireturn
         9: .line 65
      StackMap locals: org.apache.logging.log4j.core.LifeCycle
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // org.apache.logging.log4j.core.LifeCycle other
        end local 1 // java.lang.Object obj
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   10     0   this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;
            0   10     1    obj  Ljava/lang/Object;
            7   10     2  other  Lorg/apache/logging/log4j/core/LifeCycle;
    MethodParameters:
      Name  Flags
      obj   final

  public org.apache.logging.log4j.core.LifeCycle$State getState();
    descriptor: ()Lorg/apache/logging/log4j/core/LifeCycle$State;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 70
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            areturn
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  protected int hashCodeImpl();
    descriptor: ()I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 75
            iconst_1
            istore 1 /* result */
        start local 1 // int result
         1: .line 76
            bipush 31
            iload 1 /* result */
            imul
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            ifnonnull 2
            iconst_0
            goto 3
      StackMap locals: org.apache.logging.log4j.core.AbstractLifeCycle int
      StackMap stack: int
         2: aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            invokevirtual org.apache.logging.log4j.core.LifeCycle$State.hashCode:()I
      StackMap locals: org.apache.logging.log4j.core.AbstractLifeCycle int
      StackMap stack: int int
         3: iadd
            istore 1 /* result */
         4: .line 77
            iload 1 /* result */
            ireturn
        end local 1 // int result
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;
            1    5     1  result  I

  public boolean isInitialized();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 81
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            getstatic org.apache.logging.log4j.core.LifeCycle$State.INITIALIZED:Lorg/apache/logging/log4j/core/LifeCycle$State;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  public boolean isStarted();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 86
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STARTED:Lorg/apache/logging/log4j/core/LifeCycle$State;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  public boolean isStarting();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 90
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STARTING:Lorg/apache/logging/log4j/core/LifeCycle$State;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  public boolean isStopped();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 95
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STOPPED:Lorg/apache/logging/log4j/core/LifeCycle$State;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  public boolean isStopping();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 99
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STOPPING:Lorg/apache/logging/log4j/core/LifeCycle$State;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  protected void setStarted();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 103
            aload 0 /* this */
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STARTED:Lorg/apache/logging/log4j/core/LifeCycle$State;
            invokevirtual org.apache.logging.log4j.core.AbstractLifeCycle.setState:(Lorg/apache/logging/log4j/core/LifeCycle$State;)V
         1: .line 104
            return
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  protected void setStarting();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 107
            aload 0 /* this */
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STARTING:Lorg/apache/logging/log4j/core/LifeCycle$State;
            invokevirtual org.apache.logging.log4j.core.AbstractLifeCycle.setState:(Lorg/apache/logging/log4j/core/LifeCycle$State;)V
         1: .line 108
            return
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  protected void setState(org.apache.logging.log4j.core.LifeCycle$State);
    descriptor: (Lorg/apache/logging/log4j/core/LifeCycle$State;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
        start local 1 // org.apache.logging.log4j.core.LifeCycle$State newState
         0: .line 111
            aload 0 /* this */
            aload 1 /* newState */
            putfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
         1: .line 114
            return
        end local 1 // org.apache.logging.log4j.core.LifeCycle$State newState
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;
            0    2     1  newState  Lorg/apache/logging/log4j/core/LifeCycle$State;
    MethodParameters:
          Name  Flags
      newState  final

  protected void setStopped();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 117
            aload 0 /* this */
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STOPPED:Lorg/apache/logging/log4j/core/LifeCycle$State;
            invokevirtual org.apache.logging.log4j.core.AbstractLifeCycle.setState:(Lorg/apache/logging/log4j/core/LifeCycle$State;)V
         1: .line 118
            return
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  protected void setStopping();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 121
            aload 0 /* this */
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STOPPING:Lorg/apache/logging/log4j/core/LifeCycle$State;
            invokevirtual org.apache.logging.log4j.core.AbstractLifeCycle.setState:(Lorg/apache/logging/log4j/core/LifeCycle$State;)V
         1: .line 122
            return
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  public void initialize();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 126
            aload 0 /* this */
            getstatic org.apache.logging.log4j.core.LifeCycle$State.INITIALIZED:Lorg/apache/logging/log4j/core/LifeCycle$State;
            putfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
         1: .line 127
            return
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  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.AbstractLifeCycle this
         0: .line 131
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.AbstractLifeCycle.setStarted:()V
         1: .line 132
            return
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  public void stop();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
         0: .line 136
            aload 0 /* this */
            lconst_0
            getstatic org.apache.logging.log4j.core.AbstractLifeCycle.DEFAULT_STOP_TIMEUNIT:Ljava/util/concurrent/TimeUnit;
            invokevirtual org.apache.logging.log4j.core.AbstractLifeCycle.stop:(JLjava/util/concurrent/TimeUnit;)Z
            pop
         1: .line 137
            return
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;

  protected boolean stop(java.util.concurrent.Future<?>);
    descriptor: (Ljava/util/concurrent/Future;)Z
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
        start local 1 // java.util.concurrent.Future future
         0: .line 140
            iconst_1
            istore 2 /* stopped */
        start local 2 // boolean stopped
         1: .line 141
            aload 1 /* future */
            ifnull 5
         2: .line 142
            aload 1 /* future */
            invokeinterface java.util.concurrent.Future.isCancelled:()Z
            ifne 3
            aload 1 /* future */
            invokeinterface java.util.concurrent.Future.isDone:()Z
            ifeq 4
         3: .line 143
      StackMap locals: int
      StackMap stack:
            iconst_1
            ireturn
         4: .line 145
      StackMap locals:
      StackMap stack:
            aload 1 /* future */
            iconst_1
            invokeinterface java.util.concurrent.Future.cancel:(Z)Z
            istore 2 /* stopped */
         5: .line 147
      StackMap locals:
      StackMap stack:
            iload 2 /* stopped */
            ireturn
        end local 2 // boolean stopped
        end local 1 // java.util.concurrent.Future future
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0     this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;
            0    6     1   future  Ljava/util/concurrent/Future<*>;
            1    6     2  stopped  Z
    Signature: (Ljava/util/concurrent/Future<*>;)Z
    MethodParameters:
        Name  Flags
      future  final

  public boolean stop(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit timeUnit
         0: .line 152
            aload 0 /* this */
            getstatic org.apache.logging.log4j.core.LifeCycle$State.STOPPED:Lorg/apache/logging/log4j/core/LifeCycle$State;
            putfield org.apache.logging.log4j.core.AbstractLifeCycle.state:Lorg/apache/logging/log4j/core/LifeCycle$State;
         1: .line 153
            iconst_1
            ireturn
        end local 3 // java.util.concurrent.TimeUnit timeUnit
        end local 1 // long timeout
        end local 0 // org.apache.logging.log4j.core.AbstractLifeCycle this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/logging/log4j/core/AbstractLifeCycle;
            0    2     1   timeout  J
            0    2     3  timeUnit  Ljava/util/concurrent/TimeUnit;
    MethodParameters:
          Name  Flags
      timeout   final
      timeUnit  final
}
SourceFile: "AbstractLifeCycle.java"
InnerClasses:
  public final State = org.apache.logging.log4j.core.LifeCycle$State of org.apache.logging.log4j.core.LifeCycle