public class io.vertx.ext.web.handler.impl.LoggerHandlerImpl implements io.vertx.ext.web.handler.LoggerHandler
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.vertx.ext.web.handler.impl.LoggerHandlerImpl
  super_class: java.lang.Object
{
  private final io.vertx.core.logging.Logger logger;
    descriptor: Lio/vertx/core/logging/Logger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.text.DateFormat dateTimeFormat;
    descriptor: Ljava/text/DateFormat;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final boolean immediate;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final io.vertx.ext.web.handler.LoggerFormat format;
    descriptor: Lio/vertx/ext/web/handler/LoggerFormat;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private static volatile int[] $SWITCH_TABLE$io$vertx$core$http$HttpVersion;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  private static volatile int[] $SWITCH_TABLE$io$vertx$ext$web$handler$LoggerFormat;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  public void <init>(boolean, io.vertx.ext.web.handler.LoggerFormat);
    descriptor: (ZLio/vertx/ext/web/handler/LoggerFormat;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
        start local 1 // boolean immediate
        start local 2 // io.vertx.ext.web.handler.LoggerFormat format
         0: .line 63
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 49
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokestatic io.vertx.core.logging.LoggerFactory.getLogger:(Ljava/lang/Class;)Lio/vertx/core/logging/Logger;
            putfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.logger:Lio/vertx/core/logging/Logger;
         2: .line 53
            aload 0 /* this */
            invokestatic io.vertx.ext.web.impl.Utils.createRFC1123DateTimeFormatter:()Ljava/text/DateFormat;
            putfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.dateTimeFormat:Ljava/text/DateFormat;
         3: .line 64
            aload 0 /* this */
            iload 1 /* immediate */
            putfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.immediate:Z
         4: .line 65
            aload 0 /* this */
            aload 2 /* format */
            putfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.format:Lio/vertx/ext/web/handler/LoggerFormat;
         5: .line 66
            return
        end local 2 // io.vertx.ext.web.handler.LoggerFormat format
        end local 1 // boolean immediate
        end local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lio/vertx/ext/web/handler/impl/LoggerHandlerImpl;
            0    6     1  immediate  Z
            0    6     2     format  Lio/vertx/ext/web/handler/LoggerFormat;
    MethodParameters:
           Name  Flags
      immediate  
      format     

  public void <init>(io.vertx.ext.web.handler.LoggerFormat);
    descriptor: (Lio/vertx/ext/web/handler/LoggerFormat;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
        start local 1 // io.vertx.ext.web.handler.LoggerFormat format
         0: .line 69
            aload 0 /* this */
            iconst_0
            aload 1 /* format */
            invokespecial io.vertx.ext.web.handler.impl.LoggerHandlerImpl.<init>:(ZLio/vertx/ext/web/handler/LoggerFormat;)V
         1: .line 70
            return
        end local 1 // io.vertx.ext.web.handler.LoggerFormat format
        end local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lio/vertx/ext/web/handler/impl/LoggerHandlerImpl;
            0    2     1  format  Lio/vertx/ext/web/handler/LoggerFormat;
    MethodParameters:
        Name  Flags
      format  

  private java.lang.String getClientAddress(io.vertx.core.net.SocketAddress);
    descriptor: (Lio/vertx/core/net/SocketAddress;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
        start local 1 // io.vertx.core.net.SocketAddress inetSocketAddress
         0: .line 73
            aload 1 /* inetSocketAddress */
            ifnonnull 2
         1: .line 74
            aconst_null
            areturn
         2: .line 76
      StackMap locals:
      StackMap stack:
            aload 1 /* inetSocketAddress */
            invokeinterface io.vertx.core.net.SocketAddress.host:()Ljava/lang/String;
            areturn
        end local 1 // io.vertx.core.net.SocketAddress inetSocketAddress
        end local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    3     0               this  Lio/vertx/ext/web/handler/impl/LoggerHandlerImpl;
            0    3     1  inetSocketAddress  Lio/vertx/core/net/SocketAddress;
    MethodParameters:
                   Name  Flags
      inetSocketAddress  

  private void log(io.vertx.ext.web.RoutingContext, long, java.lang.String, io.vertx.core.http.HttpVersion, io.vertx.core.http.HttpMethod, java.lang.String);
    descriptor: (Lio/vertx/ext/web/RoutingContext;JLjava/lang/String;Lio/vertx/core/http/HttpVersion;Lio/vertx/core/http/HttpMethod;Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=17, args_size=7
        start local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
        start local 1 // io.vertx.ext.web.RoutingContext context
        start local 2 // long timestamp
        start local 4 // java.lang.String remoteClient
        start local 5 // io.vertx.core.http.HttpVersion version
        start local 6 // io.vertx.core.http.HttpMethod method
        start local 7 // java.lang.String uri
         0: .line 80
            aload 1 /* context */
            invokeinterface io.vertx.ext.web.RoutingContext.request:()Lio/vertx/core/http/HttpServerRequest;
            astore 8 /* request */
        start local 8 // io.vertx.core.http.HttpServerRequest request
         1: .line 81
            lconst_0
            lstore 9 /* contentLength */
        start local 9 // long contentLength
         2: .line 82
            aload 0 /* this */
            getfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.immediate:Z
            ifeq 10
         3: .line 83
            aload 8 /* request */
            invokeinterface io.vertx.core.http.HttpServerRequest.headers:()Lio/vertx/core/MultiMap;
            ldc "content-length"
            invokeinterface io.vertx.core.MultiMap.get:(Ljava/lang/String;)Ljava/lang/String;
            astore 11 /* obj */
        start local 11 // java.lang.Object obj
         4: .line 84
            aload 11 /* obj */
            ifnull 11
         5: .line 86
            aload 11 /* obj */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokestatic java.lang.Long.parseLong:(Ljava/lang/String;)J
            lstore 9 /* contentLength */
         6: .line 87
            goto 11
      StackMap locals: io.vertx.ext.web.handler.impl.LoggerHandlerImpl io.vertx.ext.web.RoutingContext long java.lang.String io.vertx.core.http.HttpVersion io.vertx.core.http.HttpMethod java.lang.String io.vertx.core.http.HttpServerRequest long java.lang.Object
      StackMap stack: java.lang.NumberFormatException
         7: pop
         8: .line 89
            lconst_0
            lstore 9 /* contentLength */
        end local 11 // java.lang.Object obj
         9: .line 92
            goto 11
        10: .line 93
      StackMap locals:
      StackMap stack:
            aload 8 /* request */
            invokeinterface io.vertx.core.http.HttpServerRequest.response:()Lio/vertx/core/http/HttpServerResponse;
            invokeinterface io.vertx.core.http.HttpServerResponse.bytesWritten:()J
            lstore 9 /* contentLength */
        11: .line 95
      StackMap locals:
      StackMap stack:
            ldc "-"
            astore 11 /* versionFormatted */
        start local 11 // java.lang.String versionFormatted
        12: .line 96
            invokestatic io.vertx.ext.web.handler.impl.LoggerHandlerImpl.$SWITCH_TABLE$io$vertx$core$http$HttpVersion:()[I
            aload 5 /* version */
            invokevirtual io.vertx.core.http.HttpVersion.ordinal:()I
            iaload
            tableswitch { // 1 - 3
                    1: 13
                    2: 15
                    3: 17
              default: 18
          }
        13: .line 98
      StackMap locals: java.lang.String
      StackMap stack:
            ldc "HTTP/1.0"
            astore 11 /* versionFormatted */
        14: .line 99
            goto 18
        15: .line 101
      StackMap locals:
      StackMap stack:
            ldc "HTTP/1.1"
            astore 11 /* versionFormatted */
        16: .line 102
            goto 18
        17: .line 104
      StackMap locals:
      StackMap stack:
            ldc "HTTP/2.0"
            astore 11 /* versionFormatted */
        18: .line 108
      StackMap locals:
      StackMap stack:
            aload 8 /* request */
            invokeinterface io.vertx.core.http.HttpServerRequest.headers:()Lio/vertx/core/MultiMap;
            astore 12 /* headers */
        start local 12 // io.vertx.core.MultiMap headers
        19: .line 109
            aload 8 /* request */
            invokeinterface io.vertx.core.http.HttpServerRequest.response:()Lio/vertx/core/http/HttpServerResponse;
            invokeinterface io.vertx.core.http.HttpServerResponse.getStatusCode:()I
            istore 13 /* status */
        start local 13 // int status
        20: .line 110
            aconst_null
            astore 14 /* message */
        start local 14 // java.lang.String message
        21: .line 112
            invokestatic io.vertx.ext.web.handler.impl.LoggerHandlerImpl.$SWITCH_TABLE$io$vertx$ext$web$handler$LoggerFormat:()[I
            aload 0 /* this */
            getfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.format:Lio/vertx/ext/web/handler/LoggerFormat;
            invokevirtual io.vertx.ext.web.handler.LoggerFormat.ordinal:()I
            iaload
            tableswitch { // 1 - 3
                    1: 22
                    2: 44
                    3: 54
              default: 61
          }
        22: .line 115
      StackMap locals: io.vertx.core.MultiMap int java.lang.String
      StackMap stack:
            aload 12 /* headers */
            ldc "referrer"
            invokeinterface io.vertx.core.MultiMap.contains:(Ljava/lang/String;)Z
            ifeq 23
            aload 12 /* headers */
            ldc "referrer"
            invokeinterface io.vertx.core.MultiMap.get:(Ljava/lang/String;)Ljava/lang/String;
            goto 24
      StackMap locals:
      StackMap stack:
        23: aload 12 /* headers */
            ldc "referer"
            invokeinterface io.vertx.core.MultiMap.get:(Ljava/lang/String;)Ljava/lang/String;
      StackMap locals:
      StackMap stack: java.lang.String
        24: astore 15 /* referrer */
        start local 15 // java.lang.String referrer
        25: .line 116
            aload 8 /* request */
            invokeinterface io.vertx.core.http.HttpServerRequest.headers:()Lio/vertx/core/MultiMap;
            ldc "user-agent"
            invokeinterface io.vertx.core.MultiMap.get:(Ljava/lang/String;)Ljava/lang/String;
            astore 16 /* userAgent */
        start local 16 // java.lang.String userAgent
        26: .line 117
            aload 15 /* referrer */
            ifnonnull 27
            ldc "-"
            goto 28
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
        27: aload 15 /* referrer */
      StackMap locals:
      StackMap stack: java.lang.String
        28: astore 15 /* referrer */
        29: .line 118
            aload 16 /* userAgent */
            ifnonnull 30
            ldc "-"
            goto 31
      StackMap locals:
      StackMap stack:
        30: aload 16 /* userAgent */
      StackMap locals:
      StackMap stack: java.lang.String
        31: astore 16 /* userAgent */
        32: .line 120
            ldc "%s - - [%s] \"%s %s %s\" %d %d \"%s\" \"%s\""
            bipush 9
            anewarray java.lang.Object
            dup
            iconst_0
        33: .line 121
            aload 4 /* remoteClient */
            aastore
            dup
            iconst_1
        34: .line 122
            aload 0 /* this */
            getfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.dateTimeFormat:Ljava/text/DateFormat;
            new java.util.Date
            dup
            lload 2 /* timestamp */
            invokespecial java.util.Date.<init>:(J)V
            invokevirtual java.text.DateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            aastore
            dup
            iconst_2
        35: .line 123
            aload 6 /* method */
            aastore
            dup
            iconst_3
        36: .line 124
            aload 7 /* uri */
            aastore
            dup
            iconst_4
        37: .line 125
            aload 11 /* versionFormatted */
            aastore
            dup
            iconst_5
        38: .line 126
            iload 13 /* status */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            bipush 6
        39: .line 127
            lload 9 /* contentLength */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            bipush 7
        40: .line 128
            aload 15 /* referrer */
            aastore
            dup
            bipush 8
        41: .line 129
            aload 16 /* userAgent */
            aastore
        42: .line 120
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 14 /* message */
        43: .line 130
            goto 61
        end local 16 // java.lang.String userAgent
        end local 15 // java.lang.String referrer
        44: .line 132
      StackMap locals:
      StackMap stack:
            ldc "%s - %s %s %s %d %d - %d ms"
            bipush 7
            anewarray java.lang.Object
            dup
            iconst_0
        45: .line 133
            aload 4 /* remoteClient */
            aastore
            dup
            iconst_1
        46: .line 134
            aload 6 /* method */
            aastore
            dup
            iconst_2
        47: .line 135
            aload 7 /* uri */
            aastore
            dup
            iconst_3
        48: .line 136
            aload 11 /* versionFormatted */
            aastore
            dup
            iconst_4
        49: .line 137
            iload 13 /* status */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_5
        50: .line 138
            lload 9 /* contentLength */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            bipush 6
        51: .line 139
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 2 /* timestamp */
            lsub
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
        52: .line 132
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 14 /* message */
        53: .line 140
            goto 61
        54: .line 142
      StackMap locals:
      StackMap stack:
            ldc "%s %s %d %d - %d ms"
            iconst_5
            anewarray java.lang.Object
            dup
            iconst_0
        55: .line 143
            aload 6 /* method */
            aastore
            dup
            iconst_1
        56: .line 144
            aload 7 /* uri */
            aastore
            dup
            iconst_2
        57: .line 145
            iload 13 /* status */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_3
        58: .line 146
            lload 9 /* contentLength */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_4
        59: .line 147
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 2 /* timestamp */
            lsub
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
        60: .line 142
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 14 /* message */
        61: .line 150
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 13 /* status */
            aload 14 /* message */
            invokevirtual io.vertx.ext.web.handler.impl.LoggerHandlerImpl.doLog:(ILjava/lang/String;)V
        62: .line 151
            return
        end local 14 // java.lang.String message
        end local 13 // int status
        end local 12 // io.vertx.core.MultiMap headers
        end local 11 // java.lang.String versionFormatted
        end local 9 // long contentLength
        end local 8 // io.vertx.core.http.HttpServerRequest request
        end local 7 // java.lang.String uri
        end local 6 // io.vertx.core.http.HttpMethod method
        end local 5 // io.vertx.core.http.HttpVersion version
        end local 4 // java.lang.String remoteClient
        end local 2 // long timestamp
        end local 1 // io.vertx.ext.web.RoutingContext context
        end local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   63     0              this  Lio/vertx/ext/web/handler/impl/LoggerHandlerImpl;
            0   63     1           context  Lio/vertx/ext/web/RoutingContext;
            0   63     2         timestamp  J
            0   63     4      remoteClient  Ljava/lang/String;
            0   63     5           version  Lio/vertx/core/http/HttpVersion;
            0   63     6            method  Lio/vertx/core/http/HttpMethod;
            0   63     7               uri  Ljava/lang/String;
            1   63     8           request  Lio/vertx/core/http/HttpServerRequest;
            2   63     9     contentLength  J
            4    9    11               obj  Ljava/lang/Object;
           12   63    11  versionFormatted  Ljava/lang/String;
           19   63    12           headers  Lio/vertx/core/MultiMap;
           20   63    13            status  I
           21   63    14           message  Ljava/lang/String;
           25   44    15          referrer  Ljava/lang/String;
           26   44    16         userAgent  Ljava/lang/String;
      Exception table:
        from    to  target  type
           5     6       7  Class java.lang.NumberFormatException
    MethodParameters:
              Name  Flags
      context       
      timestamp     
      remoteClient  
      version       
      method        
      uri           

  protected void doLog(int, java.lang.String);
    descriptor: (ILjava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
        start local 1 // int status
        start local 2 // java.lang.String message
         0: .line 154
            iload 1 /* status */
            sipush 500
            if_icmplt 3
         1: .line 155
            aload 0 /* this */
            getfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.logger:Lio/vertx/core/logging/Logger;
            aload 2 /* message */
            invokevirtual io.vertx.core.logging.Logger.error:(Ljava/lang/Object;)V
         2: .line 156
            goto 7
      StackMap locals:
      StackMap stack:
         3: iload 1 /* status */
            sipush 400
            if_icmplt 6
         4: .line 157
            aload 0 /* this */
            getfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.logger:Lio/vertx/core/logging/Logger;
            aload 2 /* message */
            invokevirtual io.vertx.core.logging.Logger.warn:(Ljava/lang/Object;)V
         5: .line 158
            goto 7
         6: .line 159
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.logger:Lio/vertx/core/logging/Logger;
            aload 2 /* message */
            invokevirtual io.vertx.core.logging.Logger.info:(Ljava/lang/Object;)V
         7: .line 161
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String message
        end local 1 // int status
        end local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0     this  Lio/vertx/ext/web/handler/impl/LoggerHandlerImpl;
            0    8     1   status  I
            0    8     2  message  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      status   
      message  

  public void handle(io.vertx.ext.web.RoutingContext);
    descriptor: (Lio/vertx/ext/web/RoutingContext;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=8, args_size=2
        start local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
        start local 1 // io.vertx.ext.web.RoutingContext context
         0: .line 166
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 2 /* timestamp */
        start local 2 // long timestamp
         1: .line 167
            aload 0 /* this */
            aload 1 /* context */
            invokeinterface io.vertx.ext.web.RoutingContext.request:()Lio/vertx/core/http/HttpServerRequest;
            invokeinterface io.vertx.core.http.HttpServerRequest.remoteAddress:()Lio/vertx/core/net/SocketAddress;
            invokevirtual io.vertx.ext.web.handler.impl.LoggerHandlerImpl.getClientAddress:(Lio/vertx/core/net/SocketAddress;)Ljava/lang/String;
            astore 4 /* remoteClient */
        start local 4 // java.lang.String remoteClient
         2: .line 168
            aload 1 /* context */
            invokeinterface io.vertx.ext.web.RoutingContext.request:()Lio/vertx/core/http/HttpServerRequest;
            invokeinterface io.vertx.core.http.HttpServerRequest.method:()Lio/vertx/core/http/HttpMethod;
            astore 5 /* method */
        start local 5 // io.vertx.core.http.HttpMethod method
         3: .line 169
            aload 1 /* context */
            invokeinterface io.vertx.ext.web.RoutingContext.request:()Lio/vertx/core/http/HttpServerRequest;
            invokeinterface io.vertx.core.http.HttpServerRequest.uri:()Ljava/lang/String;
            astore 6 /* uri */
        start local 6 // java.lang.String uri
         4: .line 170
            aload 1 /* context */
            invokeinterface io.vertx.ext.web.RoutingContext.request:()Lio/vertx/core/http/HttpServerRequest;
            invokeinterface io.vertx.core.http.HttpServerRequest.version:()Lio/vertx/core/http/HttpVersion;
            astore 7 /* version */
        start local 7 // io.vertx.core.http.HttpVersion version
         5: .line 172
            aload 0 /* this */
            getfield io.vertx.ext.web.handler.impl.LoggerHandlerImpl.immediate:Z
            ifeq 8
         6: .line 173
            aload 0 /* this */
            aload 1 /* context */
            lload 2 /* timestamp */
            aload 4 /* remoteClient */
            aload 7 /* version */
            aload 5 /* method */
            aload 6 /* uri */
            invokevirtual io.vertx.ext.web.handler.impl.LoggerHandlerImpl.log:(Lio/vertx/ext/web/RoutingContext;JLjava/lang/String;Lio/vertx/core/http/HttpVersion;Lio/vertx/core/http/HttpMethod;Ljava/lang/String;)V
         7: .line 174
            goto 9
         8: .line 175
      StackMap locals: io.vertx.ext.web.handler.impl.LoggerHandlerImpl io.vertx.ext.web.RoutingContext long java.lang.String io.vertx.core.http.HttpMethod java.lang.String io.vertx.core.http.HttpVersion
      StackMap stack:
            aload 1 /* context */
            aload 0 /* this */
            aload 1 /* context */
            lload 2 /* timestamp */
            aload 4 /* remoteClient */
            aload 7 /* version */
            aload 5 /* method */
            aload 6 /* uri */
            invokedynamic handle(Lio/vertx/ext/web/handler/impl/LoggerHandlerImpl;Lio/vertx/ext/web/RoutingContext;JLjava/lang/String;Lio/vertx/core/http/HttpVersion;Lio/vertx/core/http/HttpMethod;Ljava/lang/String;)Lio/vertx/core/Handler;
              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;)V
                  io/vertx/ext/web/handler/impl/LoggerHandlerImpl.lambda$0(Lio/vertx/ext/web/RoutingContext;JLjava/lang/String;Lio/vertx/core/http/HttpVersion;Lio/vertx/core/http/HttpMethod;Ljava/lang/String;Ljava/lang/Void;)V (7)
                  (Ljava/lang/Void;)V
            invokeinterface io.vertx.ext.web.RoutingContext.addBodyEndHandler:(Lio/vertx/core/Handler;)I
            pop
         9: .line 178
      StackMap locals:
      StackMap stack:
            aload 1 /* context */
            invokeinterface io.vertx.ext.web.RoutingContext.next:()V
        10: .line 180
            return
        end local 7 // io.vertx.core.http.HttpVersion version
        end local 6 // java.lang.String uri
        end local 5 // io.vertx.core.http.HttpMethod method
        end local 4 // java.lang.String remoteClient
        end local 2 // long timestamp
        end local 1 // io.vertx.ext.web.RoutingContext context
        end local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   11     0          this  Lio/vertx/ext/web/handler/impl/LoggerHandlerImpl;
            0   11     1       context  Lio/vertx/ext/web/RoutingContext;
            1   11     2     timestamp  J
            2   11     4  remoteClient  Ljava/lang/String;
            3   11     5        method  Lio/vertx/core/http/HttpMethod;
            4   11     6           uri  Ljava/lang/String;
            5   11     7       version  Lio/vertx/core/http/HttpVersion;
    MethodParameters:
         Name  Flags
      context  

  public void handle(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            checkcast io.vertx.ext.web.RoutingContext
            invokevirtual io.vertx.ext.web.handler.impl.LoggerHandlerImpl.handle:(Lio/vertx/ext/web/RoutingContext;)V
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static int[] $SWITCH_TABLE$io$vertx$core$http$HttpVersion();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 47
            getstatic io.vertx.ext.web.handler.impl.LoggerHandlerImpl.$SWITCH_TABLE$io$vertx$core$http$HttpVersion:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic io.vertx.core.http.HttpVersion.values:()[Lio/vertx/core/http/HttpVersion;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic io.vertx.core.http.HttpVersion.HTTP_1_0:Lio/vertx/core/http/HttpVersion;
            invokevirtual io.vertx.core.http.HttpVersion.ordinal:()I
            iconst_1
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic io.vertx.core.http.HttpVersion.HTTP_1_1:Lio/vertx/core/http/HttpVersion;
            invokevirtual io.vertx.core.http.HttpVersion.ordinal:()I
            iconst_2
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic io.vertx.core.http.HttpVersion.HTTP_2:Lio/vertx/core/http/HttpVersion;
            invokevirtual io.vertx.core.http.HttpVersion.ordinal:()I
            iconst_3
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            dup
            putstatic io.vertx.ext.web.handler.impl.LoggerHandlerImpl.$SWITCH_TABLE$io$vertx$core$http$HttpVersion:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError

  static int[] $SWITCH_TABLE$io$vertx$ext$web$handler$LoggerFormat();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 47
            getstatic io.vertx.ext.web.handler.impl.LoggerHandlerImpl.$SWITCH_TABLE$io$vertx$ext$web$handler$LoggerFormat:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic io.vertx.ext.web.handler.LoggerFormat.values:()[Lio/vertx/ext/web/handler/LoggerFormat;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic io.vertx.ext.web.handler.LoggerFormat.DEFAULT:Lio/vertx/ext/web/handler/LoggerFormat;
            invokevirtual io.vertx.ext.web.handler.LoggerFormat.ordinal:()I
            iconst_1
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic io.vertx.ext.web.handler.LoggerFormat.SHORT:Lio/vertx/ext/web/handler/LoggerFormat;
            invokevirtual io.vertx.ext.web.handler.LoggerFormat.ordinal:()I
            iconst_2
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic io.vertx.ext.web.handler.LoggerFormat.TINY:Lio/vertx/ext/web/handler/LoggerFormat;
            invokevirtual io.vertx.ext.web.handler.LoggerFormat.ordinal:()I
            iconst_3
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            dup
            putstatic io.vertx.ext.web.handler.impl.LoggerHandlerImpl.$SWITCH_TABLE$io$vertx$ext$web$handler$LoggerFormat:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError

  private void lambda$0(io.vertx.ext.web.RoutingContext, long, java.lang.String, io.vertx.core.http.HttpVersion, io.vertx.core.http.HttpMethod, java.lang.String, java.lang.Void);
    descriptor: (Lio/vertx/ext/web/RoutingContext;JLjava/lang/String;Lio/vertx/core/http/HttpVersion;Lio/vertx/core/http/HttpMethod;Ljava/lang/String;Ljava/lang/Void;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=8, locals=9, args_size=8
        start local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
        start local 8 // java.lang.Void v
         0: .line 175
            aload 0 /* this */
            aload 1
            lload 2
            aload 4
            aload 5
            aload 6
            aload 7
            invokevirtual io.vertx.ext.web.handler.impl.LoggerHandlerImpl.log:(Lio/vertx/ext/web/RoutingContext;JLjava/lang/String;Lio/vertx/core/http/HttpVersion;Lio/vertx/core/http/HttpMethod;Ljava/lang/String;)V
            return
        end local 8 // java.lang.Void v
        end local 0 // io.vertx.ext.web.handler.impl.LoggerHandlerImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/vertx/ext/web/handler/impl/LoggerHandlerImpl;
            0    1     8     v  Ljava/lang/Void;
}
SourceFile: "LoggerHandlerImpl.java"
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles