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: .line 33
            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: .line 39
            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 // io.undertow.attribute.ResponseTimeAttribute this
        start local 1 // java.util.concurrent.TimeUnit timeUnit
         0: .line 43
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 44
            aload 0 /* this */
            aload 1 /* timeUnit */
            putfield io.undertow.attribute.ResponseTimeAttribute.timeUnit:Ljava/util/concurrent/TimeUnit;
         2: .line 45
            return
        end local 1 // java.util.concurrent.TimeUnit timeUnit
        end local 0 // io.undertow.attribute.ResponseTimeAttribute this
      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 // io.undertow.attribute.ResponseTimeAttribute this
        start local 1 // io.undertow.server.HttpServerExchange exchange
         0: .line 49
            aload 1 /* exchange */
            invokevirtual io.undertow.server.HttpServerExchange.getRequestStartTime:()J
            lstore 2 /* requestStartTime */
        start local 2 // long requestStartTime
         1: .line 50
            lload 2 /* requestStartTime */
            ldc -1
            lcmp
            ifne 3
         2: .line 51
            aconst_null
            areturn
         3: .line 54
      StackMap locals: long
      StackMap stack:
            aload 1 /* exchange */
            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 /* first */
        start local 6 // java.lang.Long first
         4: .line 55
            aload 6 /* first */
            ifnull 7
         5: .line 56
            aload 6 /* first */
            invokevirtual java.lang.Long.longValue:()J
            lstore 4 /* nanos */
        start local 4 // long nanos
         6: .line 57
            goto 10
        end local 4 // long nanos
         7: .line 58
      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 /* requestStartTime */
            lsub
            lstore 4 /* nanos */
        start local 4 // long nanos
         8: .line 59
            aload 1 /* exchange */
            invokevirtual io.undertow.server.HttpServerExchange.isResponseComplete:()Z
            ifeq 10
         9: .line 61
            aload 1 /* exchange */
            getstatic io.undertow.attribute.ResponseTimeAttribute.FIRST_RESPONSE_TIME_NANOS:Lio/undertow/util/AttachmentKey;
            lload 4 /* nanos */
            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: .line 64
      StackMap locals: io.undertow.attribute.ResponseTimeAttribute io.undertow.server.HttpServerExchange long long java.lang.Long
      StackMap stack:
            aload 0 /* this */
            getfield io.undertow.attribute.ResponseTimeAttribute.timeUnit:Ljava/util/concurrent/TimeUnit;
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            if_acmpne 21
        11: .line 65
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 7 /* buf */
        start local 7 // java.lang.StringBuilder buf
        12: .line 66
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            lload 4 /* nanos */
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual java.util.concurrent.TimeUnit.convert:(JLjava/util/concurrent/TimeUnit;)J
            lstore 8 /* milis */
        start local 8 // long milis
        13: .line 67
            aload 7 /* buf */
            lload 8 /* milis */
            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: .line 68
            aload 7 /* buf */
            bipush 46
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        15: .line 69
            lload 8 /* milis */
            ldc 1000
            lrem
            l2i
            istore 10 /* remains */
        start local 10 // int remains
        16: .line 70
            aload 7 /* buf */
            iload 10 /* remains */
            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: .line 71
            iload 10 /* remains */
            bipush 100
            irem
            istore 10 /* remains */
        18: .line 72
            aload 7 /* buf */
            iload 10 /* remains */
            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: .line 73
            aload 7 /* buf */
            iload 10 /* remains */
            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: .line 74
            aload 7 /* buf */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 10 // int remains
        end local 8 // long milis
        end local 7 // java.lang.StringBuilder buf
        21: .line 76
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.undertow.attribute.ResponseTimeAttribute.timeUnit:Ljava/util/concurrent/TimeUnit;
            lload 4 /* nanos */
            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 // java.lang.Long first
        end local 4 // long nanos
        end local 2 // long requestStartTime
        end local 1 // io.undertow.server.HttpServerExchange exchange
        end local 0 // io.undertow.attribute.ResponseTimeAttribute this
      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 // io.undertow.attribute.ResponseTimeAttribute this
        start local 1 // io.undertow.server.HttpServerExchange exchange
        start local 2 // java.lang.String newValue
         0: .line 82
            new io.undertow.attribute.ReadOnlyAttributeException
            dup
            ldc "Response Time"
            aload 2 /* newValue */
            invokespecial io.undertow.attribute.ReadOnlyAttributeException.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            athrow
        end local 2 // java.lang.String newValue
        end local 1 // io.undertow.server.HttpServerExchange exchange
        end local 0 // io.undertow.attribute.ResponseTimeAttribute this
      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