class io.ebeaninternal.server.core.DumpMetricsJson implements io.ebean.meta.ServerMetricsAsJson
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: io.ebeaninternal.server.core.DumpMetricsJson
  super_class: java.lang.Object
{
  private final io.ebean.Database database;
    descriptor: Lio/ebean/Database;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private java.lang.Appendable writer;
    descriptor: Ljava/lang/Appendable;
    flags: (0x0002) ACC_PRIVATE

  private int includeExtraAttributes;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private boolean withHeader;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private boolean withHash;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String newLine;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private java.util.Comparator<io.ebean.meta.MetaTimedMetric> sortBy;
    descriptor: Ljava/util/Comparator;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Comparator<Lio/ebean/meta/MetaTimedMetric;>;

  private int listCounter;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int objKeyCounter;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  void <init>(io.ebean.Database);
    descriptor: (Lio/ebean/Database;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // io.ebean.Database database
         0: .line 37
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 26
            aload 0 /* this */
            iconst_1
            putfield io.ebeaninternal.server.core.DumpMetricsJson.includeExtraAttributes:I
         2: .line 28
            aload 0 /* this */
            iconst_1
            putfield io.ebeaninternal.server.core.DumpMetricsJson.withHeader:Z
         3: .line 29
            aload 0 /* this */
            iconst_1
            putfield io.ebeaninternal.server.core.DumpMetricsJson.withHash:Z
         4: .line 30
            aload 0 /* this */
            ldc "\n"
            putfield io.ebeaninternal.server.core.DumpMetricsJson.newLine:Ljava/lang/String;
         5: .line 32
            aload 0 /* this */
            getstatic io.ebean.meta.SortMetric.NAME:Ljava/util/Comparator;
            putfield io.ebeaninternal.server.core.DumpMetricsJson.sortBy:Ljava/util/Comparator;
         6: .line 38
            aload 0 /* this */
            aload 1 /* database */
            putfield io.ebeaninternal.server.core.DumpMetricsJson.database:Lio/ebean/Database;
         7: .line 39
            return
        end local 1 // io.ebean.Database database
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    8     0      this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    8     1  database  Lio/ebean/Database;
    MethodParameters:
          Name  Flags
      database  

  public io.ebean.meta.ServerMetricsAsJson withHeader(boolean);
    descriptor: (Z)Lio/ebean/meta/ServerMetricsAsJson;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // boolean withHeader
         0: .line 43
            aload 0 /* this */
            iload 1 /* withHeader */
            putfield io.ebeaninternal.server.core.DumpMetricsJson.withHeader:Z
         1: .line 44
            aload 0 /* this */
            areturn
        end local 1 // boolean withHeader
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    2     1  withHeader  Z
    MethodParameters:
            Name  Flags
      withHeader  

  public io.ebean.meta.ServerMetricsAsJson withExtraAttributes(boolean);
    descriptor: (Z)Lio/ebean/meta/ServerMetricsAsJson;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // boolean extraAttributes
         0: .line 49
            aload 0 /* this */
            iload 1 /* extraAttributes */
            ifeq 1
            iconst_2
            goto 2
      StackMap locals:
      StackMap stack: io.ebeaninternal.server.core.DumpMetricsJson
         1: iconst_0
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson int
      StackMap stack: io.ebeaninternal.server.core.DumpMetricsJson int
         2: putfield io.ebeaninternal.server.core.DumpMetricsJson.includeExtraAttributes:I
         3: .line 50
            aload 0 /* this */
            areturn
        end local 1 // boolean extraAttributes
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    4     0             this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    4     1  extraAttributes  Z
    MethodParameters:
                 Name  Flags
      extraAttributes  

  public io.ebean.meta.ServerMetricsAsJson withHash(boolean);
    descriptor: (Z)Lio/ebean/meta/ServerMetricsAsJson;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // boolean withHash
         0: .line 55
            aload 0 /* this */
            iload 1 /* withHash */
            putfield io.ebeaninternal.server.core.DumpMetricsJson.withHash:Z
         1: .line 56
            aload 0 /* this */
            areturn
        end local 1 // boolean withHash
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    2     1  withHash  Z
    MethodParameters:
          Name  Flags
      withHash  

  public io.ebean.meta.ServerMetricsAsJson withSort(java.util.Comparator<io.ebean.meta.MetaTimedMetric>);
    descriptor: (Ljava/util/Comparator;)Lio/ebean/meta/ServerMetricsAsJson;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // java.util.Comparator sortBy
         0: .line 61
            aload 0 /* this */
            aload 1 /* sortBy */
            putfield io.ebeaninternal.server.core.DumpMetricsJson.sortBy:Ljava/util/Comparator;
         1: .line 62
            aload 0 /* this */
            areturn
        end local 1 // java.util.Comparator sortBy
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    2     1  sortBy  Ljava/util/Comparator<Lio/ebean/meta/MetaTimedMetric;>;
    Signature: (Ljava/util/Comparator<Lio/ebean/meta/MetaTimedMetric;>;)Lio/ebean/meta/ServerMetricsAsJson;
    MethodParameters:
        Name  Flags
      sortBy  

  public io.ebean.meta.ServerMetricsAsJson withNewLine(boolean);
    descriptor: (Z)Lio/ebean/meta/ServerMetricsAsJson;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // boolean withNewLine
         0: .line 67
            aload 0 /* this */
            iload 1 /* withNewLine */
            ifeq 1
            ldc "\n"
            goto 2
      StackMap locals:
      StackMap stack: io.ebeaninternal.server.core.DumpMetricsJson
         1: ldc ""
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson int
      StackMap stack: io.ebeaninternal.server.core.DumpMetricsJson java.lang.String
         2: putfield io.ebeaninternal.server.core.DumpMetricsJson.newLine:Ljava/lang/String;
         3: .line 68
            aload 0 /* this */
            areturn
        end local 1 // boolean withNewLine
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    4     1  withNewLine  Z
    MethodParameters:
             Name  Flags
      withNewLine  

  public java.lang.String json();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
         0: .line 73
            aload 0 /* this */
            new java.io.StringWriter
            dup
            invokespecial java.io.StringWriter.<init>:()V
            putfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
         1: .line 74
            aload 0 /* this */
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.database:Lio/ebean/Database;
            invokeinterface io.ebean.Database.getMetaInfoManager:()Lio/ebean/meta/MetaInfoManager;
            invokeinterface io.ebean.meta.MetaInfoManager.collectMetrics:()Lio/ebean/meta/ServerMetrics;
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.collect:(Lio/ebean/meta/ServerMetrics;)V
         2: .line 75
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            areturn
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;

  public void write(java.lang.Appendable);
    descriptor: (Ljava/lang/Appendable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // java.lang.Appendable buffer
         0: .line 80
            aload 0 /* this */
            aload 1 /* buffer */
            putfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
         1: .line 81
            aload 0 /* this */
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.database:Lio/ebean/Database;
            invokeinterface io.ebean.Database.getMetaInfoManager:()Lio/ebean/meta/MetaInfoManager;
            invokeinterface io.ebean.meta.MetaInfoManager.collectMetrics:()Lio/ebean/meta/ServerMetrics;
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.collect:(Lio/ebean/meta/ServerMetrics;)V
         2: .line 82
            return
        end local 1 // java.lang.Appendable buffer
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    3     1  buffer  Ljava/lang/Appendable;
    MethodParameters:
        Name  Flags
      buffer  

  private void collect(io.ebean.meta.ServerMetrics);
    descriptor: (Lio/ebean/meta/ServerMetrics;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // io.ebean.meta.ServerMetrics serverMetrics
         0: .line 86
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.start:()V
         1: .line 87
            aload 1 /* serverMetrics */
            invokeinterface io.ebean.meta.ServerMetrics.getTimedMetrics:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson io.ebean.meta.ServerMetrics top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.ebean.meta.MetaTimedMetric
            astore 2 /* metric */
        start local 2 // io.ebean.meta.MetaTimedMetric metric
         3: .line 88
            aload 0 /* this */
            aload 2 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.logTimed:(Lio/ebean/meta/MetaTimedMetric;)V
        end local 2 // io.ebean.meta.MetaTimedMetric metric
         4: .line 87
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 91
            aload 1 /* serverMetrics */
            invokeinterface io.ebean.meta.ServerMetrics.getCountMetrics:()Ljava/util/List;
            astore 2 /* countMetrics */
        start local 2 // java.util.List countMetrics
         6: .line 92
            aload 2 /* countMetrics */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 13
         7: .line 93
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.sortBy:Ljava/util/Comparator;
            ifnull 9
         8: .line 94
            aload 2 /* countMetrics */
            getstatic io.ebean.meta.SortMetric.COUNT_NAME:Ljava/util/Comparator;
            invokeinterface java.util.List.sort:(Ljava/util/Comparator;)V
         9: .line 96
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson io.ebean.meta.ServerMetrics java.util.List
      StackMap stack:
            aload 2 /* countMetrics */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 12
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson io.ebean.meta.ServerMetrics java.util.List top java.util.Iterator
      StackMap stack:
        10: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.ebean.meta.MetaCountMetric
            astore 3 /* metric */
        start local 3 // io.ebean.meta.MetaCountMetric metric
        11: .line 97
            aload 0 /* this */
            aload 3 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.logCount:(Lio/ebean/meta/MetaCountMetric;)V
        end local 3 // io.ebean.meta.MetaCountMetric metric
        12: .line 96
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        13: .line 101
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson io.ebean.meta.ServerMetrics java.util.List
      StackMap stack:
            aload 1 /* serverMetrics */
            invokeinterface io.ebean.meta.ServerMetrics.getQueryMetrics:()Ljava/util/List;
            astore 3 /* queryMetrics */
        start local 3 // java.util.List queryMetrics
        14: .line 102
            aload 3 /* queryMetrics */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 21
        15: .line 103
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.sortBy:Ljava/util/Comparator;
            ifnull 17
        16: .line 104
            aload 3 /* queryMetrics */
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.sortBy:Ljava/util/Comparator;
            invokeinterface java.util.List.sort:(Ljava/util/Comparator;)V
        17: .line 106
      StackMap locals: java.util.List
      StackMap stack:
            aload 3 /* queryMetrics */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 20
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson io.ebean.meta.ServerMetrics java.util.List java.util.List top java.util.Iterator
      StackMap stack:
        18: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.ebean.meta.MetaQueryMetric
            astore 4 /* metric */
        start local 4 // io.ebean.meta.MetaQueryMetric metric
        19: .line 107
            aload 0 /* this */
            aload 4 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.logQuery:(Lio/ebean/meta/MetaQueryMetric;)V
        end local 4 // io.ebean.meta.MetaQueryMetric metric
        20: .line 106
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 18
        21: .line 110
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson io.ebean.meta.ServerMetrics java.util.List java.util.List
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.end:()V
        end local 3 // java.util.List queryMetrics
        end local 2 // java.util.List countMetrics
        22: .line 111
            goto 25
      StackMap locals: io.ebeaninternal.server.core.DumpMetricsJson io.ebean.meta.ServerMetrics
      StackMap stack: java.io.IOException
        23: astore 2 /* e */
        start local 2 // java.io.IOException e
        24: .line 112
            new java.lang.RuntimeException
            dup
            ldc "Error writing metrics as JSON"
            aload 2 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.IOException e
        25: .line 114
      StackMap locals:
      StackMap stack:
            return
        end local 1 // io.ebean.meta.ServerMetrics serverMetrics
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   26     0           this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0   26     1  serverMetrics  Lio/ebean/meta/ServerMetrics;
            3    4     2         metric  Lio/ebean/meta/MetaTimedMetric;
            6   22     2   countMetrics  Ljava/util/List<Lio/ebean/meta/MetaCountMetric;>;
           11   12     3         metric  Lio/ebean/meta/MetaCountMetric;
           14   22     3   queryMetrics  Ljava/util/List<Lio/ebean/meta/MetaQueryMetric;>;
           19   20     4         metric  Lio/ebean/meta/MetaQueryMetric;
           24   25     2              e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           0    22      23  Class java.io.IOException
    MethodParameters:
               Name  Flags
      serverMetrics  

  private void start();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
         0: .line 117
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.withHeader:Z
            ifeq 6
         1: .line 118
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.objStart:()V
         2: .line 119
            aload 0 /* this */
            ldc "db"
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         3: .line 120
            aload 0 /* this */
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.database:Lio/ebean/Database;
            invokeinterface io.ebean.Database.getName:()Ljava/lang/String;
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.val:(Ljava/lang/String;)V
         4: .line 121
            aload 0 /* this */
            ldc "metrics"
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         5: .line 122
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.listStart:()V
         6: .line 124
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
    Exceptions:
      throws java.io.IOException

  private void end();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
         0: .line 127
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.withHeader:Z
            ifeq 3
         1: .line 128
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.listEnd:()V
         2: .line 129
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.objEnd:()V
         3: .line 131
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
    Exceptions:
      throws java.io.IOException

  private void objStart();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
         0: .line 134
            aload 0 /* this */
            iconst_0
            putfield io.ebeaninternal.server.core.DumpMetricsJson.objKeyCounter:I
         1: .line 135
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            ldc "{"
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         2: .line 136
            return
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
    Exceptions:
      throws java.io.IOException

  private void objEnd();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
         0: .line 139
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            ldc "}"
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         1: .line 140
            return
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
    Exceptions:
      throws java.io.IOException

  private void listStart();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
         0: .line 143
            aload 0 /* this */
            iconst_0
            putfield io.ebeaninternal.server.core.DumpMetricsJson.listCounter:I
         1: .line 144
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            ldc "["
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         2: .line 145
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.newLine:Ljava/lang/String;
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         3: .line 146
            return
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
    Exceptions:
      throws java.io.IOException

  private void listEnd();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
         0: .line 149
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            ldc "]"
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         1: .line 150
            return
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
    Exceptions:
      throws java.io.IOException

  private void key(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // java.lang.String key
         0: .line 153
            aload 0 /* this */
            dup
            getfield io.ebeaninternal.server.core.DumpMetricsJson.objKeyCounter:I
            dup_x1
            iconst_1
            iadd
            putfield io.ebeaninternal.server.core.DumpMetricsJson.objKeyCounter:I
            ifle 2
         1: .line 154
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            ldc ", "
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         2: .line 156
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            ldc "\""
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            aload 1 /* key */
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            ldc "\":"
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         3: .line 157
            return
        end local 1 // java.lang.String key
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    4     1   key  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      key   

  private void val(long);
    descriptor: (J)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // long count
         0: .line 160
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            lload 1 /* count */
            invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         1: .line 161
            return
        end local 1 // long count
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    2     1  count  J
    Exceptions:
      throws java.io.IOException
    MethodParameters:
       Name  Flags
      count  

  private void val(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // java.lang.String val
         0: .line 164
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            ldc "\""
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            aload 1 /* val */
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            ldc "\""
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         1: .line 165
            return
        end local 1 // java.lang.String val
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    2     1   val  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      val   

  private void metricStart(io.ebean.meta.MetaMetric);
    descriptor: (Lio/ebean/meta/MetaMetric;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // io.ebean.meta.MetaMetric metric
         0: .line 168
            aload 0 /* this */
            dup
            getfield io.ebeaninternal.server.core.DumpMetricsJson.listCounter:I
            dup_x1
            iconst_1
            iadd
            putfield io.ebeaninternal.server.core.DumpMetricsJson.listCounter:I
            ifle 2
         1: .line 169
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.writer:Ljava/lang/Appendable;
            ldc ","
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.newLine:Ljava/lang/String;
            invokeinterface java.lang.Appendable.append:(Ljava/lang/CharSequence;)Ljava/lang/Appendable;
            pop
         2: .line 171
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.objStart:()V
         3: .line 172
            aload 0 /* this */
            ldc "name"
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         4: .line 173
            aload 0 /* this */
            aload 1 /* metric */
            invokeinterface io.ebean.meta.MetaMetric.getName:()Ljava/lang/String;
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.val:(Ljava/lang/String;)V
         5: .line 174
            return
        end local 1 // io.ebean.meta.MetaMetric metric
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    6     1  metric  Lio/ebean/meta/MetaMetric;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
        Name  Flags
      metric  

  private void metricEnd();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
         0: .line 177
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.objEnd:()V
         1: .line 178
            return
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
    Exceptions:
      throws java.io.IOException

  private void logCount(io.ebean.meta.MetaCountMetric);
    descriptor: (Lio/ebean/meta/MetaCountMetric;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // io.ebean.meta.MetaCountMetric metric
         0: .line 181
            aload 0 /* this */
            aload 1 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.metricStart:(Lio/ebean/meta/MetaMetric;)V
         1: .line 182
            aload 0 /* this */
            ldc "count"
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         2: .line 183
            aload 0 /* this */
            aload 1 /* metric */
            invokeinterface io.ebean.meta.MetaCountMetric.getCount:()J
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.val:(J)V
         3: .line 184
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.metricEnd:()V
         4: .line 185
            return
        end local 1 // io.ebean.meta.MetaCountMetric metric
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    5     1  metric  Lio/ebean/meta/MetaCountMetric;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
        Name  Flags
      metric  

  private void logTimed(io.ebean.meta.MetaTimedMetric);
    descriptor: (Lio/ebean/meta/MetaTimedMetric;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // io.ebean.meta.MetaTimedMetric metric
         0: .line 188
            aload 0 /* this */
            aload 1 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.metricStart:(Lio/ebean/meta/MetaMetric;)V
         1: .line 189
            aload 0 /* this */
            aload 1 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.appendTiming:(Lio/ebean/meta/MetaTimedMetric;)V
         2: .line 190
            aload 0 /* this */
            aload 1 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.isIncludeDetail:(Lio/ebean/meta/MetaTimedMetric;)Z
            ifeq 4
         3: .line 191
            aload 0 /* this */
            ldc "loc"
            aload 1 /* metric */
            invokeinterface io.ebean.meta.MetaTimedMetric.getLocation:()Ljava/lang/String;
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.appendExtra:(Ljava/lang/String;Ljava/lang/String;)V
         4: .line 193
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.metricEnd:()V
         5: .line 194
            return
        end local 1 // io.ebean.meta.MetaTimedMetric metric
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    6     1  metric  Lio/ebean/meta/MetaTimedMetric;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
        Name  Flags
      metric  

  private void logQuery(io.ebean.meta.MetaQueryMetric);
    descriptor: (Lio/ebean/meta/MetaQueryMetric;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // io.ebean.meta.MetaQueryMetric metric
         0: .line 197
            aload 0 /* this */
            aload 1 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.metricStart:(Lio/ebean/meta/MetaMetric;)V
         1: .line 198
            aload 0 /* this */
            aload 1 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.appendTiming:(Lio/ebean/meta/MetaTimedMetric;)V
         2: .line 199
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.withHash:Z
            ifeq 4
         3: .line 200
            aload 0 /* this */
            ldc "hash"
            aload 1 /* metric */
            invokeinterface io.ebean.meta.MetaQueryMetric.getHash:()Ljava/lang/String;
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.appendExtra:(Ljava/lang/String;Ljava/lang/String;)V
         4: .line 202
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* metric */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.isIncludeDetail:(Lio/ebean/meta/MetaTimedMetric;)Z
            ifeq 7
         5: .line 203
            aload 0 /* this */
            ldc "loc"
            aload 1 /* metric */
            invokeinterface io.ebean.meta.MetaQueryMetric.getLocation:()Ljava/lang/String;
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.appendExtra:(Ljava/lang/String;Ljava/lang/String;)V
         6: .line 204
            aload 0 /* this */
            ldc "sql"
            aload 1 /* metric */
            invokeinterface io.ebean.meta.MetaQueryMetric.getSql:()Ljava/lang/String;
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.appendExtra:(Ljava/lang/String;Ljava/lang/String;)V
         7: .line 206
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.metricEnd:()V
         8: .line 207
            return
        end local 1 // io.ebean.meta.MetaQueryMetric metric
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    9     1  metric  Lio/ebean/meta/MetaQueryMetric;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
        Name  Flags
      metric  

  private boolean isIncludeDetail(io.ebean.meta.MetaTimedMetric);
    descriptor: (Lio/ebean/meta/MetaTimedMetric;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // io.ebean.meta.MetaTimedMetric metric
         0: .line 210
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.includeExtraAttributes:I
            iconst_2
            if_icmpeq 2
            aload 0 /* this */
            getfield io.ebeaninternal.server.core.DumpMetricsJson.includeExtraAttributes:I
            iconst_1
            if_icmpne 1
            aload 1 /* metric */
            invokeinterface io.ebean.meta.MetaTimedMetric.initialCollection:()Z
            ifne 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         2: iconst_1
            ireturn
        end local 1 // io.ebean.meta.MetaTimedMetric metric
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    3     1  metric  Lio/ebean/meta/MetaTimedMetric;
    MethodParameters:
        Name  Flags
      metric  

  private void appendExtra(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // java.lang.String key
        start local 2 // java.lang.String val
         0: .line 214
            aload 2 /* val */
            ifnull 3
         1: .line 215
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         2: .line 216
            aload 0 /* this */
            aload 2 /* val */
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.val:(Ljava/lang/String;)V
         3: .line 218
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String val
        end local 1 // java.lang.String key
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    4     1   key  Ljava/lang/String;
            0    4     2   val  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      key   
      val   

  private void appendTiming(io.ebean.meta.MetaTimedMetric);
    descriptor: (Lio/ebean/meta/MetaTimedMetric;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
        start local 1 // io.ebean.meta.MetaTimedMetric timedMetric
         0: .line 221
            aload 0 /* this */
            ldc "count"
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         1: .line 222
            aload 0 /* this */
            aload 1 /* timedMetric */
            invokeinterface io.ebean.meta.MetaTimedMetric.getCount:()J
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.val:(J)V
         2: .line 223
            aload 0 /* this */
            ldc "total"
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         3: .line 224
            aload 0 /* this */
            aload 1 /* timedMetric */
            invokeinterface io.ebean.meta.MetaTimedMetric.getTotal:()J
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.val:(J)V
         4: .line 225
            aload 0 /* this */
            ldc "mean"
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         5: .line 226
            aload 0 /* this */
            aload 1 /* timedMetric */
            invokeinterface io.ebean.meta.MetaTimedMetric.getMean:()J
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.val:(J)V
         6: .line 227
            aload 0 /* this */
            ldc "max"
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.key:(Ljava/lang/String;)V
         7: .line 228
            aload 0 /* this */
            aload 1 /* timedMetric */
            invokeinterface io.ebean.meta.MetaTimedMetric.getMax:()J
            invokevirtual io.ebeaninternal.server.core.DumpMetricsJson.val:(J)V
         8: .line 229
            return
        end local 1 // io.ebean.meta.MetaTimedMetric timedMetric
        end local 0 // io.ebeaninternal.server.core.DumpMetricsJson this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    9     0         this  Lio/ebeaninternal/server/core/DumpMetricsJson;
            0    9     1  timedMetric  Lio/ebean/meta/MetaTimedMetric;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      timedMetric  
}
SourceFile: "DumpMetricsJson.java"