public class org.apache.catalina.valves.ExtendedAccessLogValve$TimeElement implements org.apache.catalina.valves.AbstractAccessLogValve$AccessLogElement
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.catalina.valves.ExtendedAccessLogValve$TimeElement
super_class: java.lang.Object
{
private static final long INTERVAL;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 1000
private static final java.lang.ThreadLocal<org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct> currentTime;
descriptor: Ljava/lang/ThreadLocal;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/lang/ThreadLocal<Lorg/apache/catalina/valves/ExtendedAccessLogValve$ElementTimestampStruct;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: invokedynamic get()Ljava/util/function/Supplier;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
()Ljava/lang/Object;
org/apache/catalina/valves/ExtendedAccessLogValve$TimeElement.lambda$0()Lorg/apache/catalina/valves/ExtendedAccessLogValve$ElementTimestampStruct; (6)
()Lorg/apache/catalina/valves/ExtendedAccessLogValve$ElementTimestampStruct;
invokestatic java.lang.ThreadLocal.withInitial:(Ljava/util/function/Supplier;)Ljava/lang/ThreadLocal;
1: putstatic org.apache.catalina.valves.ExtendedAccessLogValve$TimeElement.currentTime:Ljava/lang/ThreadLocal;
2: return
LocalVariableTable:
Start End Slot Name Signature
protected void <init>();
descriptor: ()V
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/catalina/valves/ExtendedAccessLogValve$TimeElement;
public void addElement(java.io.CharArrayWriter, java.util.Date, org.apache.catalina.connector.Request, org.apache.catalina.connector.Response, long);
descriptor: (Ljava/io/CharArrayWriter;Ljava/util/Date;Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;J)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=10, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: getstatic org.apache.catalina.valves.ExtendedAccessLogValve$TimeElement.currentTime:Ljava/lang/ThreadLocal;
invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
checkcast org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct
astore 7
start local 7 1: aload 7
getfield org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct.currentTimestamp:Ljava/util/Date;
invokevirtual java.util.Date.getTime:()J
lstore 8
start local 8 2: aload 2
invokevirtual java.util.Date.getTime:()J
lload 8
ldc 1000
ladd
lconst_1
lsub
lcmp
ifgt 4
3: aload 2
invokevirtual java.util.Date.getTime:()J
lload 8
lcmp
ifge 10
4: StackMap locals: org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct long
StackMap stack:
aload 7
getfield org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct.currentTimestamp:Ljava/util/Date;
5: aload 2
invokevirtual java.util.Date.getTime:()J
aload 2
invokevirtual java.util.Date.getTime:()J
ldc 1000
lrem
lsub
6: invokevirtual java.util.Date.setTime:(J)V
7: aload 7
8: aload 7
getfield org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct.currentTimestampFormat:Ljava/text/SimpleDateFormat;
aload 7
getfield org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct.currentTimestamp:Ljava/util/Date;
invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
9: putfield org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct.currentTimestampString:Ljava/lang/String;
10: StackMap locals:
StackMap stack:
aload 1
aload 7
getfield org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct.currentTimestampString:Ljava/lang/String;
invokevirtual java.io.CharArrayWriter.append:(Ljava/lang/CharSequence;)Ljava/io/CharArrayWriter;
pop
11: return
end local 8 end local 7 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 12 0 this Lorg/apache/catalina/valves/ExtendedAccessLogValve$TimeElement;
0 12 1 buf Ljava/io/CharArrayWriter;
0 12 2 date Ljava/util/Date;
0 12 3 request Lorg/apache/catalina/connector/Request;
0 12 4 response Lorg/apache/catalina/connector/Response;
0 12 5 time J
1 12 7 eds Lorg/apache/catalina/valves/ExtendedAccessLogValve$ElementTimestampStruct;
2 12 8 millis J
MethodParameters:
Name Flags
buf
date
request
response
time
private static org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct lambda$0();
descriptor: ()Lorg/apache/catalina/valves/ExtendedAccessLogValve$ElementTimestampStruct;
flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
Code:
stack=3, locals=0, args_size=0
0: new org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct
dup
ldc "HH:mm:ss"
invokespecial org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct.<init>:(Ljava/lang/String;)V
areturn
LocalVariableTable:
Start End Slot Name Signature
}
SourceFile: "ExtendedAccessLogValve.java"
NestHost: org.apache.catalina.valves.ExtendedAccessLogValve
InnerClasses:
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
protected abstract AccessLogElement = org.apache.catalina.valves.AbstractAccessLogValve$AccessLogElement of org.apache.catalina.valves.AbstractAccessLogValve
private ElementTimestampStruct = org.apache.catalina.valves.ExtendedAccessLogValve$ElementTimestampStruct of org.apache.catalina.valves.ExtendedAccessLogValve
protected TimeElement = org.apache.catalina.valves.ExtendedAccessLogValve$TimeElement of org.apache.catalina.valves.ExtendedAccessLogValve