public abstract class org.apache.logging.log4j.core.appender.AbstractFileAppender<M extends org.apache.logging.log4j.core.appender.OutputStreamManager> extends org.apache.logging.log4j.core.appender.AbstractOutputStreamAppender<M>
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: org.apache.logging.log4j.core.appender.AbstractFileAppender
  super_class: org.apache.logging.log4j.core.appender.AbstractOutputStreamAppender
{
  private final java.lang.String fileName;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.logging.log4j.core.net.Advertiser advertiser;
    descriptor: Lorg/apache/logging/log4j/core/net/Advertiser;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.Object advertisement;
    descriptor: Ljava/lang/Object;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private void <init>(java.lang.String, org.apache.logging.log4j.core.Layout<? extends java.io.Serializable>, org.apache.logging.log4j.core.Filter, M, java.lang.String, boolean, boolean, org.apache.logging.log4j.core.net.Advertiser);
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Layout;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/appender/OutputStreamManager;Ljava/lang/String;ZZLorg/apache/logging/log4j/core/net/Advertiser;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=10, args_size=9
        start local 0 // org.apache.logging.log4j.core.appender.AbstractFileAppender this
        start local 1 // java.lang.String name
        start local 2 // org.apache.logging.log4j.core.Layout layout
        start local 3 // org.apache.logging.log4j.core.Filter filter
        start local 4 // org.apache.logging.log4j.core.appender.OutputStreamManager manager
        start local 5 // java.lang.String filename
        start local 6 // boolean ignoreExceptions
        start local 7 // boolean immediateFlush
        start local 8 // org.apache.logging.log4j.core.net.Advertiser advertiser
         0: .line 164
            aload 0 /* this */
            aload 1 /* name */
            aload 2 /* layout */
            aload 3 /* filter */
            iload 6 /* ignoreExceptions */
            iload 7 /* immediateFlush */
            aload 4 /* manager */
            invokespecial org.apache.logging.log4j.core.appender.AbstractOutputStreamAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Layout;Lorg/apache/logging/log4j/core/Filter;ZZLorg/apache/logging/log4j/core/appender/OutputStreamManager;)V
         1: .line 165
            aload 8 /* advertiser */
            ifnull 8
         2: .line 166
            new java.util.HashMap
            dup
            aload 2 /* layout */
            invokeinterface org.apache.logging.log4j.core.Layout.getContentFormat:()Ljava/util/Map;
            invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
            astore 9 /* configuration */
        start local 9 // java.util.Map configuration
         3: .line 167
            aload 9 /* configuration */
            aload 4 /* manager */
            invokevirtual org.apache.logging.log4j.core.appender.OutputStreamManager.getContentFormat:()Ljava/util/Map;
            invokeinterface java.util.Map.putAll:(Ljava/util/Map;)V
         4: .line 168
            aload 9 /* configuration */
            ldc "contentType"
            aload 2 /* layout */
            invokeinterface org.apache.logging.log4j.core.Layout.getContentType:()Ljava/lang/String;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 169
            aload 9 /* configuration */
            ldc "name"
            aload 1 /* name */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 170
            aload 0 /* this */
            aload 8 /* advertiser */
            aload 9 /* configuration */
            invokeinterface org.apache.logging.log4j.core.net.Advertiser.advertise:(Ljava/util/Map;)Ljava/lang/Object;
            putfield org.apache.logging.log4j.core.appender.AbstractFileAppender.advertisement:Ljava/lang/Object;
        end local 9 // java.util.Map configuration
         7: .line 171
            goto 9
         8: .line 172
      StackMap locals: org.apache.logging.log4j.core.appender.AbstractFileAppender java.lang.String org.apache.logging.log4j.core.Layout org.apache.logging.log4j.core.Filter org.apache.logging.log4j.core.appender.OutputStreamManager java.lang.String int int org.apache.logging.log4j.core.net.Advertiser
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield org.apache.logging.log4j.core.appender.AbstractFileAppender.advertisement:Ljava/lang/Object;
         9: .line 174
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 5 /* filename */
            putfield org.apache.logging.log4j.core.appender.AbstractFileAppender.fileName:Ljava/lang/String;
        10: .line 175
            aload 0 /* this */
            aload 8 /* advertiser */
            putfield org.apache.logging.log4j.core.appender.AbstractFileAppender.advertiser:Lorg/apache/logging/log4j/core/net/Advertiser;
        11: .line 176
            return
        end local 8 // org.apache.logging.log4j.core.net.Advertiser advertiser
        end local 7 // boolean immediateFlush
        end local 6 // boolean ignoreExceptions
        end local 5 // java.lang.String filename
        end local 4 // org.apache.logging.log4j.core.appender.OutputStreamManager manager
        end local 3 // org.apache.logging.log4j.core.Filter filter
        end local 2 // org.apache.logging.log4j.core.Layout layout
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.appender.AbstractFileAppender this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   12     0              this  Lorg/apache/logging/log4j/core/appender/AbstractFileAppender<TM;>;
            0   12     1              name  Ljava/lang/String;
            0   12     2            layout  Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;
            0   12     3            filter  Lorg/apache/logging/log4j/core/Filter;
            0   12     4           manager  TM;
            0   12     5          filename  Ljava/lang/String;
            0   12     6  ignoreExceptions  Z
            0   12     7    immediateFlush  Z
            0   12     8        advertiser  Lorg/apache/logging/log4j/core/net/Advertiser;
            3    7     9     configuration  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
    Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;Lorg/apache/logging/log4j/core/Filter;TM;Ljava/lang/String;ZZLorg/apache/logging/log4j/core/net/Advertiser;)V
    MethodParameters:
                  Name  Flags
      name              final
      layout            final
      filter            final
      manager           final
      filename          final
      ignoreExceptions  final
      immediateFlush    final
      advertiser        final

  public java.lang.String getFileName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.AbstractFileAppender this
         0: .line 183
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.AbstractFileAppender.fileName:Ljava/lang/String;
            areturn
        end local 0 // org.apache.logging.log4j.core.appender.AbstractFileAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/appender/AbstractFileAppender<TM;>;

  public boolean stop(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.apache.logging.log4j.core.appender.AbstractFileAppender this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit timeUnit
         0: .line 188
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.AbstractFileAppender.setStopping:()V
         1: .line 189
            aload 0 /* this */
            lload 1 /* timeout */
            aload 3 /* timeUnit */
            iconst_0
            invokespecial org.apache.logging.log4j.core.appender.AbstractOutputStreamAppender.stop:(JLjava/util/concurrent/TimeUnit;Z)Z
            pop
         2: .line 190
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.AbstractFileAppender.advertiser:Lorg/apache/logging/log4j/core/net/Advertiser;
            ifnull 4
         3: .line 191
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.AbstractFileAppender.advertiser:Lorg/apache/logging/log4j/core/net/Advertiser;
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.AbstractFileAppender.advertisement:Ljava/lang/Object;
            invokeinterface org.apache.logging.log4j.core.net.Advertiser.unadvertise:(Ljava/lang/Object;)V
         4: .line 193
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.AbstractFileAppender.setStopped:()V
         5: .line 194
            iconst_1
            ireturn
        end local 3 // java.util.concurrent.TimeUnit timeUnit
        end local 1 // long timeout
        end local 0 // org.apache.logging.log4j.core.appender.AbstractFileAppender this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/apache/logging/log4j/core/appender/AbstractFileAppender<TM;>;
            0    6     1   timeout  J
            0    6     3  timeUnit  Ljava/util/concurrent/TimeUnit;
    MethodParameters:
          Name  Flags
      timeout   final
      timeUnit  final
}
Signature: <M:Lorg/apache/logging/log4j/core/appender/OutputStreamManager;>Lorg/apache/logging/log4j/core/appender/AbstractOutputStreamAppender<TM;>;
SourceFile: "AbstractFileAppender.java"
NestMembers:
  org.apache.logging.log4j.core.appender.AbstractFileAppender$Builder
InnerClasses:
  public abstract Builder = org.apache.logging.log4j.core.appender.AbstractFileAppender$Builder of org.apache.logging.log4j.core.appender.AbstractFileAppender