public abstract class org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender<T extends org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager> extends org.apache.logging.log4j.core.appender.AbstractAppender
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender
  super_class: org.apache.logging.log4j.core.appender.AbstractAppender
{
  public static final int DEFAULT_RECONNECT_INTERVAL_MILLIS;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 5000

  private final java.util.concurrent.locks.ReadWriteLock lock;
    descriptor: Ljava/util/concurrent/locks/ReadWriteLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.locks.Lock readLock;
    descriptor: Ljava/util/concurrent/locks/Lock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.locks.Lock writeLock;
    descriptor: Ljava/util/concurrent/locks/Lock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private T manager;
    descriptor: Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
    flags: (0x0002) ACC_PRIVATE
    Signature: TT;

  protected void <init>(java.lang.String, org.apache.logging.log4j.core.Filter, boolean, );
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;ZLorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=5, args_size=5
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
        start local 1 // java.lang.String name
        start local 2 // org.apache.logging.log4j.core.Filter filter
        start local 3 // boolean ignoreExceptions
        start local 4 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager manager
         0: .line 67
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* filter */
            aconst_null
            iload 3 /* ignoreExceptions */
            getstatic org.apache.logging.log4j.core.config.Property.EMPTY_ARRAY:[Lorg/apache/logging/log4j/core/config/Property;
            invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;)V
         1: .line 49
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantReadWriteLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:()V
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
         2: .line 50
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
         3: .line 51
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
         4: .line 68
            aload 0 /* this */
            aload 4 /* manager */
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
         5: .line 69
            return
        end local 4 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager manager
        end local 3 // boolean ignoreExceptions
        end local 2 // org.apache.logging.log4j.core.Filter filter
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    6     0              this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
            0    6     1              name  Ljava/lang/String;
            0    6     2            filter  Lorg/apache/logging/log4j/core/Filter;
            0    6     3  ignoreExceptions  Z
            0    6     4           manager  TT;
    Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;ZTT;)V
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()
    MethodParameters:
                  Name  Flags
      name              final
      filter            final
      ignoreExceptions  final
      manager           final

  protected void <init>(java.lang.String, org.apache.logging.log4j.core.Filter, org.apache.logging.log4j.core.Layout<? extends java.io.Serializable>, boolean, org.apache.logging.log4j.core.config.Property[], );
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=7, args_size=7
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
        start local 1 // java.lang.String name
        start local 2 // org.apache.logging.log4j.core.Filter filter
        start local 3 // org.apache.logging.log4j.core.Layout layout
        start local 4 // boolean ignoreExceptions
        start local 5 // org.apache.logging.log4j.core.config.Property[] properties
        start local 6 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager manager
         0: .line 84
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* filter */
            aload 3 /* layout */
            iload 4 /* ignoreExceptions */
            aload 5 /* properties */
            invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;)V
         1: .line 49
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantReadWriteLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:()V
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
         2: .line 50
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
         3: .line 51
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
         4: .line 85
            aload 0 /* this */
            aload 6 /* manager */
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
         5: .line 86
            return
        end local 6 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager manager
        end local 5 // org.apache.logging.log4j.core.config.Property[] properties
        end local 4 // boolean ignoreExceptions
        end local 3 // org.apache.logging.log4j.core.Layout layout
        end local 2 // org.apache.logging.log4j.core.Filter filter
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    6     0              this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
            0    6     1              name  Ljava/lang/String;
            0    6     2            filter  Lorg/apache/logging/log4j/core/Filter;
            0    6     3            layout  Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;
            0    6     4  ignoreExceptions  Z
            0    6     5        properties  [Lorg/apache/logging/log4j/core/config/Property;
            0    6     6           manager  TT;
    Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;Z[Lorg/apache/logging/log4j/core/config/Property;TT;)V
    MethodParameters:
                  Name  Flags
      name              final
      filter            final
      layout            final
      ignoreExceptions  final
      properties        final
      manager           final

  protected void <init>(java.lang.String, org.apache.logging.log4j.core.Filter, org.apache.logging.log4j.core.Layout<? extends java.io.Serializable>, boolean, );
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;ZLorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=6, args_size=6
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
        start local 1 // java.lang.String name
        start local 2 // org.apache.logging.log4j.core.Filter filter
        start local 3 // org.apache.logging.log4j.core.Layout layout
        start local 4 // boolean ignoreExceptions
        start local 5 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager manager
         0: .line 102
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* filter */
            aload 3 /* layout */
            iload 4 /* ignoreExceptions */
            getstatic org.apache.logging.log4j.core.config.Property.EMPTY_ARRAY:[Lorg/apache/logging/log4j/core/config/Property;
            invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;)V
         1: .line 49
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantReadWriteLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:()V
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
         2: .line 50
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
         3: .line 51
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
         4: .line 103
            aload 0 /* this */
            aload 5 /* manager */
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
         5: .line 104
            return
        end local 5 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager manager
        end local 4 // boolean ignoreExceptions
        end local 3 // org.apache.logging.log4j.core.Layout layout
        end local 2 // org.apache.logging.log4j.core.Filter filter
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    6     0              this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
            0    6     1              name  Ljava/lang/String;
            0    6     2            filter  Lorg/apache/logging/log4j/core/Filter;
            0    6     3            layout  Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;
            0    6     4  ignoreExceptions  Z
            0    6     5           manager  TT;
    Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;ZTT;)V
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()
    MethodParameters:
                  Name  Flags
      name              final
      filter            final
      layout            final
      ignoreExceptions  final
      manager           final

  public final void append(org.apache.logging.log4j.core.LogEvent);
    descriptor: (Lorg/apache/logging/log4j/core/LogEvent;)V
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
        start local 1 // org.apache.logging.log4j.core.LogEvent event
         0: .line 108
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 110
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            aload 1 /* event */
            aload 0 /* this */
            aload 1 /* event */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.toSerializable:(Lorg/apache/logging/log4j/core/LogEvent;)Ljava/io/Serializable;
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.write:(Lorg/apache/logging/log4j/core/LogEvent;Ljava/io/Serializable;)V
         2: .line 111
            goto 16
      StackMap locals:
      StackMap stack: org.apache.logging.log4j.LoggingException
         3: astore 2 /* e */
        start local 2 // org.apache.logging.log4j.LoggingException e
         4: .line 112
            getstatic org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Unable to write to database [{}] for appender [{}]."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.getName:()Ljava/lang/String;
         5: .line 113
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getName:()Ljava/lang/String;
            aload 2 /* e */
         6: .line 112
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         7: .line 114
            aload 2 /* e */
            athrow
        end local 2 // org.apache.logging.log4j.LoggingException e
         8: .line 115
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 2 /* e */
        start local 2 // java.lang.Exception e
         9: .line 116
            getstatic org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Unable to write to database [{}] for appender [{}]."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.getName:()Ljava/lang/String;
        10: .line 117
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getName:()Ljava/lang/String;
            aload 2 /* e */
        11: .line 116
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        12: .line 118
            new org.apache.logging.log4j.core.appender.AppenderLoggingException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unable to write to database in appender: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* e */
            invokespecial org.apache.logging.log4j.core.appender.AppenderLoggingException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.lang.Exception e
        13: .line 119
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 3
        14: .line 120
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        15: .line 121
            aload 3
            athrow
        16: .line 120
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        17: .line 122
            return
        end local 1 // org.apache.logging.log4j.core.LogEvent event
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   18     0   this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
            0   18     1  event  Lorg/apache/logging/log4j/core/LogEvent;
            4    8     2      e  Lorg/apache/logging/log4j/LoggingException;
            9   13     2      e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     2       3  Class org.apache.logging.log4j.LoggingException
           1     2       8  Class java.lang.Exception
           1    13      13  any
    MethodParameters:
       Name  Flags
      event  final

  public final org.apache.logging.log4j.core.Layout<org.apache.logging.log4j.core.LogEvent> getLayout();
    descriptor: ()Lorg/apache/logging/log4j/core/Layout;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
         0: .line 132
            aconst_null
            areturn
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
    Signature: ()Lorg/apache/logging/log4j/core/Layout<Lorg/apache/logging/log4j/core/LogEvent;>;

  public final T getManager();
    descriptor: ()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
         0: .line 141
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            areturn
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
    Signature: ()TT;

  protected final void replaceManager();
    descriptor: (Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;)V
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
        start local 1 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager manager
         0: .line 152
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 154
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            astore 2 /* old */
        start local 2 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager old
         2: .line 155
            aload 1 /* manager */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.isRunning:()Z
            ifne 4
         3: .line 156
            aload 1 /* manager */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.startup:()V
         4: .line 158
      StackMap locals: org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager
      StackMap stack:
            aload 0 /* this */
            aload 1 /* manager */
            putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
         5: .line 159
            aload 2 /* old */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.close:()V
        end local 2 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager old
         6: .line 160
            goto 10
      StackMap locals: org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager
      StackMap stack: java.lang.Throwable
         7: astore 3
         8: .line 161
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         9: .line 162
            aload 3
            athrow
        10: .line 161
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        11: .line 163
            return
        end local 1 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager manager
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   12     0     this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
            0   12     1  manager  TT;
            2    6     2      old  TT;
      Exception table:
        from    to  target  type
           1     7       7  any
    Signature: (TT;)V
    MethodParameters:
         Name  Flags
      manager  final

  public final void start();
    descriptor: ()V
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
         0: .line 167
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            ifnonnull 2
         1: .line 168
            getstatic org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "No AbstractDatabaseManager set for the appender named [{}]."
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getName:()Ljava/lang/String;
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;)V
         2: .line 170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.start:()V
         3: .line 171
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            ifnull 5
         4: .line 172
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.startup:()V
         5: .line 174
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;

  public boolean stop(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit timeUnit
         0: .line 178
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.setStopping:()V
         1: .line 179
            aload 0 /* this */
            lload 1 /* timeout */
            aload 3 /* timeUnit */
            iconst_0
            invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.stop:(JLjava/util/concurrent/TimeUnit;Z)Z
            istore 4 /* stopped */
        start local 4 // boolean stopped
         2: .line 180
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            ifnull 4
         3: .line 181
            iload 4 /* stopped */
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
            lload 1 /* timeout */
            aload 3 /* timeUnit */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.stop:(JLjava/util/concurrent/TimeUnit;)Z
            iand
            istore 4 /* stopped */
         4: .line 183
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.setStopped:()V
         5: .line 184
            iload 4 /* stopped */
            ireturn
        end local 4 // boolean stopped
        end local 3 // java.util.concurrent.TimeUnit timeUnit
        end local 1 // long timeout
        end local 0 // org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
            0    6     1   timeout  J
            0    6     3  timeUnit  Ljava/util/concurrent/TimeUnit;
            2    6     4   stopped  Z
    MethodParameters:
          Name  Flags
      timeout   final
      timeUnit  final
}
Signature: <T:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;>Lorg/apache/logging/log4j/core/appender/AbstractAppender;
SourceFile: "AbstractDatabaseAppender.java"
NestMembers:
  org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender$Builder
InnerClasses:
  public Builder = org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender$Builder of org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender