class org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory implements org.apache.logging.log4j.core.appender.ManagerFactory<org.apache.logging.log4j.core.appender.FileManager, org.apache.logging.log4j.core.appender.FileManager$FactoryData>
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory
  super_class: java.lang.Object
{
  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory this
         0: .line 406
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/appender/FileManager$FileManagerFactory;

  public org.apache.logging.log4j.core.appender.FileManager createManager(java.lang.String, org.apache.logging.log4j.core.appender.FileManager$FactoryData);
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/appender/FileManager$FactoryData;)Lorg/apache/logging/log4j/core/appender/FileManager;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=15, locals=9, args_size=3
        start local 0 // org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory this
        start local 1 // java.lang.String name
        start local 2 // org.apache.logging.log4j.core.appender.FileManager$FactoryData data
         0: .line 416
            new java.io.File
            dup
            aload 1 /* name */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 3 /* file */
        start local 3 // java.io.File file
         1: .line 418
            aload 3 /* file */
            invokestatic org.apache.logging.log4j.core.util.FileUtils.makeParentDirs:(Ljava/io/File;)V
         2: .line 419
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.append:Z
            ifeq 3
            aload 3 /* file */
            invokevirtual java.io.File.exists:()Z
            ifeq 3
            iconst_0
            goto 4
      StackMap locals: java.io.File
      StackMap stack:
         3: iconst_1
      StackMap locals:
      StackMap stack: int
         4: istore 4 /* writeHeader */
        start local 4 // boolean writeHeader
         5: .line 420
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.bufferedIo:Z
            ifeq 6
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.bufferSize:I
            goto 7
      StackMap locals: int
      StackMap stack:
         6: getstatic org.apache.logging.log4j.core.util.Constants.ENCODER_BYTE_BUFFER_SIZE:I
      StackMap locals:
      StackMap stack: int
         7: istore 5 /* actualSize */
        start local 5 // int actualSize
         8: .line 421
            iload 5 /* actualSize */
            newarray 8
            invokestatic java.nio.ByteBuffer.wrap:([B)Ljava/nio/ByteBuffer;
            astore 6 /* byteBuffer */
        start local 6 // java.nio.ByteBuffer byteBuffer
         9: .line 422
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.createOnDemand:Z
            ifeq 10
            aconst_null
            goto 11
      StackMap locals: int java.nio.ByteBuffer
      StackMap stack:
        10: new java.io.FileOutputStream
            dup
            aload 3 /* file */
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.append:Z
            invokespecial java.io.FileOutputStream.<init>:(Ljava/io/File;Z)V
      StackMap locals:
      StackMap stack: java.io.FileOutputStream
        11: astore 7 /* fos */
        start local 7 // java.io.FileOutputStream fos
        12: .line 423
            new org.apache.logging.log4j.core.appender.FileManager
            dup
            aload 2 /* data */
            invokevirtual org.apache.logging.log4j.core.appender.FileManager$FactoryData.getLoggerContext:()Lorg/apache/logging/log4j/core/LoggerContext;
            aload 1 /* name */
            aload 7 /* fos */
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.append:Z
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.locking:Z
        13: .line 424
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.createOnDemand:Z
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.advertiseURI:Ljava/lang/String;
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.layout:Lorg/apache/logging/log4j/core/Layout;
        14: .line 425
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.filePermissions:Ljava/lang/String;
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.fileOwner:Ljava/lang/String;
            aload 2 /* data */
            getfield org.apache.logging.log4j.core.appender.FileManager$FactoryData.fileGroup:Ljava/lang/String;
            iload 4 /* writeHeader */
            aload 6 /* byteBuffer */
        15: .line 423
            invokespecial org.apache.logging.log4j.core.appender.FileManager.<init>:(Lorg/apache/logging/log4j/core/LoggerContext;Ljava/lang/String;Ljava/io/OutputStream;ZZZLjava/lang/String;Lorg/apache/logging/log4j/core/Layout;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZLjava/nio/ByteBuffer;)V
            astore 8 /* fm */
        start local 8 // org.apache.logging.log4j.core.appender.FileManager fm
        16: .line 426
            aload 7 /* fos */
            ifnull 18
            aload 8 /* fm */
            getfield org.apache.logging.log4j.core.appender.FileManager.attributeViewEnabled:Z
            ifeq 18
        17: .line 427
            aload 8 /* fm */
            aload 3 /* file */
            invokevirtual java.io.File.toPath:()Ljava/nio/file/Path;
            invokevirtual org.apache.logging.log4j.core.appender.FileManager.defineAttributeView:(Ljava/nio/file/Path;)V
        18: .line 429
      StackMap locals: java.io.FileOutputStream org.apache.logging.log4j.core.appender.FileManager
      StackMap stack:
            aload 8 /* fm */
        19: areturn
        end local 8 // org.apache.logging.log4j.core.appender.FileManager fm
        end local 7 // java.io.FileOutputStream fos
        end local 6 // java.nio.ByteBuffer byteBuffer
        end local 5 // int actualSize
        end local 4 // boolean writeHeader
        20: .line 430
      StackMap locals: org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory java.lang.String org.apache.logging.log4j.core.appender.FileManager$FactoryData java.io.File
      StackMap stack: java.io.IOException
            astore 4 /* ex */
        start local 4 // java.io.IOException ex
        21: .line 431
            getstatic org.apache.logging.log4j.core.appender.FileManager.LOGGER:Lorg/apache/logging/log4j/Logger;
            new java.lang.StringBuilder
            dup
            ldc "FileManager ("
            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;
            aload 4 /* ex */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 4 /* ex */
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 4 // java.io.IOException ex
        22: .line 433
            aconst_null
            areturn
        end local 3 // java.io.File file
        end local 2 // org.apache.logging.log4j.core.appender.FileManager$FactoryData data
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   23     0         this  Lorg/apache/logging/log4j/core/appender/FileManager$FileManagerFactory;
            0   23     1         name  Ljava/lang/String;
            0   23     2         data  Lorg/apache/logging/log4j/core/appender/FileManager$FactoryData;
            1   23     3         file  Ljava/io/File;
            5   20     4  writeHeader  Z
            8   20     5   actualSize  I
            9   20     6   byteBuffer  Ljava/nio/ByteBuffer;
           12   20     7          fos  Ljava/io/FileOutputStream;
           16   20     8           fm  Lorg/apache/logging/log4j/core/appender/FileManager;
           21   22     4           ex  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1    19      20  Class java.io.IOException
    MethodParameters:
      Name  Flags
      name  final
      data  final

  public java.lang.Object createManager(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            aload 2
            checkcast org.apache.logging.log4j.core.appender.FileManager$FactoryData
            invokevirtual org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory.createManager:(Ljava/lang/String;Lorg/apache/logging/log4j/core/appender/FileManager$FactoryData;)Lorg/apache/logging/log4j/core/appender/FileManager;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
Signature: Ljava/lang/Object;Lorg/apache/logging/log4j/core/appender/ManagerFactory<Lorg/apache/logging/log4j/core/appender/FileManager;Lorg/apache/logging/log4j/core/appender/FileManager$FactoryData;>;
SourceFile: "FileManager.java"
NestHost: org.apache.logging.log4j.core.appender.FileManager
InnerClasses:
  private FactoryData = org.apache.logging.log4j.core.appender.FileManager$FactoryData of org.apache.logging.log4j.core.appender.FileManager
  private FileManagerFactory = org.apache.logging.log4j.core.appender.FileManager$FileManagerFactory of org.apache.logging.log4j.core.appender.FileManager