public class io.undertow.attribute.ResponseTimeAttribute implements io.undertow.attribute.ExchangeAttribute
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: io.undertow.attribute.ResponseTimeAttribute
super_class: java.lang.Object
{
private static final io.undertow.util.AttachmentKey<java.lang.Long> FIRST_RESPONSE_TIME_NANOS;
descriptor: Lio/undertow/util/AttachmentKey;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Lio/undertow/util/AttachmentKey<Ljava/lang/Long;>;
public static final java.lang.String RESPONSE_TIME_MILLIS_SHORT;
descriptor: Ljava/lang/String;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
ConstantValue: "%D"
public static final java.lang.String RESPONSE_TIME_SECONDS_SHORT;
descriptor: Ljava/lang/String;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
ConstantValue: "%T"
public static final java.lang.String RESPONSE_TIME_MILLIS;
descriptor: Ljava/lang/String;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
ConstantValue: "%{RESPONSE_TIME}"
public static final java.lang.String RESPONSE_TIME_MICROS;
descriptor: Ljava/lang/String;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
ConstantValue: "%{RESPONSE_TIME_MICROS}"
public static final java.lang.String RESPONSE_TIME_NANOS;
descriptor: Ljava/lang/String;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
ConstantValue: "%{RESPONSE_TIME_NANOS}"
private final java.util.concurrent.TimeUnit timeUnit;
descriptor: Ljava/util/concurrent/TimeUnit;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Ljava/lang/Long;
invokestatic io.undertow.util.AttachmentKey.create:(Ljava/lang/Class;)Lio/undertow/util/AttachmentKey;
putstatic io.undertow.attribute.ResponseTimeAttribute.FIRST_RESPONSE_TIME_NANOS:Lio/undertow/util/AttachmentKey;
1: return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(java.util.concurrent.TimeUnit);
descriptor: (Ljava/util/concurrent/TimeUnit;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 1
putfield io.undertow.attribute.ResponseTimeAttribute.timeUnit:Ljava/util/concurrent/TimeUnit;
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lio/undertow/attribute/ResponseTimeAttribute;
0 3 1 timeUnit Ljava/util/concurrent/TimeUnit;
MethodParameters:
Name Flags
timeUnit
public java.lang.String readAttribute(io.undertow.server.HttpServerExchange);
descriptor: (Lio/undertow/server/HttpServerExchange;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=11, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual io.undertow.server.HttpServerExchange.getRequestStartTime:()J
lstore 2
start local 2 1: lload 2
ldc -1
lcmp
ifne 3
2: aconst_null
areturn
3: StackMap locals: long
StackMap stack:
aload 1
getstatic io.undertow.attribute.ResponseTimeAttribute.FIRST_RESPONSE_TIME_NANOS:Lio/undertow/util/AttachmentKey;
invokevirtual io.undertow.server.HttpServerExchange.getAttachment:(Lio/undertow/util/AttachmentKey;)Ljava/lang/Object;
checkcast java.lang.Long
astore 6
start local 6 4: aload 6
ifnull 7
5: aload 6
invokevirtual java.lang.Long.longValue:()J
lstore 4
start local 4 6: goto 10
end local 4 7: StackMap locals: io.undertow.attribute.ResponseTimeAttribute io.undertow.server.HttpServerExchange long top top java.lang.Long
StackMap stack:
invokestatic java.lang.System.nanoTime:()J
lload 2
lsub
lstore 4
start local 4 8: aload 1
invokevirtual io.undertow.server.HttpServerExchange.isResponseComplete:()Z
ifeq 10
9: aload 1
getstatic io.undertow.attribute.ResponseTimeAttribute.FIRST_RESPONSE_TIME_NANOS:Lio/undertow/util/AttachmentKey;
lload 4
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
invokevirtual io.undertow.server.HttpServerExchange.putAttachment:(Lio/undertow/util/AttachmentKey;Ljava/lang/Object;)Ljava/lang/Object;
pop
10: StackMap locals: io.undertow.attribute.ResponseTimeAttribute io.undertow.server.HttpServerExchange long long java.lang.Long
StackMap stack:
aload 0
getfield io.undertow.attribute.ResponseTimeAttribute.timeUnit:Ljava/util/concurrent/TimeUnit;
getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
if_acmpne 21
11: new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 7
start local 7 12: getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
lload 4
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invokevirtual java.util.concurrent.TimeUnit.convert:(JLjava/util/concurrent/TimeUnit;)J
lstore 8
start local 8 13: aload 7
lload 8
ldc 1000
ldiv
invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
14: aload 7
bipush 46
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
15: lload 8
ldc 1000
lrem
l2i
istore 10
start local 10 16: aload 7
iload 10
bipush 100
idiv
i2l
invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
17: iload 10
bipush 100
irem
istore 10
18: aload 7
iload 10
bipush 10
idiv
i2l
invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
19: aload 7
iload 10
bipush 10
irem
i2l
invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
20: aload 7
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 10 end local 8 end local 7 21: StackMap locals:
StackMap stack:
aload 0
getfield io.undertow.attribute.ResponseTimeAttribute.timeUnit:Ljava/util/concurrent/TimeUnit;
lload 4
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invokevirtual java.util.concurrent.TimeUnit.convert:(JLjava/util/concurrent/TimeUnit;)J
invokestatic java.lang.String.valueOf:(J)Ljava/lang/String;
areturn
end local 6 end local 4 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 22 0 this Lio/undertow/attribute/ResponseTimeAttribute;
0 22 1 exchange Lio/undertow/server/HttpServerExchange;
1 22 2 requestStartTime J
6 7 4 nanos J
8 22 4 nanos J
4 22 6 first Ljava/lang/Long;
12 21 7 buf Ljava/lang/StringBuilder;
13 21 8 milis J
16 21 10 remains I
MethodParameters:
Name Flags
exchange
public void writeAttribute(io.undertow.server.HttpServerExchange, java.lang.String);
descriptor: (Lio/undertow/server/HttpServerExchange;Ljava/lang/String;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: new io.undertow.attribute.ReadOnlyAttributeException
dup
ldc "Response Time"
aload 2
invokespecial io.undertow.attribute.ReadOnlyAttributeException.<init>:(Ljava/lang/String;Ljava/lang/String;)V
athrow
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/undertow/attribute/ResponseTimeAttribute;
0 1 1 exchange Lio/undertow/server/HttpServerExchange;
0 1 2 newValue Ljava/lang/String;
Exceptions:
throws io.undertow.attribute.ReadOnlyAttributeException
MethodParameters:
Name Flags
exchange
newValue
}
SourceFile: "ResponseTimeAttribute.java"
NestMembers:
io.undertow.attribute.ResponseTimeAttribute$Builder
InnerClasses:
public final Builder = io.undertow.attribute.ResponseTimeAttribute$Builder of io.undertow.attribute.ResponseTimeAttribute