public class org.graalvm.compiler.debug.GlobalMetrics
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.debug.GlobalMetrics
  super_class: java.lang.Object
{
  long[] values;
    descriptor: [J
    flags: (0x0000) 

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.debug.GlobalMetrics this
         0: .line 44
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.graalvm.compiler.debug.GlobalMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/debug/GlobalMetrics;

  public synchronized void add(org.graalvm.compiler.debug.DebugContext);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.debug.GlobalMetrics this
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
         0: .line 51
            aload 0 /* this */
            aload 1 /* debug */
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.GlobalMetrics.values:[J
            invokevirtual org.graalvm.compiler.debug.DebugContext.addValuesTo:([J)[J
            putfield org.graalvm.compiler.debug.GlobalMetrics.values:[J
         1: .line 52
            return
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.debug.GlobalMetrics this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lorg/graalvm/compiler/debug/GlobalMetrics;
            0    2     1  debug  Lorg/graalvm/compiler/debug/DebugContext;
    MethodParameters:
       Name  Flags
      debug  

  public synchronized void clear();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.debug.GlobalMetrics this
         0: .line 58
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.debug.GlobalMetrics.values:[J
         1: .line 59
            return
        end local 0 // org.graalvm.compiler.debug.GlobalMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/graalvm/compiler/debug/GlobalMetrics;

  public org.graalvm.collections.EconomicMap<org.graalvm.compiler.debug.MetricKey, java.lang.Long> asKeyValueMap();
    descriptor: ()Lorg/graalvm/collections/EconomicMap;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=1
        start local 0 // org.graalvm.compiler.debug.GlobalMetrics this
         0: .line 65
            invokestatic org.graalvm.compiler.debug.KeyRegistry.getKeys:()Ljava/util/List;
            astore 1 /* keys */
        start local 1 // java.util.List keys
         1: .line 66
            aload 1 /* keys */
            getstatic org.graalvm.compiler.debug.MetricKey.NAME_COMPARATOR:Ljava/util/Comparator;
            invokestatic java.util.Collections.sort:(Ljava/util/List;Ljava/util/Comparator;)V
         2: .line 67
            aload 1 /* keys */
            invokeinterface java.util.List.size:()I
            invokestatic org.graalvm.collections.EconomicMap.create:(I)Lorg/graalvm/collections/EconomicMap;
            astore 2 /* res */
        start local 2 // org.graalvm.collections.EconomicMap res
         3: .line 68
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.GlobalMetrics.values:[J
            astore 3 /* vals */
        start local 3 // long[] vals
         4: .line 69
            aload 1 /* keys */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 11
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics java.util.List org.graalvm.collections.EconomicMap long[] top java.util.Iterator
      StackMap stack:
         5: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.debug.MetricKey
            astore 4 /* key */
        start local 4 // org.graalvm.compiler.debug.MetricKey key
         6: .line 70
            aload 4 /* key */
            checkcast org.graalvm.compiler.debug.AbstractKey
            invokevirtual org.graalvm.compiler.debug.AbstractKey.getIndex:()I
            istore 6 /* index */
        start local 6 // int index
         7: .line 71
            aload 3 /* vals */
            ifnull 8
            iload 6 /* index */
            aload 3 /* vals */
            arraylength
            if_icmplt 10
         8: .line 72
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics java.util.List org.graalvm.collections.EconomicMap long[] org.graalvm.compiler.debug.MetricKey java.util.Iterator int
      StackMap stack:
            aload 2 /* res */
            aload 4 /* key */
            lconst_0
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface org.graalvm.collections.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         9: .line 73
            goto 11
        10: .line 74
      StackMap locals:
      StackMap stack:
            aload 2 /* res */
            aload 4 /* key */
            aload 3 /* vals */
            iload 6 /* index */
            laload
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface org.graalvm.collections.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 6 // int index
        end local 4 // org.graalvm.compiler.debug.MetricKey key
        11: .line 69
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics java.util.List org.graalvm.collections.EconomicMap long[] top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        12: .line 77
            aload 2 /* res */
            areturn
        end local 3 // long[] vals
        end local 2 // org.graalvm.collections.EconomicMap res
        end local 1 // java.util.List keys
        end local 0 // org.graalvm.compiler.debug.GlobalMetrics this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   13     0   this  Lorg/graalvm/compiler/debug/GlobalMetrics;
            1   13     1   keys  Ljava/util/List<Lorg/graalvm/compiler/debug/MetricKey;>;
            3   13     2    res  Lorg/graalvm/collections/EconomicMap<Lorg/graalvm/compiler/debug/MetricKey;Ljava/lang/Long;>;
            4   13     3   vals  [J
            6   11     4    key  Lorg/graalvm/compiler/debug/MetricKey;
            7   11     6  index  I
    Signature: ()Lorg/graalvm/collections/EconomicMap<Lorg/graalvm/compiler/debug/MetricKey;Ljava/lang/Long;>;

  private static java.io.PrintStream openPrintStream(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/io/PrintStream;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // java.lang.String metricsFile
         0: .line 81
            aload 0 /* metricsFile */
            ifnonnull 2
         1: .line 82
            invokestatic org.graalvm.compiler.debug.DebugContext.getDefaultLogStream:()Ljava/io/PrintStream;
            areturn
         2: .line 84
      StackMap locals:
      StackMap stack:
            invokestatic org.graalvm.compiler.serviceprovider.IsolateUtil.getIsolateID:()J
            lstore 1 /* isolateID */
        start local 1 // long isolateID
         3: .line 86
            lload 1 /* isolateID */
            lconst_0
            lcmp
            ifeq 10
         4: .line 87
            aload 0 /* metricsFile */
            bipush 46
            invokevirtual java.lang.String.lastIndexOf:(I)I
            istore 4 /* lastDot */
        start local 4 // int lastDot
         5: .line 88
            iload 4 /* lastDot */
            iconst_m1
            if_icmpeq 8
         6: .line 89
            new java.lang.StringBuilder
            dup
            aload 0 /* metricsFile */
            iconst_0
            iload 4 /* lastDot */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            bipush 64
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            lload 1 /* isolateID */
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            aload 0 /* metricsFile */
            iload 4 /* lastDot */
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.String
            invokestatic java.nio.file.Paths.get:(Ljava/lang/String;[Ljava/lang/String;)Ljava/nio/file/Path;
            astore 3 /* path */
        start local 3 // java.nio.file.Path path
         7: .line 90
            goto 11
        end local 3 // java.nio.file.Path path
         8: .line 91
      StackMap locals: java.lang.String long top int
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 0 /* metricsFile */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            lload 1 /* isolateID */
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.String
            invokestatic java.nio.file.Paths.get:(Ljava/lang/String;[Ljava/lang/String;)Ljava/nio/file/Path;
            astore 3 /* path */
        end local 4 // int lastDot
        start local 3 // java.nio.file.Path path
         9: .line 93
            goto 11
        end local 3 // java.nio.file.Path path
        10: .line 94
      StackMap locals: java.lang.String long
      StackMap stack:
            aload 0 /* metricsFile */
            iconst_0
            anewarray java.lang.String
            invokestatic java.nio.file.Paths.get:(Ljava/lang/String;[Ljava/lang/String;)Ljava/nio/file/Path;
            astore 3 /* path */
        start local 3 // java.nio.file.Path path
        11: .line 96
      StackMap locals: java.nio.file.Path
      StackMap stack:
            new java.io.PrintStream
            dup
            aload 3 /* path */
            iconst_0
            anewarray java.nio.file.OpenOption
            invokestatic java.nio.file.Files.newOutputStream:(Ljava/nio/file/Path;[Ljava/nio/file/OpenOption;)Ljava/io/OutputStream;
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            areturn
        end local 3 // java.nio.file.Path path
        end local 1 // long isolateID
        end local 0 // java.lang.String metricsFile
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   12     0  metricsFile  Ljava/lang/String;
            3   12     1    isolateID  J
            7    8     3         path  Ljava/nio/file/Path;
            9   10     3         path  Ljava/nio/file/Path;
           11   12     3         path  Ljava/nio/file/Path;
            5    9     4      lastDot  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      metricsFile  

  public synchronized void print(org.graalvm.compiler.options.OptionValues);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=13, args_size=2
        start local 0 // org.graalvm.compiler.debug.GlobalMetrics this
        start local 1 // org.graalvm.compiler.options.OptionValues options
         0: .line 106
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.GlobalMetrics.values:[J
            astore 2 /* vals */
        start local 2 // long[] vals
         1: .line 107
            aload 2 /* vals */
            ifnull 38
         2: .line 108
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.debug.GlobalMetrics.asKeyValueMap:()Lorg/graalvm/collections/EconomicMap;
            astore 3 /* map */
        start local 3 // org.graalvm.collections.EconomicMap map
         3: .line 109
            getstatic org.graalvm.compiler.debug.DebugOptions.AggregatedMetricsFile:Lorg/graalvm/compiler/options/OptionKey;
            aload 1 /* options */
            invokevirtual org.graalvm.compiler.options.OptionKey.getValue:(Lorg/graalvm/compiler/options/OptionValues;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* metricsFile */
        start local 4 // java.lang.String metricsFile
         4: .line 110
            aload 4 /* metricsFile */
            ifnull 6
            aload 4 /* metricsFile */
            ldc ".csv"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifne 5
            aload 4 /* metricsFile */
            ldc ".CSV"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 6
      StackMap locals: long[] org.graalvm.collections.EconomicMap java.lang.String
      StackMap stack:
         5: iconst_1
            goto 7
      StackMap locals:
      StackMap stack:
         6: iconst_0
      StackMap locals:
      StackMap stack: int
         7: istore 5 /* csv */
        start local 5 // boolean csv
         8: .line 111
            aconst_null
            astore 6 /* p */
        start local 6 // java.io.PrintStream p
         9: .line 113
            aload 4 /* metricsFile */
            invokestatic org.graalvm.compiler.debug.GlobalMetrics.openPrintStream:(Ljava/lang/String;)Ljava/io/PrintStream;
            astore 6 /* p */
        10: .line 114
            iconst_0
            invokestatic org.graalvm.compiler.serviceprovider.IsolateUtil.getIsolateID:(Z)Ljava/lang/String;
            astore 7 /* isolateID */
        start local 7 // java.lang.String isolateID
        11: .line 115
            iload 5 /* csv */
            ifne 14
        12: .line 116
            aload 3 /* map */
            invokeinterface org.graalvm.collections.EconomicMap.isEmpty:()Z
            ifne 14
        13: .line 117
            aload 6 /* p */
            ldc "++ Aggregated Metrics %s ++%n"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 7 /* isolateID */
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        14: .line 120
      StackMap locals: int java.io.PrintStream java.lang.String
      StackMap stack:
            iconst_3
            anewarray java.lang.String
            dup
            iconst_0
            ldc "%s"
            aastore
            dup
            iconst_1
            ldc "%s"
            aastore
            dup
            iconst_2
            ldc "%s"
            aastore
            invokestatic org.graalvm.compiler.debug.CSVUtil.buildFormatString:([Ljava/lang/String;)Ljava/lang/String;
            astore 8 /* csvFormat */
        start local 8 // java.lang.String csvFormat
        15: .line 121
            aload 3 /* map */
            invokeinterface org.graalvm.collections.EconomicMap.getEntries:()Lorg/graalvm/collections/MapCursor;
            astore 9 /* e */
        start local 9 // org.graalvm.collections.MapCursor e
        16: .line 122
            goto 23
        17: .line 123
      StackMap locals: java.lang.String org.graalvm.collections.MapCursor
      StackMap stack:
            aload 9 /* e */
            invokeinterface org.graalvm.collections.MapCursor.getKey:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.debug.MetricKey
            astore 10 /* key */
        start local 10 // org.graalvm.compiler.debug.MetricKey key
        18: .line 124
            iload 5 /* csv */
            ifeq 22
        19: .line 125
            aload 10 /* key */
            aload 9 /* e */
            invokeinterface org.graalvm.collections.MapCursor.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            invokeinterface org.graalvm.compiler.debug.MetricKey.toCSVFormat:(J)Lorg/graalvm/collections/Pair;
            astore 11 /* valueAndUnit */
        start local 11 // org.graalvm.collections.Pair valueAndUnit
        20: .line 126
            aload 6 /* p */
            aload 8 /* csvFormat */
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 10 /* key */
            invokeinterface org.graalvm.compiler.debug.MetricKey.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_1
            aload 11 /* valueAndUnit */
            invokevirtual org.graalvm.collections.Pair.getLeft:()Ljava/lang/Object;
            aastore
            dup
            iconst_2
            aload 11 /* valueAndUnit */
            invokevirtual org.graalvm.collections.Pair.getRight:()Ljava/lang/Object;
            aastore
            invokestatic org.graalvm.compiler.debug.CSVUtil$Escape.println:(Ljava/io/PrintStream;Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        end local 11 // org.graalvm.collections.Pair valueAndUnit
        21: .line 127
            goto 23
        22: .line 128
      StackMap locals: org.graalvm.compiler.debug.MetricKey
      StackMap stack:
            aload 6 /* p */
            new java.lang.StringBuilder
            dup
            aload 10 /* key */
            invokeinterface org.graalvm.compiler.debug.MetricKey.getName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 10 /* key */
            aload 9 /* e */
            invokeinterface org.graalvm.collections.MapCursor.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            invokeinterface org.graalvm.compiler.debug.MetricKey.toHumanReadableFormat:(J)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 10 // org.graalvm.compiler.debug.MetricKey key
        23: .line 122
      StackMap locals:
      StackMap stack:
            aload 9 /* e */
            invokeinterface org.graalvm.collections.MapCursor.advance:()Z
            ifne 17
        24: .line 131
            iload 5 /* csv */
            ifne 36
        25: .line 132
            aload 3 /* map */
            invokeinterface org.graalvm.collections.EconomicMap.isEmpty:()Z
            ifne 36
        26: .line 133
            aload 6 /* p */
            ldc "-- Aggregated Metrics %s --%n"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 7 /* isolateID */
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        end local 9 // org.graalvm.collections.MapCursor e
        end local 8 // java.lang.String csvFormat
        end local 7 // java.lang.String isolateID
        27: .line 136
            goto 36
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics org.graalvm.compiler.options.OptionValues long[] org.graalvm.collections.EconomicMap java.lang.String int java.io.PrintStream
      StackMap stack: java.io.IOException
        28: astore 7 /* e */
        start local 7 // java.io.IOException e
        29: .line 137
            aload 7 /* e */
            invokevirtual java.io.IOException.printStackTrace:()V
        end local 7 // java.io.IOException e
        30: .line 140
            aload 4 /* metricsFile */
            ifnull 38
            aload 6 /* p */
            ifnull 38
        31: .line 141
            aload 6 /* p */
            invokevirtual java.io.PrintStream.close:()V
            goto 38
        32: .line 138
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 12
        33: .line 140
            aload 4 /* metricsFile */
            ifnull 35
            aload 6 /* p */
            ifnull 35
        34: .line 141
            aload 6 /* p */
            invokevirtual java.io.PrintStream.close:()V
        35: .line 143
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics org.graalvm.compiler.options.OptionValues long[] org.graalvm.collections.EconomicMap java.lang.String int java.io.PrintStream top top top top top java.lang.Throwable
      StackMap stack:
            aload 12
            athrow
        36: .line 140
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics org.graalvm.compiler.options.OptionValues long[] org.graalvm.collections.EconomicMap java.lang.String int java.io.PrintStream
      StackMap stack:
            aload 4 /* metricsFile */
            ifnull 38
            aload 6 /* p */
            ifnull 38
        37: .line 141
            aload 6 /* p */
            invokevirtual java.io.PrintStream.close:()V
        end local 6 // java.io.PrintStream p
        end local 5 // boolean csv
        end local 4 // java.lang.String metricsFile
        end local 3 // org.graalvm.collections.EconomicMap map
        38: .line 146
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics org.graalvm.compiler.options.OptionValues long[]
      StackMap stack:
            getstatic org.graalvm.compiler.debug.DebugOptions.ListMetrics:Lorg/graalvm/compiler/options/OptionKey;
            aload 1 /* options */
            invokevirtual org.graalvm.compiler.options.OptionKey.getValue:(Lorg/graalvm/compiler/options/OptionValues;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 54
        39: .line 147
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            astore 3 /* p */
        start local 3 // java.io.PrintStream p
        40: .line 148
            aload 3 /* p */
            ldc "++ Metric Keys ++"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        41: .line 149
            invokestatic org.graalvm.compiler.debug.KeyRegistry.getKeys:()Ljava/util/List;
            astore 4 /* keys */
        start local 4 // java.util.List keys
        42: .line 150
            aload 4 /* keys */
            getstatic org.graalvm.compiler.debug.MetricKey.NAME_COMPARATOR:Ljava/util/Comparator;
            invokestatic java.util.Collections.sort:(Ljava/util/List;Ljava/util/Comparator;)V
        43: .line 151
            aload 4 /* keys */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 52
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics org.graalvm.compiler.options.OptionValues long[] java.io.PrintStream java.util.List top java.util.Iterator
      StackMap stack:
        44: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.debug.MetricKey
            astore 5 /* key */
        start local 5 // org.graalvm.compiler.debug.MetricKey key
        45: .line 152
            aload 5 /* key */
            invokeinterface org.graalvm.compiler.debug.MetricKey.getDocName:()Ljava/lang/String;
            astore 7 /* name */
        start local 7 // java.lang.String name
        46: .line 153
            aload 7 /* name */
            ifnull 52
        47: .line 154
            aload 5 /* key */
            invokeinterface org.graalvm.compiler.debug.MetricKey.getDoc:()Ljava/lang/String;
            astore 8 /* doc */
        start local 8 // java.lang.String doc
        48: .line 155
            aload 8 /* doc */
            ifnull 51
        49: .line 156
            aload 3 /* p */
            new java.lang.StringBuilder
            dup
            aload 7 /* name */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 8 /* doc */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        50: .line 157
            goto 52
        51: .line 158
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics org.graalvm.compiler.options.OptionValues long[] java.io.PrintStream java.util.List org.graalvm.compiler.debug.MetricKey java.util.Iterator java.lang.String java.lang.String
      StackMap stack:
            aload 3 /* p */
            aload 7 /* name */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 8 // java.lang.String doc
        end local 7 // java.lang.String name
        end local 5 // org.graalvm.compiler.debug.MetricKey key
        52: .line 151
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics org.graalvm.compiler.options.OptionValues long[] java.io.PrintStream java.util.List top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 44
        53: .line 162
            aload 3 /* p */
            ldc "-- Metric Keys --"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 4 // java.util.List keys
        end local 3 // java.io.PrintStream p
        54: .line 164
      StackMap locals: org.graalvm.compiler.debug.GlobalMetrics org.graalvm.compiler.options.OptionValues long[]
      StackMap stack:
            return
        end local 2 // long[] vals
        end local 1 // org.graalvm.compiler.options.OptionValues options
        end local 0 // org.graalvm.compiler.debug.GlobalMetrics this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   55     0          this  Lorg/graalvm/compiler/debug/GlobalMetrics;
            0   55     1       options  Lorg/graalvm/compiler/options/OptionValues;
            1   55     2          vals  [J
            3   38     3           map  Lorg/graalvm/collections/EconomicMap<Lorg/graalvm/compiler/debug/MetricKey;Ljava/lang/Long;>;
            4   38     4   metricsFile  Ljava/lang/String;
            8   38     5           csv  Z
            9   38     6             p  Ljava/io/PrintStream;
           11   27     7     isolateID  Ljava/lang/String;
           15   27     8     csvFormat  Ljava/lang/String;
           16   27     9             e  Lorg/graalvm/collections/MapCursor<Lorg/graalvm/compiler/debug/MetricKey;Ljava/lang/Long;>;
           18   23    10           key  Lorg/graalvm/compiler/debug/MetricKey;
           20   21    11  valueAndUnit  Lorg/graalvm/collections/Pair<Ljava/lang/String;Ljava/lang/String;>;
           29   30     7             e  Ljava/io/IOException;
           40   54     3             p  Ljava/io/PrintStream;
           42   54     4          keys  Ljava/util/List<Lorg/graalvm/compiler/debug/MetricKey;>;
           45   52     5           key  Lorg/graalvm/compiler/debug/MetricKey;
           46   52     7          name  Ljava/lang/String;
           48   52     8           doc  Ljava/lang/String;
      Exception table:
        from    to  target  type
           9    27      28  Class java.io.IOException
           9    30      32  any
    MethodParameters:
         Name  Flags
      options  
}
SourceFile: "GlobalMetrics.java"
InnerClasses:
  public final Escape = org.graalvm.compiler.debug.CSVUtil$Escape of org.graalvm.compiler.debug.CSVUtil