public class org.apache.catalina.valves.AccessLogValve extends org.apache.catalina.valves.AbstractAccessLogValve
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.catalina.valves.AccessLogValve
super_class: org.apache.catalina.valves.AbstractAccessLogValve
{
private static final org.apache.juli.logging.Log log;
descriptor: Lorg/apache/juli/logging/Log;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private volatile java.lang.String dateStamp;
descriptor: Ljava/lang/String;
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
private java.lang.String directory;
descriptor: Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
protected volatile java.lang.String prefix;
descriptor: Ljava/lang/String;
flags: (0x0044) ACC_PROTECTED, ACC_VOLATILE
protected boolean rotatable;
descriptor: Z
flags: (0x0004) ACC_PROTECTED
protected boolean renameOnRotate;
descriptor: Z
flags: (0x0004) ACC_PROTECTED
private boolean buffered;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
protected volatile java.lang.String suffix;
descriptor: Ljava/lang/String;
flags: (0x0044) ACC_PROTECTED, ACC_VOLATILE
protected java.io.PrintWriter writer;
descriptor: Ljava/io/PrintWriter;
flags: (0x0004) ACC_PROTECTED
protected java.text.SimpleDateFormat fileDateFormatter;
descriptor: Ljava/text/SimpleDateFormat;
flags: (0x0004) ACC_PROTECTED
protected java.io.File currentLogFile;
descriptor: Ljava/io/File;
flags: (0x0004) ACC_PROTECTED
private volatile long rotationLastChecked;
descriptor: J
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
private boolean checkExists;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
protected java.lang.String fileDateFormat;
descriptor: Ljava/lang/String;
flags: (0x0004) ACC_PROTECTED
protected volatile java.lang.String encoding;
descriptor: Ljava/lang/String;
flags: (0x0044) ACC_PROTECTED, ACC_VOLATILE
private int maxDays;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private volatile boolean checkForOldLogs;
descriptor: Z
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/apache/catalina/valves/AccessLogValve;
invokestatic org.apache.juli.logging.LogFactory.getLog:(Ljava/lang/Class;)Lorg/apache/juli/logging/Log;
putstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
invokespecial org.apache.catalina.valves.AbstractAccessLogValve.<init>:()V
1: aload 0
ldc ""
putfield org.apache.catalina.valves.AccessLogValve.dateStamp:Ljava/lang/String;
2: aload 0
ldc "logs"
putfield org.apache.catalina.valves.AccessLogValve.directory:Ljava/lang/String;
3: aload 0
ldc "access_log"
putfield org.apache.catalina.valves.AccessLogValve.prefix:Ljava/lang/String;
4: aload 0
iconst_1
putfield org.apache.catalina.valves.AccessLogValve.rotatable:Z
5: aload 0
iconst_0
putfield org.apache.catalina.valves.AccessLogValve.renameOnRotate:Z
6: aload 0
iconst_1
putfield org.apache.catalina.valves.AccessLogValve.buffered:Z
7: aload 0
ldc ""
putfield org.apache.catalina.valves.AccessLogValve.suffix:Ljava/lang/String;
8: aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
9: aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
10: aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
11: aload 0
lconst_0
putfield org.apache.catalina.valves.AccessLogValve.rotationLastChecked:J
12: aload 0
iconst_0
putfield org.apache.catalina.valves.AccessLogValve.checkExists:Z
13: aload 0
ldc ".yyyy-MM-dd"
putfield org.apache.catalina.valves.AccessLogValve.fileDateFormat:Ljava/lang/String;
14: aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.encoding:Ljava/lang/String;
15: aload 0
iconst_m1
putfield org.apache.catalina.valves.AccessLogValve.maxDays:I
16: aload 0
iconst_0
putfield org.apache.catalina.valves.AccessLogValve.checkForOldLogs:Z
17: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Lorg/apache/catalina/valves/AccessLogValve;
public int getMaxDays();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.maxDays:I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setMaxDays(int);
descriptor: (I)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 org.apache.catalina.valves.AccessLogValve.maxDays:I
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 2 1 maxDays I
MethodParameters:
Name Flags
maxDays
public java.lang.String getDirectory();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.directory:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setDirectory(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 0
aload 1
putfield org.apache.catalina.valves.AccessLogValve.directory:Ljava/lang/String;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 2 1 directory Ljava/lang/String;
MethodParameters:
Name Flags
directory
public boolean isCheckExists();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.checkExists:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setCheckExists(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 org.apache.catalina.valves.AccessLogValve.checkExists:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 2 1 checkExists Z
MethodParameters:
Name Flags
checkExists
public java.lang.String getPrefix();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.prefix:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setPrefix(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 0
aload 1
putfield org.apache.catalina.valves.AccessLogValve.prefix:Ljava/lang/String;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 2 1 prefix Ljava/lang/String;
MethodParameters:
Name Flags
prefix
public boolean isRotatable();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.rotatable:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setRotatable(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 org.apache.catalina.valves.AccessLogValve.rotatable:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 2 1 rotatable Z
MethodParameters:
Name Flags
rotatable
public boolean isRenameOnRotate();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.renameOnRotate:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setRenameOnRotate(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 org.apache.catalina.valves.AccessLogValve.renameOnRotate:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 2 1 renameOnRotate Z
MethodParameters:
Name Flags
renameOnRotate
public boolean isBuffered();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.buffered:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setBuffered(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 org.apache.catalina.valves.AccessLogValve.buffered:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 2 1 buffered Z
MethodParameters:
Name Flags
buffered
public java.lang.String getSuffix();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.suffix:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setSuffix(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 0
aload 1
putfield org.apache.catalina.valves.AccessLogValve.suffix:Ljava/lang/String;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 2 1 suffix Ljava/lang/String;
MethodParameters:
Name Flags
suffix
public java.lang.String getFileDateFormat();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.fileDateFormat:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setFileDateFormat(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 3
1: ldc ""
astore 2
start local 2 2: goto 4
end local 2 3: StackMap locals:
StackMap stack:
aload 1
astore 2
start local 2 4: StackMap locals: java.lang.String
StackMap stack:
aload 0
aload 2
putfield org.apache.catalina.valves.AccessLogValve.fileDateFormat:Ljava/lang/String;
5: aload 0
dup
astore 3
monitorenter
6: aload 0
new java.text.SimpleDateFormat
dup
aload 2
getstatic java.util.Locale.US:Ljava/util/Locale;
invokespecial java.text.SimpleDateFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
putfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
7: aload 0
getfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
invokestatic java.util.TimeZone.getDefault:()Ljava/util/TimeZone;
invokevirtual java.text.SimpleDateFormat.setTimeZone:(Ljava/util/TimeZone;)V
8: aload 3
monitorexit
9: goto 12
StackMap locals: org.apache.catalina.valves.AccessLogValve java.lang.String java.lang.String org.apache.catalina.valves.AccessLogValve
StackMap stack: java.lang.Throwable
10: aload 3
monitorexit
11: athrow
12: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 13 1 fileDateFormat Ljava/lang/String;
2 3 2 newFormat Ljava/lang/String;
4 13 2 newFormat Ljava/lang/String;
Exception table:
from to target type
6 9 10 any
10 11 10 any
MethodParameters:
Name Flags
fileDateFormat
public java.lang.String getEncoding();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.encoding:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/AccessLogValve;
public void setEncoding(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
ifnull 3
aload 1
invokevirtual java.lang.String.length:()I
ifle 3
1: aload 0
aload 1
putfield org.apache.catalina.valves.AccessLogValve.encoding:Ljava/lang/String;
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.encoding: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 Lorg/apache/catalina/valves/AccessLogValve;
0 5 1 encoding Ljava/lang/String;
MethodParameters:
Name Flags
encoding
public synchronized void backgroundProcess();
descriptor: ()V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=7, locals=14, args_size=1
start local 0 0: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.getState:()Lorg/apache/catalina/LifecycleState;
invokevirtual org.apache.catalina.LifecycleState.isAvailable:()Z
ifeq 3
aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.getEnabled:()Z
ifeq 3
aload 0
getfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
ifnull 3
1: aload 0
getfield org.apache.catalina.valves.AccessLogValve.buffered:Z
ifeq 3
2: aload 0
getfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
invokevirtual java.io.PrintWriter.flush:()V
3: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.catalina.valves.AccessLogValve.maxDays:I
istore 1
start local 1 4: aload 0
getfield org.apache.catalina.valves.AccessLogValve.prefix:Ljava/lang/String;
astore 2
start local 2 5: aload 0
getfield org.apache.catalina.valves.AccessLogValve.suffix:Ljava/lang/String;
astore 3
start local 3 6: aload 0
getfield org.apache.catalina.valves.AccessLogValve.rotatable:Z
ifeq 34
aload 0
getfield org.apache.catalina.valves.AccessLogValve.checkForOldLogs:Z
ifeq 34
iload 1
ifle 34
7: invokestatic java.lang.System.currentTimeMillis:()J
iload 1
i2l
ldc 24
lmul
ldc 60
lmul
ldc 60
lmul
ldc 1000
lmul
lsub
8: lstore 4
start local 4 9: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.getDirectoryFile:()Ljava/io/File;
astore 6
start local 6 10: aload 6
invokevirtual java.io.File.isDirectory:()Z
ifeq 33
11: aload 6
invokevirtual java.io.File.list:()[Ljava/lang/String;
astore 7
start local 7 12: aload 7
ifnull 33
13: aload 7
dup
astore 11
arraylength
istore 10
iconst_0
istore 9
goto 32
StackMap locals: org.apache.catalina.valves.AccessLogValve int java.lang.String java.lang.String long java.io.File java.lang.String[] top int int java.lang.String[]
StackMap stack:
14: aload 11
iload 9
aaload
astore 8
start local 8 15: iconst_0
istore 12
start local 12 16: aload 2
ifnull 20
aload 2
invokevirtual java.lang.String.length:()I
ifle 20
17: aload 8
aload 2
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifne 19
18: goto 31
19: StackMap locals: org.apache.catalina.valves.AccessLogValve int java.lang.String java.lang.String long java.io.File java.lang.String[] java.lang.String int int java.lang.String[] int
StackMap stack:
iconst_1
istore 12
20: StackMap locals:
StackMap stack:
aload 3
ifnull 24
aload 3
invokevirtual java.lang.String.length:()I
ifle 24
21: aload 8
aload 3
invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
ifne 23
22: goto 31
23: StackMap locals:
StackMap stack:
iconst_1
istore 12
24: StackMap locals:
StackMap stack:
iload 12
ifeq 31
25: new java.io.File
dup
aload 6
aload 8
invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
astore 13
start local 13 26: aload 13
invokevirtual java.io.File.isFile:()Z
ifeq 31
aload 13
invokevirtual java.io.File.lastModified:()J
lload 4
lcmp
ifge 31
27: aload 13
invokevirtual java.io.File.delete:()Z
ifne 31
28: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
29: ldc "accessLogValve.deleteFail"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 13
invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
aastore
30: invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokeinterface org.apache.juli.logging.Log.warn:(Ljava/lang/Object;)V
end local 13 end local 12 end local 8 31: StackMap locals: org.apache.catalina.valves.AccessLogValve int java.lang.String java.lang.String long java.io.File java.lang.String[] top int int java.lang.String[]
StackMap stack:
iinc 9 1
StackMap locals:
StackMap stack:
32: iload 9
iload 10
if_icmplt 14
end local 7 33: StackMap locals: org.apache.catalina.valves.AccessLogValve int java.lang.String java.lang.String long java.io.File
StackMap stack:
aload 0
iconst_0
putfield org.apache.catalina.valves.AccessLogValve.checkForOldLogs:Z
end local 6 end local 4 34: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 35 0 this Lorg/apache/catalina/valves/AccessLogValve;
4 35 1 maxDays I
5 35 2 prefix Ljava/lang/String;
6 35 3 suffix Ljava/lang/String;
9 34 4 deleteIfLastModifiedBefore J
10 34 6 dir Ljava/io/File;
12 33 7 oldAccessLogs [Ljava/lang/String;
15 31 8 oldAccessLog Ljava/lang/String;
16 31 12 match Z
26 31 13 file Ljava/io/File;
public void rotate();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=5, args_size=1
start local 0 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.rotatable:Z
ifeq 15
1: invokestatic java.lang.System.currentTimeMillis:()J
lstore 1
start local 1 2: lload 1
aload 0
getfield org.apache.catalina.valves.AccessLogValve.rotationLastChecked:J
lsub
ldc 1000
lcmp
ifle 15
3: aload 0
dup
astore 3
monitorenter
4: lload 1
aload 0
getfield org.apache.catalina.valves.AccessLogValve.rotationLastChecked:J
lsub
ldc 1000
lcmp
ifle 11
5: aload 0
lload 1
putfield org.apache.catalina.valves.AccessLogValve.rotationLastChecked:J
6: aload 0
getfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
new java.util.Date
dup
lload 1
invokespecial java.util.Date.<init>:(J)V
invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
astore 4
start local 4 7: aload 0
getfield org.apache.catalina.valves.AccessLogValve.dateStamp:Ljava/lang/String;
aload 4
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifne 11
8: aload 0
iconst_1
invokevirtual org.apache.catalina.valves.AccessLogValve.close:(Z)V
9: aload 0
aload 4
putfield org.apache.catalina.valves.AccessLogValve.dateStamp:Ljava/lang/String;
10: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.open:()V
end local 4 11: StackMap locals: long org.apache.catalina.valves.AccessLogValve
StackMap stack:
aload 3
monitorexit
12: goto 15
StackMap locals:
StackMap stack: java.lang.Throwable
13: aload 3
monitorexit
14: athrow
end local 1 15: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/apache/catalina/valves/AccessLogValve;
2 15 1 systime J
7 11 4 tsDate Ljava/lang/String;
Exception table:
from to target type
4 12 13 any
13 14 13 any
public synchronized boolean rotate(java.lang.String);
descriptor: (Ljava/lang/String;)Z
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=6, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
ifnull 13
1: aload 0
getfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
astore 2
start local 2 2: aload 0
iconst_0
invokevirtual org.apache.catalina.valves.AccessLogValve.close:(Z)V
3: aload 2
new java.io.File
dup
aload 1
invokespecial java.io.File.<init>:(Ljava/lang/String;)V
invokevirtual java.io.File.renameTo:(Ljava/io/File;)Z
pop
4: goto 8
StackMap locals: org.apache.catalina.valves.AccessLogValve java.lang.String java.io.File
StackMap stack: java.lang.Throwable
5: astore 3
start local 3 6: aload 3
invokestatic org.apache.tomcat.util.ExceptionUtils.handleThrowable:(Ljava/lang/Throwable;)V
7: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.rotateFail"
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;)Ljava/lang/String;
aload 3
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
end local 3 8: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
9: new java.util.Date
dup
invokestatic java.lang.System.currentTimeMillis:()J
invokespecial java.util.Date.<init>:(J)V
10: invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
putfield org.apache.catalina.valves.AccessLogValve.dateStamp:Ljava/lang/String;
11: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.open:()V
12: iconst_1
ireturn
end local 2 13: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 14 1 newFileName Ljava/lang/String;
2 13 2 holder Ljava/io/File;
6 8 3 e Ljava/lang/Throwable;
Exception table:
from to target type
3 4 5 Class java.lang.Throwable
MethodParameters:
Name Flags
newFileName
private java.io.File getDirectoryFile();
descriptor: ()Ljava/io/File;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=2, args_size=1
start local 0 0: new java.io.File
dup
aload 0
getfield org.apache.catalina.valves.AccessLogValve.directory:Ljava/lang/String;
invokespecial java.io.File.<init>:(Ljava/lang/String;)V
astore 1
start local 1 1: aload 1
invokevirtual java.io.File.isAbsolute:()Z
ifne 3
2: new java.io.File
dup
aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.getContainer:()Lorg/apache/catalina/Container;
invokeinterface org.apache.catalina.Container.getCatalinaBase:()Ljava/io/File;
aload 0
getfield org.apache.catalina.valves.AccessLogValve.directory:Ljava/lang/String;
invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
astore 1
3: StackMap locals: java.io.File
StackMap stack:
aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/catalina/valves/AccessLogValve;
1 4 1 dir Ljava/io/File;
private java.io.File getLogFile(boolean);
descriptor: (Z)Ljava/io/File;
flags: (0x0002) ACC_PRIVATE
Code:
stack=7, locals=5, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.getDirectoryFile:()Ljava/io/File;
astore 2
start local 2 1: aload 2
invokevirtual java.io.File.mkdirs:()Z
ifne 3
aload 2
invokevirtual java.io.File.isDirectory:()Z
ifne 3
2: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.openDirFail"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 2
aastore
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;)V
3: StackMap locals: java.io.File
StackMap stack:
iload 1
ifeq 8
4: new java.io.File
dup
aload 2
invokevirtual java.io.File.getAbsoluteFile:()Ljava/io/File;
new java.lang.StringBuilder
dup
aload 0
getfield org.apache.catalina.valves.AccessLogValve.prefix:Ljava/lang/String;
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield org.apache.catalina.valves.AccessLogValve.dateStamp:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
5: aload 0
getfield org.apache.catalina.valves.AccessLogValve.suffix:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
6: invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
astore 3
start local 3 7: goto 9
end local 3 8: StackMap locals:
StackMap stack:
new java.io.File
dup
aload 2
invokevirtual java.io.File.getAbsoluteFile:()Ljava/io/File;
new java.lang.StringBuilder
dup
aload 0
getfield org.apache.catalina.valves.AccessLogValve.prefix:Ljava/lang/String;
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield org.apache.catalina.valves.AccessLogValve.suffix:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
astore 3
start local 3 9: StackMap locals: java.io.File
StackMap stack:
aload 3
invokevirtual java.io.File.getParentFile:()Ljava/io/File;
astore 4
start local 4 10: aload 4
invokevirtual java.io.File.mkdirs:()Z
ifne 12
aload 4
invokevirtual java.io.File.isDirectory:()Z
ifne 12
11: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.openDirFail"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 4
aastore
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;)V
12: StackMap locals: java.io.File
StackMap stack:
aload 3
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 13 1 useDateStamp Z
1 13 2 dir Ljava/io/File;
7 8 3 pathname Ljava/io/File;
9 13 3 pathname Ljava/io/File;
10 13 4 parent Ljava/io/File;
MethodParameters:
Name Flags
useDateStamp
private void restore();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=7, locals=4, args_size=1
start local 0 0: aload 0
iconst_0
invokevirtual org.apache.catalina.valves.AccessLogValve.getLogFile:(Z)Ljava/io/File;
astore 1
start local 1 1: aload 0
iconst_1
invokevirtual org.apache.catalina.valves.AccessLogValve.getLogFile:(Z)Ljava/io/File;
astore 2
start local 2 2: aload 2
invokevirtual java.io.File.exists:()Z
ifeq 10
aload 1
invokevirtual java.io.File.exists:()Z
ifne 10
3: aload 2
aload 1
invokevirtual java.io.File.equals:(Ljava/lang/Object;)Z
ifne 10
4: aload 2
aload 1
invokevirtual java.io.File.renameTo:(Ljava/io/File;)Z
ifne 10
5: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.renameFail"
iconst_2
anewarray java.lang.Object
dup
iconst_0
aload 2
aastore
dup
iconst_1
aload 1
aastore
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;)V
6: goto 10
StackMap locals: org.apache.catalina.valves.AccessLogValve java.io.File java.io.File
StackMap stack: java.lang.Throwable
7: astore 3
start local 3 8: aload 3
invokestatic org.apache.tomcat.util.ExceptionUtils.handleThrowable:(Ljava/lang/Throwable;)V
9: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.renameFail"
iconst_2
anewarray java.lang.Object
dup
iconst_0
aload 2
aastore
dup
iconst_1
aload 1
aastore
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
aload 3
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
end local 3 10: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/apache/catalina/valves/AccessLogValve;
1 11 1 newLogFile Ljava/io/File;
2 11 2 rotatedLogFile Ljava/io/File;
8 10 3 e Ljava/lang/Throwable;
Exception table:
from to target type
4 6 7 Class java.lang.Throwable
private synchronized void close(boolean);
descriptor: (Z)V
flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
Code:
stack=7, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
ifnonnull 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
invokevirtual java.io.PrintWriter.flush:()V
3: aload 0
getfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
invokevirtual java.io.PrintWriter.close:()V
4: iload 1
ifeq 15
aload 0
getfield org.apache.catalina.valves.AccessLogValve.renameOnRotate:Z
ifeq 15
5: aload 0
iconst_1
invokevirtual org.apache.catalina.valves.AccessLogValve.getLogFile:(Z)Ljava/io/File;
astore 2
start local 2 6: aload 2
invokevirtual java.io.File.exists:()Z
ifne 14
7: aload 0
getfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
aload 2
invokevirtual java.io.File.renameTo:(Ljava/io/File;)Z
ifne 15
8: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.renameFail"
iconst_2
anewarray java.lang.Object
dup
iconst_0
aload 0
getfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
aastore
dup
iconst_1
aload 2
aastore
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;)V
9: goto 15
StackMap locals: org.apache.catalina.valves.AccessLogValve int java.io.File
StackMap stack: java.lang.Throwable
10: astore 3
start local 3 11: aload 3
invokestatic org.apache.tomcat.util.ExceptionUtils.handleThrowable:(Ljava/lang/Throwable;)V
12: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.renameFail"
iconst_2
anewarray java.lang.Object
dup
iconst_0
aload 0
getfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
aastore
dup
iconst_1
aload 2
aastore
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
aload 3
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
end local 3 13: goto 15
14: StackMap locals:
StackMap stack:
getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.alreadyExists"
iconst_2
anewarray java.lang.Object
dup
iconst_0
aload 0
getfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
aastore
dup
iconst_1
aload 2
aastore
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;)V
end local 2 15: StackMap locals:
StackMap stack:
aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
16: aload 0
ldc ""
putfield org.apache.catalina.valves.AccessLogValve.dateStamp:Ljava/lang/String;
17: aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
18: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 19 1 rename Z
6 15 2 newLogFile Ljava/io/File;
11 13 3 e Ljava/lang/Throwable;
Exception table:
from to target type
7 9 10 Class java.lang.Throwable
MethodParameters:
Name Flags
rename
public void log(java.io.CharArrayWriter);
descriptor: (Ljava/io/CharArrayWriter;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.rotate:()V
1: aload 0
getfield org.apache.catalina.valves.AccessLogValve.checkExists:Z
ifeq 17
2: aload 0
dup
astore 2
monitorenter
3: aload 0
getfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
ifnull 13
aload 0
getfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
invokevirtual java.io.File.exists:()Z
ifne 13
4: aload 0
iconst_0
invokevirtual org.apache.catalina.valves.AccessLogValve.close:(Z)V
5: goto 9
StackMap locals: org.apache.catalina.valves.AccessLogValve java.io.CharArrayWriter org.apache.catalina.valves.AccessLogValve
StackMap stack: java.lang.Throwable
6: astore 3
start local 3 7: aload 3
invokestatic org.apache.tomcat.util.ExceptionUtils.handleThrowable:(Ljava/lang/Throwable;)V
8: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.closeFail"
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;)Ljava/lang/String;
aload 3
invokeinterface org.apache.juli.logging.Log.info:(Ljava/lang/Object;Ljava/lang/Throwable;)V
end local 3 9: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
10: new java.util.Date
dup
invokestatic java.lang.System.currentTimeMillis:()J
invokespecial java.util.Date.<init>:(J)V
11: invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
putfield org.apache.catalina.valves.AccessLogValve.dateStamp:Ljava/lang/String;
12: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.open:()V
13: StackMap locals:
StackMap stack:
aload 2
monitorexit
14: goto 17
StackMap locals:
StackMap stack: java.lang.Throwable
15: aload 2
monitorexit
16: athrow
17: StackMap locals:
StackMap stack:
aload 1
invokestatic java.lang.System.lineSeparator:()Ljava/lang/String;
invokevirtual java.io.CharArrayWriter.write:(Ljava/lang/String;)V
18: aload 0
dup
astore 2
monitorenter
19: aload 0
getfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
ifnull 23
20: aload 1
aload 0
getfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
invokevirtual java.io.CharArrayWriter.writeTo:(Ljava/io/Writer;)V
21: aload 0
getfield org.apache.catalina.valves.AccessLogValve.buffered:Z
ifne 23
22: aload 0
getfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
invokevirtual java.io.PrintWriter.flush:()V
23: StackMap locals: org.apache.catalina.valves.AccessLogValve
StackMap stack:
aload 2
monitorexit
24: goto 33
StackMap locals:
StackMap stack: java.lang.Throwable
25: aload 2
monitorexit
26: athrow
27: StackMap locals: org.apache.catalina.valves.AccessLogValve java.io.CharArrayWriter
StackMap stack: java.io.IOException
astore 2
start local 2 28: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
29: ldc "accessLogValve.writeFail"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 1
invokevirtual java.io.CharArrayWriter.toString:()Ljava/lang/String;
aastore
30: invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
31: aload 2
32: invokeinterface org.apache.juli.logging.Log.warn:(Ljava/lang/Object;Ljava/lang/Throwable;)V
end local 2 33: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 34 0 this Lorg/apache/catalina/valves/AccessLogValve;
0 34 1 message Ljava/io/CharArrayWriter;
7 9 3 e Ljava/lang/Throwable;
28 33 2 ioe Ljava/io/IOException;
Exception table:
from to target type
4 5 6 Class java.lang.Throwable
3 14 15 any
15 16 15 any
19 24 25 any
25 26 25 any
17 27 27 Class java.io.IOException
MethodParameters:
Name Flags
message
protected synchronized void open();
descriptor: ()V
flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
Code:
stack=11, locals=4, args_size=1
start local 0 0: aload 0
aload 0
getfield org.apache.catalina.valves.AccessLogValve.rotatable:Z
ifeq 1
aload 0
getfield org.apache.catalina.valves.AccessLogValve.renameOnRotate:Z
ifne 1
iconst_1
goto 2
StackMap locals:
StackMap stack: org.apache.catalina.valves.AccessLogValve
1: iconst_0
StackMap locals: org.apache.catalina.valves.AccessLogValve
StackMap stack: org.apache.catalina.valves.AccessLogValve int
2: invokevirtual org.apache.catalina.valves.AccessLogValve.getLogFile:(Z)Ljava/io/File;
astore 1
start local 1 3: aconst_null
astore 2
start local 2 4: aload 0
getfield org.apache.catalina.valves.AccessLogValve.encoding:Ljava/lang/String;
ifnull 13
5: aload 0
getfield org.apache.catalina.valves.AccessLogValve.encoding:Ljava/lang/String;
invokestatic org.apache.tomcat.util.buf.B2CConverter.getCharset:(Ljava/lang/String;)Ljava/nio/charset/Charset;
astore 2
6: goto 13
StackMap locals: org.apache.catalina.valves.AccessLogValve java.io.File java.nio.charset.Charset
StackMap stack: java.io.UnsupportedEncodingException
7: astore 3
start local 3 8: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
9: ldc "accessLogValve.unsupportedEncoding"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 0
getfield org.apache.catalina.valves.AccessLogValve.encoding:Ljava/lang/String;
aastore
10: invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
11: aload 3
12: invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
end local 3 13: StackMap locals:
StackMap stack:
aload 2
ifnonnull 15
14: getstatic java.nio.charset.StandardCharsets.ISO_8859_1:Ljava/nio/charset/Charset;
astore 2
15: StackMap locals:
StackMap stack:
aload 0
new java.io.PrintWriter
dup
new java.io.BufferedWriter
dup
new java.io.OutputStreamWriter
dup
16: new java.io.FileOutputStream
dup
aload 1
iconst_1
invokespecial java.io.FileOutputStream.<init>:(Ljava/io/File;Z)V
aload 2
invokespecial java.io.OutputStreamWriter.<init>:(Ljava/io/OutputStream;Ljava/nio/charset/Charset;)V
ldc 128000
invokespecial java.io.BufferedWriter.<init>:(Ljava/io/Writer;I)V
17: iconst_0
invokespecial java.io.PrintWriter.<init>:(Ljava/io/Writer;Z)V
18: putfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
19: aload 0
aload 1
putfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
20: goto 25
StackMap locals:
StackMap stack: java.io.IOException
21: astore 3
start local 3 22: aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.writer:Ljava/io/PrintWriter;
23: aload 0
aconst_null
putfield org.apache.catalina.valves.AccessLogValve.currentLogFile:Ljava/io/File;
24: getstatic org.apache.catalina.valves.AccessLogValve.log:Lorg/apache/juli/logging/Log;
getstatic org.apache.catalina.valves.AccessLogValve.sm:Lorg/apache/tomcat/util/res/StringManager;
ldc "accessLogValve.openFail"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 1
aastore
invokevirtual org.apache.tomcat.util.res.StringManager.getString:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
aload 3
invokeinterface org.apache.juli.logging.Log.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
end local 3 25: StackMap locals:
StackMap stack:
aload 0
iconst_1
putfield org.apache.catalina.valves.AccessLogValve.checkForOldLogs:Z
26: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 27 0 this Lorg/apache/catalina/valves/AccessLogValve;
3 27 1 pathname Ljava/io/File;
4 27 2 charset Ljava/nio/charset/Charset;
8 13 3 ex Ljava/io/UnsupportedEncodingException;
22 25 3 e Ljava/io/IOException;
Exception table:
from to target type
5 6 7 Class java.io.UnsupportedEncodingException
15 20 21 Class java.io.IOException
protected synchronized void startInternal();
descriptor: ()V
flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
Code:
stack=6, locals=2, args_size=1
start local 0 0: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.getFileDateFormat:()Ljava/lang/String;
astore 1
start local 1 1: aload 0
new java.text.SimpleDateFormat
dup
aload 1
getstatic java.util.Locale.US:Ljava/util/Locale;
invokespecial java.text.SimpleDateFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
putfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
2: aload 0
getfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
invokestatic java.util.TimeZone.getDefault:()Ljava/util/TimeZone;
invokevirtual java.text.SimpleDateFormat.setTimeZone:(Ljava/util/TimeZone;)V
3: aload 0
aload 0
getfield org.apache.catalina.valves.AccessLogValve.fileDateFormatter:Ljava/text/SimpleDateFormat;
new java.util.Date
dup
invokestatic java.lang.System.currentTimeMillis:()J
invokespecial java.util.Date.<init>:(J)V
invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
putfield org.apache.catalina.valves.AccessLogValve.dateStamp:Ljava/lang/String;
4: aload 0
getfield org.apache.catalina.valves.AccessLogValve.rotatable:Z
ifeq 6
aload 0
getfield org.apache.catalina.valves.AccessLogValve.renameOnRotate:Z
ifeq 6
5: aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.restore:()V
6: StackMap locals: java.lang.String
StackMap stack:
aload 0
invokevirtual org.apache.catalina.valves.AccessLogValve.open:()V
7: aload 0
invokespecial org.apache.catalina.valves.AbstractAccessLogValve.startInternal:()V
8: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/apache/catalina/valves/AccessLogValve;
1 9 1 format Ljava/lang/String;
Exceptions:
throws org.apache.catalina.LifecycleException
protected synchronized void stopInternal();
descriptor: ()V
flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokespecial org.apache.catalina.valves.AbstractAccessLogValve.stopInternal:()V
1: aload 0
iconst_0
invokevirtual org.apache.catalina.valves.AccessLogValve.close:(Z)V
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/catalina/valves/AccessLogValve;
Exceptions:
throws org.apache.catalina.LifecycleException
}
SourceFile: "AccessLogValve.java"