public class org.apache.logging.log4j.core.appender.RandomAccessFileManager extends org.apache.logging.log4j.core.appender.OutputStreamManager
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.appender.RandomAccessFileManager
  super_class: org.apache.logging.log4j.core.appender.OutputStreamManager
{
  static final int DEFAULT_BUFFER_SIZE;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 262144

  private static final org.apache.logging.log4j.core.appender.RandomAccessFileManager$RandomAccessFileManagerFactory FACTORY;
    descriptor: Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager$RandomAccessFileManagerFactory;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

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

  private final java.io.RandomAccessFile randomAccessFile;
    descriptor: Ljava/io/RandomAccessFile;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.ThreadLocal<java.lang.Boolean> isEndOfBatch;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Ljava/lang/Boolean;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 42
            new org.apache.logging.log4j.core.appender.RandomAccessFileManager$RandomAccessFileManagerFactory
            dup
            invokespecial org.apache.logging.log4j.core.appender.RandomAccessFileManager$RandomAccessFileManagerFactory.<init>:()V
            putstatic org.apache.logging.log4j.core.appender.RandomAccessFileManager.FACTORY:Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager$RandomAccessFileManagerFactory;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  protected void <init>(org.apache.logging.log4j.core.LoggerContext, java.io.RandomAccessFile, java.lang.String, java.io.OutputStream, int, java.lang.String, org.apache.logging.log4j.core.Layout<? extends java.io.Serializable>, );
    descriptor: (Lorg/apache/logging/log4j/core/LoggerContext;Ljava/io/RandomAccessFile;Ljava/lang/String;Ljava/io/OutputStream;ILjava/lang/String;Lorg/apache/logging/log4j/core/Layout;Z)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=8, locals=9, args_size=9
        start local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
        start local 1 // org.apache.logging.log4j.core.LoggerContext loggerContext
        start local 2 // java.io.RandomAccessFile file
        start local 3 // java.lang.String fileName
        start local 4 // java.io.OutputStream os
        start local 5 // int bufferSize
        start local 6 // java.lang.String advertiseURI
        start local 7 // org.apache.logging.log4j.core.Layout layout
        start local 8 // boolean writeHeader
         0: .line 51
            aload 0 /* this */
            aload 1 /* loggerContext */
            aload 4 /* os */
            aload 3 /* fileName */
            iconst_0
            aload 7 /* layout */
            iload 8 /* writeHeader */
            iload 5 /* bufferSize */
            newarray 8
            invokestatic java.nio.ByteBuffer.wrap:([B)Ljava/nio/ByteBuffer;
            invokespecial org.apache.logging.log4j.core.appender.OutputStreamManager.<init>:(Lorg/apache/logging/log4j/core/LoggerContext;Ljava/io/OutputStream;Ljava/lang/String;ZLorg/apache/logging/log4j/core/Layout;ZLjava/nio/ByteBuffer;)V
         1: .line 46
            aload 0 /* this */
            new java.lang.ThreadLocal
            dup
            invokespecial java.lang.ThreadLocal.<init>:()V
            putfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.isEndOfBatch:Ljava/lang/ThreadLocal;
         2: .line 52
            aload 0 /* this */
            aload 2 /* file */
            putfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.randomAccessFile:Ljava/io/RandomAccessFile;
         3: .line 53
            aload 0 /* this */
            aload 6 /* advertiseURI */
            putfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.advertiseURI:Ljava/lang/String;
         4: .line 54
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.isEndOfBatch:Ljava/lang/ThreadLocal;
            getstatic java.lang.Boolean.FALSE:Ljava/lang/Boolean;
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
         5: .line 55
            return
        end local 8 // boolean writeHeader
        end local 7 // org.apache.logging.log4j.core.Layout layout
        end local 6 // java.lang.String advertiseURI
        end local 5 // int bufferSize
        end local 4 // java.io.OutputStream os
        end local 3 // java.lang.String fileName
        end local 2 // java.io.RandomAccessFile file
        end local 1 // org.apache.logging.log4j.core.LoggerContext loggerContext
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    6     0           this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
            0    6     1  loggerContext  Lorg/apache/logging/log4j/core/LoggerContext;
            0    6     2           file  Ljava/io/RandomAccessFile;
            0    6     3       fileName  Ljava/lang/String;
            0    6     4             os  Ljava/io/OutputStream;
            0    6     5     bufferSize  I
            0    6     6   advertiseURI  Ljava/lang/String;
            0    6     7         layout  Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;
            0    6     8    writeHeader  Z
    Signature: (Lorg/apache/logging/log4j/core/LoggerContext;Ljava/io/RandomAccessFile;Ljava/lang/String;Ljava/io/OutputStream;ILjava/lang/String;Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;Z)V
    MethodParameters:
               Name  Flags
      loggerContext  final
      file           final
      fileName       final
      os             final
      bufferSize     final
      advertiseURI   final
      layout         final
      writeHeader    final

  public static org.apache.logging.log4j.core.appender.RandomAccessFileManager getFileManager(java.lang.String, boolean, boolean, int, java.lang.String, org.apache.logging.log4j.core.Layout<? extends java.io.Serializable>, org.apache.logging.log4j.core.config.Configuration);
    descriptor: (Ljava/lang/String;ZZILjava/lang/String;Lorg/apache/logging/log4j/core/Layout;Lorg/apache/logging/log4j/core/config/Configuration;)Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=10, locals=7, args_size=7
        start local 0 // java.lang.String fileName
        start local 1 // boolean append
        start local 2 // boolean immediateFlush
        start local 3 // int bufferSize
        start local 4 // java.lang.String advertiseURI
        start local 5 // org.apache.logging.log4j.core.Layout layout
        start local 6 // org.apache.logging.log4j.core.config.Configuration configuration
         0: .line 74
            ldc Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
            aload 0 /* fileName */
         1: .line 75
            new org.apache.logging.log4j.core.appender.RandomAccessFileManager$FactoryData
            dup
            iload 1 /* append */
            iload 2 /* immediateFlush */
            iload 3 /* bufferSize */
            aload 4 /* advertiseURI */
            aload 5 /* layout */
            aload 6 /* configuration */
            invokespecial org.apache.logging.log4j.core.appender.RandomAccessFileManager$FactoryData.<init>:(ZZILjava/lang/String;Lorg/apache/logging/log4j/core/Layout;Lorg/apache/logging/log4j/core/config/Configuration;)V
            getstatic org.apache.logging.log4j.core.appender.RandomAccessFileManager.FACTORY:Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager$RandomAccessFileManagerFactory;
         2: .line 74
            invokestatic org.apache.logging.log4j.core.appender.RandomAccessFileManager.getManager:(Ljava/lang/String;Ljava/lang/Object;Lorg/apache/logging/log4j/core/appender/ManagerFactory;)Lorg/apache/logging/log4j/core/appender/OutputStreamManager;
            invokestatic org.apache.logging.log4j.core.appender.RandomAccessFileManager.narrow:(Ljava/lang/Class;Lorg/apache/logging/log4j/core/appender/AbstractManager;)Lorg/apache/logging/log4j/core/appender/AbstractManager;
            checkcast org.apache.logging.log4j.core.appender.RandomAccessFileManager
            areturn
        end local 6 // org.apache.logging.log4j.core.config.Configuration configuration
        end local 5 // org.apache.logging.log4j.core.Layout layout
        end local 4 // java.lang.String advertiseURI
        end local 3 // int bufferSize
        end local 2 // boolean immediateFlush
        end local 1 // boolean append
        end local 0 // java.lang.String fileName
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    3     0        fileName  Ljava/lang/String;
            0    3     1          append  Z
            0    3     2  immediateFlush  Z
            0    3     3      bufferSize  I
            0    3     4    advertiseURI  Ljava/lang/String;
            0    3     5          layout  Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;
            0    3     6   configuration  Lorg/apache/logging/log4j/core/config/Configuration;
    Signature: (Ljava/lang/String;ZZILjava/lang/String;Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;Lorg/apache/logging/log4j/core/config/Configuration;)Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
    MethodParameters:
                Name  Flags
      fileName        final
      append          final
      immediateFlush  final
      bufferSize      final
      advertiseURI    final
      layout          final
      configuration   final

  public java.lang.Boolean isEndOfBatch();
    descriptor: ()Ljava/lang/Boolean;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
         0: .line 79
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.isEndOfBatch:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.lang.Boolean
            areturn
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;

  public void setEndOfBatch(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
        start local 1 // boolean endOfBatch
         0: .line 83
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.isEndOfBatch:Ljava/lang/ThreadLocal;
            iload 1 /* endOfBatch */
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
         1: .line 84
            return
        end local 1 // boolean endOfBatch
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
            0    2     1  endOfBatch  Z
    MethodParameters:
            Name  Flags
      endOfBatch  final

  protected void writeToDestination(byte[], int, int);
    descriptor: ([BII)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
        start local 1 // byte[] bytes
        start local 2 // int offset
        start local 3 // int length
         0: .line 89
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.randomAccessFile:Ljava/io/RandomAccessFile;
            aload 1 /* bytes */
            iload 2 /* offset */
            iload 3 /* length */
            invokevirtual java.io.RandomAccessFile.write:([BII)V
         1: .line 90
            goto 5
      StackMap locals:
      StackMap stack: java.io.IOException
         2: astore 4 /* ex */
        start local 4 // java.io.IOException ex
         3: .line 91
            new java.lang.StringBuilder
            dup
            ldc "Error writing to RandomAccessFile "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.RandomAccessFileManager.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 5 /* msg */
        start local 5 // java.lang.String msg
         4: .line 92
            new org.apache.logging.log4j.core.appender.AppenderLoggingException
            dup
            aload 5 /* msg */
            aload 4 /* ex */
            invokespecial org.apache.logging.log4j.core.appender.AppenderLoggingException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.lang.String msg
        end local 4 // java.io.IOException ex
         5: .line 94
      StackMap locals:
      StackMap stack:
            return
        end local 3 // int length
        end local 2 // int offset
        end local 1 // byte[] bytes
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
            0    6     1   bytes  [B
            0    6     2  offset  I
            0    6     3  length  I
            3    5     4      ex  Ljava/io/IOException;
            4    5     5     msg  Ljava/lang/String;
      Exception table:
        from    to  target  type
           0     1       2  Class java.io.IOException
    MethodParameters:
        Name  Flags
      bytes   final
      offset  final
      length  final

  public synchronized void flush();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
         0: .line 98
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.byteBuffer:Ljava/nio/ByteBuffer;
            invokevirtual org.apache.logging.log4j.core.appender.RandomAccessFileManager.flushBuffer:(Ljava/nio/ByteBuffer;)V
         1: .line 99
            return
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;

  public synchronized boolean closeOutputStream();
    descriptor: ()Z
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
         0: .line 103
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.RandomAccessFileManager.flush:()V
         1: .line 105
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.randomAccessFile:Ljava/io/RandomAccessFile;
            invokevirtual java.io.RandomAccessFile.close:()V
         2: .line 106
            iconst_1
            ireturn
         3: .line 107
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 1 /* ex */
        start local 1 // java.io.IOException ex
         4: .line 108
            aload 0 /* this */
            ldc "Unable to close RandomAccessFile"
            aload 1 /* ex */
            invokevirtual org.apache.logging.log4j.core.appender.RandomAccessFileManager.logError:(Ljava/lang/String;Ljava/lang/Throwable;)V
         5: .line 109
            iconst_0
            ireturn
        end local 1 // java.io.IOException ex
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
            4    6     1    ex  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     2       3  Class java.io.IOException

  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.RandomAccessFileManager this
         0: .line 119
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.RandomAccessFileManager.getName:()Ljava/lang/String;
            areturn
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;

  public int getBufferSize();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
         0: .line 127
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.byteBuffer:Ljava/nio/ByteBuffer;
            invokevirtual java.nio.ByteBuffer.capacity:()I
            ireturn
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;

  public java.util.Map<java.lang.String, java.lang.String> getContentFormat();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
         0: .line 140
            new java.util.HashMap
            dup
         1: .line 141
            aload 0 /* this */
            invokespecial org.apache.logging.log4j.core.appender.OutputStreamManager.getContentFormat:()Ljava/util/Map;
         2: .line 140
            invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
            astore 1 /* result */
        start local 1 // java.util.Map result
         3: .line 142
            aload 1 /* result */
            ldc "fileURI"
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.advertiseURI:Ljava/lang/String;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         4: .line 143
            aload 1 /* result */
            areturn
        end local 1 // java.util.Map result
        end local 0 // org.apache.logging.log4j.core.appender.RandomAccessFileManager this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
            3    5     1  result  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
}
SourceFile: "RandomAccessFileManager.java"
NestMembers:
  org.apache.logging.log4j.core.appender.RandomAccessFileManager$FactoryData  org.apache.logging.log4j.core.appender.RandomAccessFileManager$RandomAccessFileManagerFactory
InnerClasses:
  private FactoryData = org.apache.logging.log4j.core.appender.RandomAccessFileManager$FactoryData of org.apache.logging.log4j.core.appender.RandomAccessFileManager
  private RandomAccessFileManagerFactory = org.apache.logging.log4j.core.appender.RandomAccessFileManager$RandomAccessFileManagerFactory of org.apache.logging.log4j.core.appender.RandomAccessFileManager