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: 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 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 0: aload 0
aload 1
aload 4
aload 3
iconst_0
aload 7
iload 8
iload 5
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: aload 0
new java.lang.ThreadLocal
dup
invokespecial java.lang.ThreadLocal.<init>:()V
putfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.isEndOfBatch:Ljava/lang/ThreadLocal;
2: aload 0
aload 2
putfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.randomAccessFile:Ljava/io/RandomAccessFile;
3: aload 0
aload 6
putfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.advertiseURI:Ljava/lang/String;
4: aload 0
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: return
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 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 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: ldc Lorg/apache/logging/log4j/core/appender/RandomAccessFileManager;
aload 0
1: new org.apache.logging.log4j.core.appender.RandomAccessFileManager$FactoryData
dup
iload 1
iload 2
iload 3
aload 4
aload 5
aload 6
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: 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 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 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 0: aload 0
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 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 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.isEndOfBatch:Ljava/lang/ThreadLocal;
iload 1
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
1: return
end local 1 end local 0 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 start local 1 start local 2 start local 3 0: aload 0
getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.randomAccessFile:Ljava/io/RandomAccessFile;
aload 1
iload 2
iload 3
invokevirtual java.io.RandomAccessFile.write:([BII)V
1: goto 5
StackMap locals:
StackMap stack: java.io.IOException
2: astore 4
start local 4 3: new java.lang.StringBuilder
dup
ldc "Error writing to RandomAccessFile "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
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
start local 5 4: new org.apache.logging.log4j.core.appender.AppenderLoggingException
dup
aload 5
aload 4
invokespecial org.apache.logging.log4j.core.appender.AppenderLoggingException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 5 end local 4 5: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 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 0: aload 0
aload 0
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: return
end local 0 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 0: aload 0
invokevirtual org.apache.logging.log4j.core.appender.RandomAccessFileManager.flush:()V
1: aload 0
getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.randomAccessFile:Ljava/io/RandomAccessFile;
invokevirtual java.io.RandomAccessFile.close:()V
2: iconst_1
ireturn
3: StackMap locals:
StackMap stack: java.io.IOException
astore 1
start local 1 4: aload 0
ldc "Unable to close RandomAccessFile"
aload 1
invokevirtual org.apache.logging.log4j.core.appender.RandomAccessFileManager.logError:(Ljava/lang/String;Ljava/lang/Throwable;)V
5: iconst_0
ireturn
end local 1 end local 0 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 0: aload 0
invokevirtual org.apache.logging.log4j.core.appender.RandomAccessFileManager.getName:()Ljava/lang/String;
areturn
end local 0 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 0: aload 0
getfield org.apache.logging.log4j.core.appender.RandomAccessFileManager.byteBuffer:Ljava/nio/ByteBuffer;
invokevirtual java.nio.ByteBuffer.capacity:()I
ireturn
end local 0 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 0: new java.util.HashMap
dup
1: aload 0
invokespecial org.apache.logging.log4j.core.appender.OutputStreamManager.getContentFormat:()Ljava/util/Map;
2: invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
astore 1
start local 1 3: aload 1
ldc "fileURI"
aload 0
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: aload 1
areturn
end local 1 end local 0 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