public class ch.qos.logback.core.FileAppender<E> extends ch.qos.logback.core.OutputStreamAppender<E>
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: ch.qos.logback.core.FileAppender
super_class: ch.qos.logback.core.OutputStreamAppender
{
public static final long DEFAULT_BUFFER_SIZE;
descriptor: J
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
ConstantValue: 8192
protected static java.lang.String COLLISION_WITH_EARLIER_APPENDER_URL;
descriptor: Ljava/lang/String;
flags: (0x000c) ACC_PROTECTED, ACC_STATIC
protected boolean append;
descriptor: Z
flags: (0x0004) ACC_PROTECTED
protected java.lang.String fileName;
descriptor: Ljava/lang/String;
flags: (0x0004) ACC_PROTECTED
private boolean prudent;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private ch.qos.logback.core.util.FileSize bufferSize;
descriptor: Lch/qos/logback/core/util/FileSize;
flags: (0x0002) ACC_PRIVATE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc "http://logback.qos.ch/codes.html#earlier_fa_collision"
putstatic ch.qos.logback.core.FileAppender.COLLISION_WITH_EARLIER_APPENDER_URL:Ljava/lang/String;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=1, args_size=1
start local 0 0: aload 0
invokespecial ch.qos.logback.core.OutputStreamAppender.<init>:()V
1: aload 0
iconst_1
putfield ch.qos.logback.core.FileAppender.append:Z
2: aload 0
aconst_null
putfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
3: aload 0
iconst_0
putfield ch.qos.logback.core.FileAppender.prudent:Z
4: aload 0
new ch.qos.logback.core.util.FileSize
dup
ldc 8192
invokespecial ch.qos.logback.core.util.FileSize.<init>:(J)V
putfield ch.qos.logback.core.FileAppender.bufferSize:Lch/qos/logback/core/util/FileSize;
5: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lch/qos/logback/core/FileAppender<TE;>;
public void setFile(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 3
1: aload 0
aload 1
putfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual java.lang.String.trim:()Ljava/lang/String;
putfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
4: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lch/qos/logback/core/FileAppender<TE;>;
0 5 1 file Ljava/lang/String;
MethodParameters:
Name Flags
file
public boolean isAppend();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield ch.qos.logback.core.FileAppender.append:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/core/FileAppender<TE;>;
public final java.lang.String rawFileProperty();
descriptor: ()Ljava/lang/String;
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/core/FileAppender<TE;>;
public java.lang.String getFile();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/core/FileAppender<TE;>;
public void start();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=1
start local 0 0: iconst_0
istore 1
start local 1 1: aload 0
invokevirtual ch.qos.logback.core.FileAppender.getFile:()Ljava/lang/String;
ifnull 18
2: aload 0
new java.lang.StringBuilder
dup
ldc "File property is set to ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "]"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual ch.qos.logback.core.FileAppender.addInfo:(Ljava/lang/String;)V
3: aload 0
getfield ch.qos.logback.core.FileAppender.prudent:Z
ifeq 7
4: aload 0
invokevirtual ch.qos.logback.core.FileAppender.isAppend:()Z
ifne 7
5: aload 0
iconst_1
invokevirtual ch.qos.logback.core.FileAppender.setAppend:(Z)V
6: aload 0
ldc "Setting \"Append\" property to true on account of \"Prudent\" mode"
invokevirtual ch.qos.logback.core.FileAppender.addWarn:(Ljava/lang/String;)V
7: StackMap locals: int
StackMap stack:
aload 0
invokevirtual ch.qos.logback.core.FileAppender.checkForFileCollisionInPreviousFileAppenders:()Z
ifeq 12
8: aload 0
ldc "Collisions detected with FileAppender/RollingAppender instances defined earlier. Aborting."
invokevirtual ch.qos.logback.core.FileAppender.addError:(Ljava/lang/String;)V
9: aload 0
new java.lang.StringBuilder
dup
ldc "For more information, please visit "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
getstatic ch.qos.logback.core.FileAppender.COLLISION_WITH_EARLIER_APPENDER_URL:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual ch.qos.logback.core.FileAppender.addError:(Ljava/lang/String;)V
10: iinc 1 1
11: goto 20
12: StackMap locals:
StackMap stack:
aload 0
aload 0
invokevirtual ch.qos.logback.core.FileAppender.getFile:()Ljava/lang/String;
invokevirtual ch.qos.logback.core.FileAppender.openFile:(Ljava/lang/String;)V
13: goto 20
StackMap locals:
StackMap stack: java.io.IOException
14: astore 2
start local 2 15: iinc 1 1
16: aload 0
new java.lang.StringBuilder
dup
ldc "openFile("
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc ","
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield ch.qos.logback.core.FileAppender.append:Z
invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
ldc ") call failed."
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 2
invokevirtual ch.qos.logback.core.FileAppender.addError:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 2 17: goto 20
18: StackMap locals:
StackMap stack:
iinc 1 1
19: aload 0
new java.lang.StringBuilder
dup
ldc "\"File\" property not set for appender named ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield ch.qos.logback.core.FileAppender.name:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "]."
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual ch.qos.logback.core.FileAppender.addError:(Ljava/lang/String;)V
20: StackMap locals:
StackMap stack:
iload 1
ifne 22
21: aload 0
invokespecial ch.qos.logback.core.OutputStreamAppender.start:()V
22: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 23 0 this Lch/qos/logback/core/FileAppender<TE;>;
1 23 1 errors I
15 17 2 e Ljava/io/IOException;
Exception table:
from to target type
12 13 14 Class java.io.IOException
public void stop();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
invokespecial ch.qos.logback.core.OutputStreamAppender.stop:()V
1: aload 0
getfield ch.qos.logback.core.FileAppender.context:Lch/qos/logback/core/Context;
invokestatic ch.qos.logback.core.util.ContextUtil.getFilenameCollisionMap:(Lch/qos/logback/core/Context;)Ljava/util/Map;
astore 1
start local 1 2: aload 1
ifnull 3
aload 0
invokevirtual ch.qos.logback.core.FileAppender.getName:()Ljava/lang/String;
ifnonnull 4
3: StackMap locals: java.util.Map
StackMap stack:
return
4: StackMap locals:
StackMap stack:
aload 1
aload 0
invokevirtual ch.qos.logback.core.FileAppender.getName:()Ljava/lang/String;
invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
pop
5: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lch/qos/logback/core/FileAppender<TE;>;
2 6 1 map Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
protected boolean checkForFileCollisionInPreviousFileAppenders();
descriptor: ()Z
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=5, args_size=1
start local 0 0: iconst_0
istore 1
start local 1 1: aload 0
getfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
ifnonnull 3
2: iconst_0
ireturn
3: StackMap locals: int
StackMap stack:
aload 0
getfield ch.qos.logback.core.FileAppender.context:Lch/qos/logback/core/Context;
ldc "FA_FILENAME_COLLISION_MAP"
invokeinterface ch.qos.logback.core.Context.getObject:(Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.Map
astore 2
start local 2 4: aload 2
ifnonnull 6
5: iload 1
ireturn
6: StackMap locals: java.util.Map
StackMap stack:
aload 2
invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 4
goto 11
StackMap locals: ch.qos.logback.core.FileAppender int java.util.Map top java.util.Iterator
StackMap stack:
7: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.util.Map$Entry
astore 3
start local 3 8: aload 0
getfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
aload 3
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifeq 11
9: aload 0
ldc "File"
aload 3
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast java.lang.String
aload 3
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
checkcast java.lang.String
invokevirtual ch.qos.logback.core.FileAppender.addErrorForCollision:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
10: iconst_1
istore 1
end local 3 11: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 7
12: aload 0
getfield ch.qos.logback.core.FileAppender.name:Ljava/lang/String;
ifnull 14
13: aload 2
aload 0
invokevirtual ch.qos.logback.core.FileAppender.getName:()Ljava/lang/String;
aload 0
getfield ch.qos.logback.core.FileAppender.fileName:Ljava/lang/String;
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
14: StackMap locals: ch.qos.logback.core.FileAppender int java.util.Map
StackMap stack:
iload 1
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lch/qos/logback/core/FileAppender<TE;>;
1 15 1 collisionsDetected Z
4 15 2 map Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
8 11 3 entry Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/String;>;
protected void addErrorForCollision(java.lang.String, java.lang.String, java.lang.String);
descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
new java.lang.StringBuilder
dup
ldc "'"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "' option has the same value \""
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "\" as that given for appender ["
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "] defined earlier."
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual ch.qos.logback.core.FileAppender.addError:(Ljava/lang/String;)V
1: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lch/qos/logback/core/FileAppender<TE;>;
0 2 1 optionName Ljava/lang/String;
0 2 2 optionValue Ljava/lang/String;
0 2 3 appenderName Ljava/lang/String;
MethodParameters:
Name Flags
optionName
optionValue
appenderName
public void openFile(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=6, args_size=2
start local 0 start local 1 0: aload 0
getfield ch.qos.logback.core.FileAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
1: new java.io.File
dup
aload 1
invokespecial java.io.File.<init>:(Ljava/lang/String;)V
astore 2
start local 2 2: aload 2
invokestatic ch.qos.logback.core.util.FileUtil.createMissingParentDirectories:(Ljava/io/File;)Z
istore 3
start local 3 3: iload 3
ifne 5
4: aload 0
new java.lang.StringBuilder
dup
ldc "Failed to create parent directories for ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "]"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual ch.qos.logback.core.FileAppender.addError:(Ljava/lang/String;)V
5: StackMap locals: java.io.File int
StackMap stack:
new ch.qos.logback.core.recovery.ResilientFileOutputStream
dup
aload 2
aload 0
getfield ch.qos.logback.core.FileAppender.append:Z
aload 0
getfield ch.qos.logback.core.FileAppender.bufferSize:Lch/qos/logback/core/util/FileSize;
invokevirtual ch.qos.logback.core.util.FileSize.getSize:()J
invokespecial ch.qos.logback.core.recovery.ResilientFileOutputStream.<init>:(Ljava/io/File;ZJ)V
astore 4
start local 4 6: aload 4
aload 0
getfield ch.qos.logback.core.FileAppender.context:Lch/qos/logback/core/Context;
invokevirtual ch.qos.logback.core.recovery.ResilientFileOutputStream.setContext:(Lch/qos/logback/core/Context;)V
7: aload 0
aload 4
invokevirtual ch.qos.logback.core.FileAppender.setOutputStream:(Ljava/io/OutputStream;)V
end local 4 end local 3 end local 2 8: goto 12
StackMap locals: ch.qos.logback.core.FileAppender java.lang.String
StackMap stack: java.lang.Throwable
9: astore 5
10: aload 0
getfield ch.qos.logback.core.FileAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
11: aload 5
athrow
12: StackMap locals:
StackMap stack:
aload 0
getfield ch.qos.logback.core.FileAppender.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
13: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lch/qos/logback/core/FileAppender<TE;>;
0 14 1 file_name Ljava/lang/String;
2 8 2 file Ljava/io/File;
3 8 3 result Z
6 8 4 resilientFos Lch/qos/logback/core/recovery/ResilientFileOutputStream;
Exception table:
from to target type
1 9 9 any
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
file_name
public boolean isPrudent();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield ch.qos.logback.core.FileAppender.prudent:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/core/FileAppender<TE;>;
public void setPrudent(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
iload 1
putfield ch.qos.logback.core.FileAppender.prudent:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lch/qos/logback/core/FileAppender<TE;>;
0 2 1 prudent Z
MethodParameters:
Name Flags
prudent
public void setAppend(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
iload 1
putfield ch.qos.logback.core.FileAppender.append:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lch/qos/logback/core/FileAppender<TE;>;
0 2 1 append Z
MethodParameters:
Name Flags
append
public void setBufferSize(ch.qos.logback.core.util.FileSize);
descriptor: (Lch/qos/logback/core/util/FileSize;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
new java.lang.StringBuilder
dup
ldc "Setting bufferSize to ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual ch.qos.logback.core.util.FileSize.toString:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "]"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual ch.qos.logback.core.FileAppender.addInfo:(Ljava/lang/String;)V
1: aload 0
aload 1
putfield ch.qos.logback.core.FileAppender.bufferSize:Lch/qos/logback/core/util/FileSize;
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lch/qos/logback/core/FileAppender<TE;>;
0 3 1 bufferSize Lch/qos/logback/core/util/FileSize;
MethodParameters:
Name Flags
bufferSize
private void safeWrite();
descriptor: (Ljava/lang/Object;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=11, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual ch.qos.logback.core.FileAppender.getOutputStream:()Ljava/io/OutputStream;
checkcast ch.qos.logback.core.recovery.ResilientFileOutputStream
astore 2
start local 2 1: aload 2
invokevirtual ch.qos.logback.core.recovery.ResilientFileOutputStream.getChannel:()Ljava/nio/channels/FileChannel;
astore 3
start local 3 2: aload 3
ifnonnull 4
3: return
4: StackMap locals: ch.qos.logback.core.recovery.ResilientFileOutputStream java.nio.channels.FileChannel
StackMap stack:
invokestatic java.lang.Thread.interrupted:()Z
istore 4
start local 4 5: aconst_null
astore 5
start local 5 6: aload 3
invokevirtual java.nio.channels.FileChannel.lock:()Ljava/nio/channels/FileLock;
astore 5
7: aload 3
invokevirtual java.nio.channels.FileChannel.position:()J
lstore 6
start local 6 8: aload 3
invokevirtual java.nio.channels.FileChannel.size:()J
lstore 8
start local 8 9: lload 8
lload 6
lcmp
ifeq 11
10: aload 3
lload 8
invokevirtual java.nio.channels.FileChannel.position:(J)Ljava/nio/channels/FileChannel;
pop
11: StackMap locals: ch.qos.logback.core.FileAppender java.lang.Object ch.qos.logback.core.recovery.ResilientFileOutputStream java.nio.channels.FileChannel int java.nio.channels.FileLock long long
StackMap stack:
aload 0
aload 1
invokespecial ch.qos.logback.core.OutputStreamAppender.writeOut:(Ljava/lang/Object;)V
end local 8 end local 6 12: goto 25
StackMap locals: ch.qos.logback.core.FileAppender java.lang.Object ch.qos.logback.core.recovery.ResilientFileOutputStream java.nio.channels.FileChannel int java.nio.channels.FileLock
StackMap stack: java.io.IOException
13: astore 6
start local 6 14: aload 2
aload 6
invokevirtual ch.qos.logback.core.recovery.ResilientFileOutputStream.postIOFailure:(Ljava/io/IOException;)V
end local 6 15: aload 5
ifnull 17
aload 5
invokevirtual java.nio.channels.FileLock.isValid:()Z
ifeq 17
16: aload 5
invokevirtual java.nio.channels.FileLock.release:()V
17: StackMap locals:
StackMap stack:
iload 4
ifeq 29
18: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
goto 29
19: StackMap locals:
StackMap stack: java.lang.Throwable
astore 10
20: aload 5
ifnull 22
aload 5
invokevirtual java.nio.channels.FileLock.isValid:()Z
ifeq 22
21: aload 5
invokevirtual java.nio.channels.FileLock.release:()V
22: StackMap locals: ch.qos.logback.core.FileAppender java.lang.Object ch.qos.logback.core.recovery.ResilientFileOutputStream java.nio.channels.FileChannel int java.nio.channels.FileLock top top top top java.lang.Throwable
StackMap stack:
iload 4
ifeq 24
23: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
24: StackMap locals:
StackMap stack:
aload 10
athrow
25: StackMap locals: ch.qos.logback.core.FileAppender java.lang.Object ch.qos.logback.core.recovery.ResilientFileOutputStream java.nio.channels.FileChannel int java.nio.channels.FileLock
StackMap stack:
aload 5
ifnull 27
aload 5
invokevirtual java.nio.channels.FileLock.isValid:()Z
ifeq 27
26: aload 5
invokevirtual java.nio.channels.FileLock.release:()V
27: StackMap locals:
StackMap stack:
iload 4
ifeq 29
28: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
29: StackMap locals:
StackMap stack:
return
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 30 0 this Lch/qos/logback/core/FileAppender<TE;>;
0 30 1 event TE;
1 30 2 resilientFOS Lch/qos/logback/core/recovery/ResilientFileOutputStream;
2 30 3 fileChannel Ljava/nio/channels/FileChannel;
5 30 4 interrupted Z
6 30 5 fileLock Ljava/nio/channels/FileLock;
8 12 6 position J
9 12 8 size J
14 15 6 e Ljava/io/IOException;
Exception table:
from to target type
6 12 13 Class java.io.IOException
6 15 19 any
Exceptions:
throws java.io.IOException
Signature: (TE;)V
MethodParameters:
Name Flags
event
protected void writeOut();
descriptor: (Ljava/lang/Object;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield ch.qos.logback.core.FileAppender.prudent:Z
ifeq 3
1: aload 0
aload 1
invokevirtual ch.qos.logback.core.FileAppender.safeWrite:(Ljava/lang/Object;)V
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
aload 1
invokespecial ch.qos.logback.core.OutputStreamAppender.writeOut:(Ljava/lang/Object;)V
4: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lch/qos/logback/core/FileAppender<TE;>;
0 5 1 event TE;
Exceptions:
throws java.io.IOException
Signature: (TE;)V
MethodParameters:
Name Flags
event
}
Signature: <E:Ljava/lang/Object;>Lch/qos/logback/core/OutputStreamAppender<TE;>;
SourceFile: "FileAppender.java"
InnerClasses:
public abstract Entry = java.util.Map$Entry of java.util.Map