public class org.graalvm.compiler.debug.internal.method.MethodMetricsImpl implements org.graalvm.compiler.debug.DebugMethodMetrics
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl
  super_class: java.lang.Object
{
  private static final java.util.List<java.util.Map<jdk.vm.ci.meta.ResolvedJavaMethod, org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData>> threadMaps;
    descriptor: Ljava/util/List;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/List<Ljava/util/Map<Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;>;>;

  private static final java.lang.ThreadLocal<java.util.Map<jdk.vm.ci.meta.ResolvedJavaMethod, org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData>> threadEntries;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Ljava/util/Map<Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;>;>;

  private static long lowestCompilationDebugScopeId;
    descriptor: J
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private final jdk.vm.ci.meta.ResolvedJavaMethod method;
    descriptor: Ljdk/vm/ci/meta/ResolvedJavaMethod;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private java.util.List<java.util.Map<java.lang.Long, java.util.Map<java.lang.String, java.lang.Long>>> collected;
    descriptor: Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/List<Ljava/util/Map<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;>;

  private java.util.Map<java.lang.String, java.lang.Long> currentCompilation;
    descriptor: Ljava/util/Map;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  private static final java.lang.String FMT;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String INLINEE_PREFIX;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "INLINING_SCOPE_"

  private static final boolean TRACK_INLINED_SCOPES;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  private static final boolean COUNT_CACHE;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  private static final java.lang.String HIT_MSG;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "InterceptionCache_Hit"

  private static final java.lang.String MISS_MSG;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "InterceptionCache_Miss"

  private static final org.graalvm.compiler.debug.DebugCounter cacheHit;
    descriptor: Lorg/graalvm/compiler/debug/DebugCounter;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final org.graalvm.compiler.debug.DebugCounter cacheMiss;
    descriptor: Lorg/graalvm/compiler/debug/DebugCounter;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.ThreadLocal<java.lang.Long> interceptionCache;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Ljava/lang/Long;>;

  private static final java.lang.ThreadLocal<org.graalvm.compiler.debug.internal.method.MethodMetricsImpl> interceptionMetrics;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;>;

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 44
            ldc Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.$assertionsDisabled:Z
         3: .line 52
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadMaps:Ljava/util/List;
         4: .line 60
            new java.lang.ThreadLocal
            dup
            invokespecial java.lang.ThreadLocal.<init>:()V
            putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadEntries:Ljava/lang/ThreadLocal;
         5: .line 297
            bipush 6
            anewarray java.lang.String
            dup
            iconst_0
            ldc "%s"
            aastore
            dup
            iconst_1
            ldc "%s"
            aastore
            dup
            iconst_2
            ldc "%d"
            aastore
            dup
            iconst_3
            ldc "%d"
            aastore
            dup
            iconst_4
            ldc "%s"
            aastore
            dup
            iconst_5
            ldc "%d"
            aastore
            invokestatic org.graalvm.compiler.debug.CSVUtil.buildFormatString:([Ljava/lang/String;)Ljava/lang/String;
            putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.FMT:Ljava/lang/String;
         6: .line 384
            ldc "InterceptionCache_Hit"
            invokestatic org.graalvm.compiler.debug.Debug.counter:(Ljava/lang/CharSequence;)Lorg/graalvm/compiler/debug/DebugCounter;
            putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.cacheHit:Lorg/graalvm/compiler/debug/DebugCounter;
         7: .line 385
            ldc "InterceptionCache_Miss"
            invokestatic org.graalvm.compiler.debug.Debug.counter:(Ljava/lang/CharSequence;)Lorg/graalvm/compiler/debug/DebugCounter;
            putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.cacheMiss:Lorg/graalvm/compiler/debug/DebugCounter;
         8: .line 393
            new java.lang.ThreadLocal
            dup
            invokespecial java.lang.ThreadLocal.<init>:()V
            putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.interceptionCache:Ljava/lang/ThreadLocal;
         9: .line 394
            new java.lang.ThreadLocal
            dup
            invokespecial java.lang.ThreadLocal.<init>:()V
            putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.interceptionMetrics:Ljava/lang/ThreadLocal;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static void addThreadCompilationData(java.util.Map<jdk.vm.ci.meta.ResolvedJavaMethod, org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData>);
    descriptor: (Ljava/util/Map;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.util.Map threadMap
         0: .line 94
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadMaps:Ljava/util/List;
            dup
            astore 1
            monitorenter
         1: .line 95
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadMaps:Ljava/util/List;
            aload 0 /* threadMap */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         2: .line 94
            aload 1
            monitorexit
         3: goto 6
      StackMap locals: java.util.Map java.util.List
      StackMap stack: java.lang.Throwable
         4: aload 1
            monitorexit
         5: athrow
         6: .line 97
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.util.Map threadMap
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0  threadMap  Ljava/util/Map<Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;>;
      Exception table:
        from    to  target  type
           1     3       4  any
           4     5       4  any
    Signature: (Ljava/util/Map<Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;>;)V
    MethodParameters:
           Name  Flags
      threadMap  

  void <init>(jdk.vm.ci.meta.ResolvedJavaMethod);
    descriptor: (Ljdk/vm/ci/meta/ResolvedJavaMethod;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // jdk.vm.ci.meta.ResolvedJavaMethod method
         0: .line 118
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 119
            aload 0 /* this */
            aload 1 /* method */
            putfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.method:Ljdk/vm/ci/meta/ResolvedJavaMethod;
         2: .line 120
            return
        end local 1 // jdk.vm.ci.meta.ResolvedJavaMethod method
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    3     1  method  Ljdk/vm/ci/meta/ResolvedJavaMethod;
    MethodParameters:
        Name  Flags
      method  

  private static void clearData();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 123
            invokestatic org.graalvm.compiler.debug.internal.DebugScope.getCurrentGlobalScopeId:()J
            putstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.lowestCompilationDebugScopeId:J
         1: .line 124
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void addToMetric(long, java.lang.String);
    descriptor: (JLjava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // long value
        start local 3 // java.lang.String metricName
         0: .line 128
            invokestatic org.graalvm.compiler.debug.Debug.isMethodMeterEnabled:()Z
            ifeq 1
            lload 1 /* value */
            lconst_0
            lcmp
            ifne 2
         1: .line 129
      StackMap locals:
      StackMap stack:
            return
         2: .line 131
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.$assertionsDisabled:Z
            ifne 3
            aload 3 /* metricName */
            ifnonnull 3
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 132
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.currentCompilation:Ljava/util/Map;
            aload 3 /* metricName */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            astore 4 /* valueStored */
        start local 4 // java.lang.Long valueStored
         4: .line 133
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.currentCompilation:Ljava/util/Map;
            aload 3 /* metricName */
            aload 4 /* valueStored */
            ifnonnull 5
            lload 1 /* value */
            goto 6
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl long java.lang.String java.lang.Long
      StackMap stack: java.util.Map java.lang.String
         5: lload 1 /* value */
            aload 4 /* valueStored */
            invokevirtual java.lang.Long.longValue:()J
            ladd
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl long java.lang.String java.lang.Long
      StackMap stack: java.util.Map java.lang.String long
         6: invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 134
            return
        end local 4 // java.lang.Long valueStored
        end local 3 // java.lang.String metricName
        end local 1 // long value
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    8     0         this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    8     1        value  J
            0    8     3   metricName  Ljava/lang/String;
            4    8     4  valueStored  Ljava/lang/Long;
    MethodParameters:
            Name  Flags
      value       
      metricName  

  public long getCurrentMetricValue(java.lang.String);
    descriptor: (Ljava/lang/String;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.lang.String metricName
         0: .line 138
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.$assertionsDisabled:Z
            ifne 1
            aload 1 /* metricName */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 139
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.currentCompilation:Ljava/util/Map;
            aload 1 /* metricName */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            astore 2 /* valueStored */
        start local 2 // java.lang.Long valueStored
         2: .line 140
            aload 2 /* valueStored */
            ifnonnull 3
            lconst_0
            goto 4
      StackMap locals: java.lang.Long
      StackMap stack:
         3: aload 2 /* valueStored */
            invokevirtual java.lang.Long.longValue:()J
      StackMap locals:
      StackMap stack: long
         4: lreturn
        end local 2 // java.lang.Long valueStored
        end local 1 // java.lang.String metricName
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    5     1   metricName  Ljava/lang/String;
            2    5     2  valueStored  Ljava/lang/Long;
    MethodParameters:
            Name  Flags
      metricName  

  public void addToMetric(long, java.lang.String, java.lang.Object);
    descriptor: (JLjava/lang/String;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=5, args_size=4
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // long value
        start local 3 // java.lang.String format
        start local 4 // java.lang.Object arg1
         0: .line 145
            aload 0 /* this */
            lload 1 /* value */
            aload 3 /* format */
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 4 /* arg1 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.addToMetric:(JLjava/lang/String;)V
         1: .line 146
            return
        end local 4 // java.lang.Object arg1
        end local 3 // java.lang.String format
        end local 1 // long value
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    2     1   value  J
            0    2     3  format  Ljava/lang/String;
            0    2     4    arg1  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      value   
      format  
      arg1    

  public void addToMetric(long, java.lang.String, java.lang.Object, java.lang.Object);
    descriptor: (JLjava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=6, args_size=5
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // long value
        start local 3 // java.lang.String format
        start local 4 // java.lang.Object arg1
        start local 5 // java.lang.Object arg2
         0: .line 150
            aload 0 /* this */
            lload 1 /* value */
            aload 3 /* format */
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 4 /* arg1 */
            aastore
            dup
            iconst_1
            aload 5 /* arg2 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.addToMetric:(JLjava/lang/String;)V
         1: .line 151
            return
        end local 5 // java.lang.Object arg2
        end local 4 // java.lang.Object arg1
        end local 3 // java.lang.String format
        end local 1 // long value
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    2     1   value  J
            0    2     3  format  Ljava/lang/String;
            0    2     4    arg1  Ljava/lang/Object;
            0    2     5    arg2  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      value   
      format  
      arg1    
      arg2    

  public void addToMetric(long, java.lang.String, java.lang.Object, java.lang.Object, java.lang.Object);
    descriptor: (JLjava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=7, args_size=6
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // long value
        start local 3 // java.lang.String format
        start local 4 // java.lang.Object arg1
        start local 5 // java.lang.Object arg2
        start local 6 // java.lang.Object arg3
         0: .line 155
            aload 0 /* this */
            lload 1 /* value */
            aload 3 /* format */
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 4 /* arg1 */
            aastore
            dup
            iconst_1
            aload 5 /* arg2 */
            aastore
            dup
            iconst_2
            aload 6 /* arg3 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.addToMetric:(JLjava/lang/String;)V
         1: .line 156
            return
        end local 6 // java.lang.Object arg3
        end local 5 // java.lang.Object arg2
        end local 4 // java.lang.Object arg1
        end local 3 // java.lang.String format
        end local 1 // long value
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    2     1   value  J
            0    2     3  format  Ljava/lang/String;
            0    2     4    arg1  Ljava/lang/Object;
            0    2     5    arg2  Ljava/lang/Object;
            0    2     6    arg3  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      value   
      format  
      arg1    
      arg2    
      arg3    

  public void incrementMetric(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.lang.String metricName
         0: .line 160
            aload 0 /* this */
            lconst_1
            aload 1 /* metricName */
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.addToMetric:(JLjava/lang/String;)V
         1: .line 161
            return
        end local 1 // java.lang.String metricName
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    2     1  metricName  Ljava/lang/String;
    MethodParameters:
            Name  Flags
      metricName  

  public void incrementMetric(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object arg1
         0: .line 165
            aload 0 /* this */
            aload 1 /* format */
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* arg1 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.incrementMetric:(Ljava/lang/String;)V
         1: .line 166
            return
        end local 2 // java.lang.Object arg1
        end local 1 // java.lang.String format
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    2     1  format  Ljava/lang/String;
            0    2     2    arg1  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  
      arg1    

  public void incrementMetric(java.lang.String, java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object arg1
        start local 3 // java.lang.Object arg2
         0: .line 170
            aload 0 /* this */
            aload 1 /* format */
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* arg1 */
            aastore
            dup
            iconst_1
            aload 3 /* arg2 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.incrementMetric:(Ljava/lang/String;)V
         1: .line 171
            return
        end local 3 // java.lang.Object arg2
        end local 2 // java.lang.Object arg1
        end local 1 // java.lang.String format
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    2     1  format  Ljava/lang/String;
            0    2     2    arg1  Ljava/lang/Object;
            0    2     3    arg2  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  
      arg1    
      arg2    

  public void incrementMetric(java.lang.String, java.lang.Object, java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=5
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object arg1
        start local 3 // java.lang.Object arg2
        start local 4 // java.lang.Object arg3
         0: .line 175
            aload 0 /* this */
            aload 1 /* format */
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* arg1 */
            aastore
            dup
            iconst_1
            aload 3 /* arg2 */
            aastore
            dup
            iconst_2
            aload 4 /* arg3 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.incrementMetric:(Ljava/lang/String;)V
         1: .line 176
            return
        end local 4 // java.lang.Object arg3
        end local 3 // java.lang.Object arg2
        end local 2 // java.lang.Object arg1
        end local 1 // java.lang.String format
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    2     1  format  Ljava/lang/String;
            0    2     2    arg1  Ljava/lang/Object;
            0    2     3    arg2  Ljava/lang/Object;
            0    2     4    arg3  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  
      arg1    
      arg2    
      arg3    

  public long getCurrentMetricValue(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object arg1
         0: .line 180
            aload 0 /* this */
            aload 1 /* format */
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* arg1 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.getCurrentMetricValue:(Ljava/lang/String;)J
            lreturn
        end local 2 // java.lang.Object arg1
        end local 1 // java.lang.String format
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    1     1  format  Ljava/lang/String;
            0    1     2    arg1  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  
      arg1    

  public long getCurrentMetricValue(java.lang.String, java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object arg1
        start local 3 // java.lang.Object arg2
         0: .line 185
            aload 0 /* this */
            aload 1 /* format */
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* arg1 */
            aastore
            dup
            iconst_1
            aload 3 /* arg2 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.getCurrentMetricValue:(Ljava/lang/String;)J
            lreturn
        end local 3 // java.lang.Object arg2
        end local 2 // java.lang.Object arg1
        end local 1 // java.lang.String format
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    1     1  format  Ljava/lang/String;
            0    1     2    arg1  Ljava/lang/Object;
            0    1     3    arg2  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  
      arg1    
      arg2    

  public long getCurrentMetricValue(java.lang.String, java.lang.Object, java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=5
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object arg1
        start local 3 // java.lang.Object arg2
        start local 4 // java.lang.Object arg3
         0: .line 190
            aload 0 /* this */
            aload 1 /* format */
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* arg1 */
            aastore
            dup
            iconst_1
            aload 3 /* arg2 */
            aastore
            dup
            iconst_2
            aload 4 /* arg3 */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.getCurrentMetricValue:(Ljava/lang/String;)J
            lreturn
        end local 4 // java.lang.Object arg3
        end local 3 // java.lang.Object arg2
        end local 2 // java.lang.Object arg1
        end local 1 // java.lang.String format
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0    1     1  format  Ljava/lang/String;
            0    1     2    arg1  Ljava/lang/Object;
            0    1     3    arg2  Ljava/lang/Object;
            0    1     4    arg3  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  
      arg1    
      arg2    
      arg3    

  public jdk.vm.ci.meta.ResolvedJavaMethod getMethod();
    descriptor: ()Ljdk/vm/ci/meta/ResolvedJavaMethod;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
         0: .line 195
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.method:Ljdk/vm/ci/meta/ResolvedJavaMethod;
            areturn
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;

  public static org.graalvm.compiler.debug.DebugMethodMetrics getMethodMetrics(jdk.vm.ci.meta.ResolvedJavaMethod);
    descriptor: (Ljdk/vm/ci/meta/ResolvedJavaMethod;)Lorg/graalvm/compiler/debug/DebugMethodMetrics;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=1
        start local 0 // jdk.vm.ci.meta.ResolvedJavaMethod method
         0: .line 199
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.$assertionsDisabled:Z
            ifne 1
            aload 0 /* method */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 200
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadEntries:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.util.Map
            astore 1 /* threadCache */
        start local 1 // java.util.Map threadCache
         2: .line 201
            aload 1 /* threadCache */
            ifnonnull 8
         3: .line 204
            new java.util.HashMap
            dup
            getstatic org.graalvm.compiler.debug.GraalDebugConfig$Options.MethodFilter:Lorg/graalvm/compiler/options/OptionValue;
            invokevirtual org.graalvm.compiler.options.OptionValue.getValue:()Ljava/lang/Object;
            ifnonnull 4
            sipush 128
            goto 5
      StackMap locals: jdk.vm.ci.meta.ResolvedJavaMethod java.util.Map
      StackMap stack: new 3 new 3
         4: bipush 16
      StackMap locals: jdk.vm.ci.meta.ResolvedJavaMethod java.util.Map
      StackMap stack: new 3 new 3 int
         5: invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* threadCache */
         6: .line 205
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadEntries:Ljava/lang/ThreadLocal;
            aload 1 /* threadCache */
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
         7: .line 206
            aload 1 /* threadCache */
            invokestatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.addThreadCompilationData:(Ljava/util/Map;)V
         8: .line 209
      StackMap locals:
      StackMap stack:
            aload 1 /* threadCache */
            aload 0 /* method */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData
            astore 2 /* recorded */
        start local 2 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData recorded
         9: .line 210
            aload 2 /* recorded */
            ifnonnull 12
        10: .line 211
            new org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData
            dup
            aload 0 /* method */
            invokespecial org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData.<init>:(Ljdk/vm/ci/meta/ResolvedJavaMethod;)V
            astore 2 /* recorded */
        11: .line 212
            aload 1 /* threadCache */
            aload 0 /* method */
            aload 2 /* recorded */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        12: .line 216
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData
      StackMap stack:
            invokestatic org.graalvm.compiler.debug.internal.DebugScope.getInstance:()Lorg/graalvm/compiler/debug/internal/DebugScope;
            invokevirtual org.graalvm.compiler.debug.internal.DebugScope.scopeId:()J
            lstore 3 /* compilationId */
        start local 3 // long compilationId
        13: .line 217
            aload 2 /* recorded */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData.compilations:Ljava/util/Map;
            lload 3 /* compilationId */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.Map
            astore 5 /* currentCompilation */
        start local 5 // java.util.Map currentCompilation
        14: .line 218
            aload 5 /* currentCompilation */
            ifnonnull 18
        15: .line 220
            new java.util.HashMap
            dup
            bipush 32
            invokespecial java.util.HashMap.<init>:(I)V
            astore 5 /* currentCompilation */
        16: .line 221
            aload 2 /* recorded */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData.compilations:Ljava/util/Map;
            lload 3 /* compilationId */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aload 5 /* currentCompilation */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        17: .line 223
            aload 2 /* recorded */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData.metrics:Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            aload 5 /* currentCompilation */
            putfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.currentCompilation:Ljava/util/Map;
        18: .line 226
      StackMap locals: long java.util.Map
      StackMap stack:
            aload 2 /* recorded */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData.metrics:Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            areturn
        end local 5 // java.util.Map currentCompilation
        end local 3 // long compilationId
        end local 2 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData recorded
        end local 1 // java.util.Map threadCache
        end local 0 // jdk.vm.ci.meta.ResolvedJavaMethod method
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   19     0              method  Ljdk/vm/ci/meta/ResolvedJavaMethod;
            2   19     1         threadCache  Ljava/util/Map<Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;>;
            9   19     2            recorded  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;
           13   19     3       compilationId  J
           14   19     5  currentCompilation  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
    MethodParameters:
        Name  Flags
      method  

  public void dumpASCII(java.io.PrintStream);
    descriptor: (Ljava/io/PrintStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=16, args_size=2
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.io.PrintStream p
         0: .line 232
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadMaps:Ljava/util/List;
            dup
            astore 2
            monitorenter
         1: .line 233
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.method:Ljdk/vm/ci/meta/ResolvedJavaMethod;
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            astore 3 /* methodName */
        start local 3 // java.lang.String methodName
         2: .line 234
            aload 3 /* methodName */
            invokevirtual java.lang.String.length:()I
            istore 4 /* maxLen */
        start local 4 // int maxLen
         3: .line 235
            iconst_0
            istore 5 /* entrySum */
        start local 5 // int entrySum
         4: .line 237
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.collected:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 16
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int top java.util.Iterator
      StackMap stack:
         5: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map
            astore 6 /* compilationThreadTable */
        start local 6 // java.util.Map compilationThreadTable
         6: .line 238
            aload 6 /* compilationThreadTable */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 9
            goto 15
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator top java.util.Iterator
      StackMap stack:
         7: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 8 /* compilationEntry */
        start local 8 // java.util.Map$Entry compilationEntry
         8: .line 239
            aload 8 /* compilationEntry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.util.Map
            astore 10 /* table */
        start local 10 // java.util.Map table
         9: .line 240
            aload 10 /* table */
            ifnull 15
        10: .line 241
            aload 10 /* table */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 12
            goto 14
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator java.util.Map$Entry java.util.Iterator java.util.Map top java.util.Iterator
      StackMap stack:
        11: aload 12
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 11 /* entry */
        start local 11 // java.util.Map$Entry entry
        12: .line 242
            iload 4 /* maxLen */
            aload 11 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.String.length:()I
            invokestatic java.lang.Math.max:(II)I
            istore 4 /* maxLen */
        13: .line 243
            iload 5 /* entrySum */
            i2l
            aload 11 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            ladd
            l2i
            istore 5 /* entrySum */
        end local 11 // java.util.Map$Entry entry
        14: .line 241
      StackMap locals:
      StackMap stack:
            aload 12
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        end local 10 // java.util.Map table
        end local 8 // java.util.Map$Entry compilationEntry
        15: .line 238
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator top java.util.Iterator
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        end local 6 // java.util.Map compilationThreadTable
        16: .line 237
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        17: .line 248
            iload 5 /* entrySum */
            ifne 20
        18: .line 250
            aload 2
            monitorexit
        19: return
        20: .line 252
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int
      StackMap stack:
            iinc 4 /* maxLen */ 23
        21: .line 253
            iconst_0
            istore 6 /* j */
        start local 6 // int j
        22: goto 25
        23: .line 254
      StackMap locals: int
      StackMap stack:
            aload 1 /* p */
            ldc "#"
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        24: .line 253
            iinc 6 /* j */ 1
      StackMap locals:
      StackMap stack:
        25: iload 6 /* j */
            iload 4 /* maxLen */
            if_icmplt 23
        end local 6 // int j
        26: .line 256
            aload 1 /* p */
            invokevirtual java.io.PrintStream.println:()V
        27: .line 257
            aload 1 /* p */
            aload 3 /* methodName */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        28: .line 258
            iconst_0
            istore 6 /* j */
        start local 6 // int j
        29: goto 32
        30: .line 259
      StackMap locals:
      StackMap stack:
            aload 1 /* p */
            ldc "~"
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        31: .line 258
            iinc 6 /* j */ 1
      StackMap locals:
      StackMap stack:
        32: iload 6 /* j */
            iload 4 /* maxLen */
            if_icmplt 30
        end local 6 // int j
        33: .line 261
            aload 1 /* p */
            invokevirtual java.io.PrintStream.println:()V
        34: .line 262
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.collected:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 61
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int top java.util.Iterator
      StackMap stack:
        35: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map
            astore 6 /* compilationThreadTable */
        start local 6 // java.util.Map compilationThreadTable
        36: .line 263
            aload 6 /* compilationThreadTable */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 9
            goto 60
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator top java.util.Iterator
      StackMap stack:
        37: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 8 /* compilationEntry */
        start local 8 // java.util.Map$Entry compilationEntry
        38: .line 264
            aload 8 /* compilationEntry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.util.Map
            astore 10 /* table */
        start local 10 // java.util.Map table
        39: .line 265
            aload 10 /* table */
            ifnull 60
        40: .line 266
            aload 10 /* table */
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.stream:()Ljava/util/stream/Stream;
            invokedynamic test()Ljava/util/function/Predicate;
              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;)Z
                  org/graalvm/compiler/debug/internal/method/MethodMetricsImpl.lambda$0(Ljava/lang/Long;)Z (6)
                  (Ljava/lang/Long;)Z
            invokeinterface java.util.stream.Stream.filter:(Ljava/util/function/Predicate;)Ljava/util/stream/Stream;
            invokeinterface java.util.stream.Stream.count:()J
            lconst_0
            lcmp
            ifne 42
        41: .line 267
            goto 60
        42: .line 269
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator java.util.Map$Entry java.util.Iterator java.util.Map
      StackMap stack:
            aload 10 /* table */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            astore 11 /* entries */
        start local 11 // java.util.Set entries
        43: .line 270
            aload 11 /* entries */
            invokeinterface java.util.Set.stream:()Ljava/util/stream/Stream;
            invokedynamic compare()Ljava/util/Comparator;
              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;Ljava/lang/Object;)I
                  org/graalvm/compiler/debug/internal/method/MethodMetricsImpl.lambda$1(Ljava/util/Map$Entry;Ljava/util/Map$Entry;)I (6)
                  (Ljava/util/Map$Entry;Ljava/util/Map$Entry;)I
            invokeinterface java.util.stream.Stream.sorted:(Ljava/util/Comparator;)Ljava/util/stream/Stream;
            invokestatic java.util.stream.Collectors.toList:()Ljava/util/stream/Collector;
            invokeinterface java.util.stream.Stream.collect:(Ljava/util/stream/Collector;)Ljava/lang/Object;
            checkcast java.util.List
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 13
            goto 53
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator java.util.Map$Entry java.util.Iterator java.util.Map java.util.Set top java.util.Iterator
      StackMap stack:
        44: aload 13
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 12 /* entry */
        start local 12 // java.util.Map$Entry entry
        45: .line 271
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lstore 14 /* value */
        start local 14 // long value
        46: .line 273
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            ldc "Accm"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifne 47
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            ldc "Flat"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 49
        47: .line 274
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator java.util.Map$Entry java.util.Iterator java.util.Map java.util.Set java.util.Map$Entry java.util.Iterator long
      StackMap stack:
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            ldc "mem"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifne 49
        48: .line 275
            lload 14 /* value */
            ldc 1000000
            ldiv
            lstore 14 /* value */
        49: .line 277
      StackMap locals:
      StackMap stack:
            lload 14 /* value */
            lconst_0
            lcmp
            ifne 51
        50: .line 278
            goto 53
        51: .line 280
      StackMap locals:
      StackMap stack:
            aload 1 /* p */
            new java.lang.StringBuilder
            dup
            ldc "%-"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 4 /* maxLen */
            bipush 23
            isub
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "s = %20d"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            aastore
            dup
            iconst_1
            lload 14 /* value */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        52: .line 281
            aload 1 /* p */
            invokevirtual java.io.PrintStream.println:()V
        end local 14 // long value
        end local 12 // java.util.Map$Entry entry
        53: .line 270
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator java.util.Map$Entry java.util.Iterator java.util.Map java.util.Set top java.util.Iterator
      StackMap stack:
            aload 13
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 44
        54: .line 283
            iconst_0
            istore 12 /* j */
        start local 12 // int j
        55: goto 58
        56: .line 284
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator java.util.Map$Entry java.util.Iterator java.util.Map java.util.Set int
      StackMap stack:
            aload 1 /* p */
            ldc "~"
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        57: .line 283
            iinc 12 /* j */ 1
      StackMap locals:
      StackMap stack:
        58: iload 12 /* j */
            iload 4 /* maxLen */
            if_icmplt 56
        end local 12 // int j
        59: .line 286
            aload 1 /* p */
            invokevirtual java.io.PrintStream.println:()V
        end local 11 // java.util.Set entries
        end local 10 // java.util.Map table
        end local 8 // java.util.Map$Entry compilationEntry
        60: .line 263
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int java.util.Map java.util.Iterator top java.util.Iterator
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 37
        end local 6 // java.util.Map compilationThreadTable
        61: .line 262
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 35
        62: .line 290
            iconst_0
            istore 6 /* j */
        start local 6 // int j
        63: goto 66
        64: .line 291
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String int int int
      StackMap stack:
            aload 1 /* p */
            ldc "#"
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        65: .line 290
            iinc 6 /* j */ 1
      StackMap locals:
      StackMap stack:
        66: iload 6 /* j */
            iload 4 /* maxLen */
            if_icmplt 64
        end local 6 // int j
        67: .line 293
            aload 1 /* p */
            invokevirtual java.io.PrintStream.println:()V
        end local 5 // int entrySum
        end local 4 // int maxLen
        end local 3 // java.lang.String methodName
        68: .line 232
            aload 2
            monitorexit
        69: goto 72
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List
      StackMap stack: java.lang.Throwable
        70: aload 2
            monitorexit
        71: athrow
        72: .line 295
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.io.PrintStream p
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0   73     0                    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0   73     1                       p  Ljava/io/PrintStream;
            2   68     3              methodName  Ljava/lang/String;
            3   68     4                  maxLen  I
            4   68     5                entrySum  I
            6   16     6  compilationThreadTable  Ljava/util/Map<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;
            8   15     8        compilationEntry  Ljava/util/Map$Entry<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;
            9   15    10                   table  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
           12   14    11                   entry  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;
           22   26     6                       j  I
           29   33     6                       j  I
           36   61     6  compilationThreadTable  Ljava/util/Map<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;
           38   60     8        compilationEntry  Ljava/util/Map$Entry<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;
           39   60    10                   table  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
           43   60    11                 entries  Ljava/util/Set<Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;>;
           45   53    12                   entry  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;
           46   53    14                   value  J
           55   59    12                       j  I
           63   67     6                       j  I
      Exception table:
        from    to  target  type
           1    19      70  any
          20    69      70  any
          70    71      70  any
    MethodParameters:
      Name  Flags
      p     

  public void dumpCSV(java.io.PrintStream);
    descriptor: (Ljava/io/PrintStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=14, args_size=2
        start local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
        start local 1 // java.io.PrintStream p
         0: .line 302
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadMaps:Ljava/util/List;
            dup
            astore 2
            monitorenter
         1: .line 303
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.method:Ljdk/vm/ci/meta/ResolvedJavaMethod;
            ldc "%H.%n(%p)%R"
            invokeinterface jdk.vm.ci.meta.ResolvedJavaMethod.format:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* methodName */
        start local 3 // java.lang.String methodName
         2: .line 312
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.method:Ljdk/vm/ci/meta/ResolvedJavaMethod;
            invokestatic java.lang.System.identityHashCode:(Ljava/lang/Object;)I
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            astore 4 /* methodIdentity */
        start local 4 // java.lang.String methodIdentity
         3: .line 313
            iconst_0
            istore 5 /* nrOfCompilations */
        start local 5 // int nrOfCompilations
         4: .line 314
            aload 0 /* this */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.collected:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 17
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String java.lang.String int top java.util.Iterator
      StackMap stack:
         5: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map
            astore 6 /* compilationThreadTable */
        start local 6 // java.util.Map compilationThreadTable
         6: .line 315
            aload 6 /* compilationThreadTable */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 9
            goto 16
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String java.lang.String int java.util.Map java.util.Iterator top java.util.Iterator
      StackMap stack:
         7: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 8 /* compilationEntry */
        start local 8 // java.util.Map$Entry compilationEntry
         8: .line 316
            aload 8 /* compilationEntry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.util.Map
            astore 10 /* table */
        start local 10 // java.util.Map table
         9: .line 317
            aload 10 /* table */
            ifnull 16
        10: .line 318
            aload 10 /* table */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            astore 11 /* entries */
        start local 11 // java.util.Set entries
        11: .line 319
            aload 11 /* entries */
            invokeinterface java.util.Set.stream:()Ljava/util/stream/Stream;
            invokedynamic compare()Ljava/util/Comparator;
              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;Ljava/lang/Object;)I
                  org/graalvm/compiler/debug/internal/method/MethodMetricsImpl.lambda$2(Ljava/util/Map$Entry;Ljava/util/Map$Entry;)I (6)
                  (Ljava/util/Map$Entry;Ljava/util/Map$Entry;)I
            invokeinterface java.util.stream.Stream.sorted:(Ljava/util/Comparator;)Ljava/util/stream/Stream;
            invokestatic java.util.stream.Collectors.toList:()Ljava/util/stream/Collector;
            invokeinterface java.util.stream.Stream.collect:(Ljava/util/stream/Collector;)Ljava/lang/Object;
            checkcast java.util.List
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 13
            goto 14
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String java.lang.String int java.util.Map java.util.Iterator java.util.Map$Entry java.util.Iterator java.util.Map java.util.Set top java.util.Iterator
      StackMap stack:
        12: aload 13
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 12 /* entry */
        start local 12 // java.util.Map$Entry entry
        13: .line 320
            aload 1 /* p */
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.FMT:Ljava/lang/String;
            bipush 6
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* methodName */
            aastore
            dup
            iconst_1
            aload 4 /* methodIdentity */
            aastore
            dup
            iconst_2
            iload 5 /* nrOfCompilations */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_3
            aload 8 /* compilationEntry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            aastore
            dup
            iconst_4
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            aastore
            dup
            iconst_5
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()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 12 // java.util.Map$Entry entry
        14: .line 319
      StackMap locals:
      StackMap stack:
            aload 13
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        15: .line 322
            iinc 5 /* nrOfCompilations */ 1
        end local 11 // java.util.Set entries
        end local 10 // java.util.Map table
        end local 8 // java.util.Map$Entry compilationEntry
        16: .line 315
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String java.lang.String int java.util.Map java.util.Iterator top java.util.Iterator
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        end local 6 // java.util.Map compilationThreadTable
        17: .line 314
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List java.lang.String java.lang.String int top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        end local 5 // int nrOfCompilations
        end local 4 // java.lang.String methodIdentity
        end local 3 // java.lang.String methodName
        18: .line 302
            aload 2
            monitorexit
        19: goto 22
      StackMap locals: org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.io.PrintStream java.util.List
      StackMap stack: java.lang.Throwable
        20: aload 2
            monitorexit
        21: athrow
        22: .line 327
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.io.PrintStream p
        end local 0 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl this
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0   23     0                    this  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
            0   23     1                       p  Ljava/io/PrintStream;
            2   18     3              methodName  Ljava/lang/String;
            3   18     4          methodIdentity  Ljava/lang/String;
            4   18     5        nrOfCompilations  I
            6   17     6  compilationThreadTable  Ljava/util/Map<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;
            8   16     8        compilationEntry  Ljava/util/Map$Entry<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;
            9   16    10                   table  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
           11   16    11                 entries  Ljava/util/Set<Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;>;
           13   14    12                   entry  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;
      Exception table:
        from    to  target  type
           1    19      20  any
          20    21      20  any
    MethodParameters:
      Name  Flags
      p     

  public static java.util.Collection<org.graalvm.compiler.debug.DebugMethodMetrics> collectedMetrics();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=14, args_size=0
         0: .line 330
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadMaps:Ljava/util/List;
            dup
            astore 0
            monitorenter
         1: .line 332
            invokestatic org.graalvm.compiler.debug.internal.DebugScope.getCurrentGlobalScopeId:()J
            lstore 1 /* lastId */
        start local 1 // long lastId
         2: .line 333
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 3 /* finalMetrics */
        start local 3 // java.util.List finalMetrics
         3: .line 334
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 4 /* methods */
        start local 4 // java.util.Set methods
         4: .line 337
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadMaps:Ljava/util/List;
            invokeinterface java.util.List.stream:()Ljava/util/stream/Stream;
            aload 4 /* methods */
            invokedynamic accept(Ljava/util/Set;)Ljava/util/function/Consumer;
              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
                  org/graalvm/compiler/debug/internal/method/MethodMetricsImpl.lambda$3(Ljava/util/Set;Ljava/util/Map;)V (6)
                  (Ljava/util/Map;)V
            invokeinterface java.util.stream.Stream.forEach:(Ljava/util/function/Consumer;)V
         5: .line 344
            aload 4 /* methods */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 6
            goto 22
      StackMap locals: java.util.List long java.util.List java.util.Set top java.util.Iterator
      StackMap stack:
         6: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast jdk.vm.ci.meta.ResolvedJavaMethod
            astore 5 /* method */
        start local 5 // jdk.vm.ci.meta.ResolvedJavaMethod method
         7: .line 345
            new org.graalvm.compiler.debug.internal.method.MethodMetricsImpl
            dup
            aload 5 /* method */
            invokespecial org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.<init>:(Ljdk/vm/ci/meta/ResolvedJavaMethod;)V
            astore 7 /* impl */
        start local 7 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl impl
         8: .line 346
            aload 7 /* impl */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.collected:Ljava/util/List;
         9: .line 347
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.threadMaps:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 9
            goto 20
      StackMap locals: java.util.List long java.util.List java.util.Set jdk.vm.ci.meta.ResolvedJavaMethod java.util.Iterator org.graalvm.compiler.debug.internal.method.MethodMetricsImpl top java.util.Iterator
      StackMap stack:
        10: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map
            astore 8 /* threadMap */
        start local 8 // java.util.Map threadMap
        11: .line 348
            aload 8 /* threadMap */
            aload 5 /* method */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData
            astore 10 /* threadMethodData */
        start local 10 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData threadMethodData
        12: .line 351
            aload 10 /* threadMethodData */
            ifnull 20
        13: .line 352
            new java.util.HashMap
            dup
            aload 10 /* threadMethodData */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData.compilations:Ljava/util/Map;
            invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
            astore 11 /* snapshot */
        start local 11 // java.util.Map snapshot
        14: .line 353
            aload 11 /* snapshot */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 13
            goto 18
      StackMap locals: java.util.List long java.util.List java.util.Set jdk.vm.ci.meta.ResolvedJavaMethod java.util.Iterator org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.util.Map java.util.Iterator org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData java.util.Map top java.util.Iterator
      StackMap stack:
        15: aload 13
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 12 /* entry */
        start local 12 // java.util.Map$Entry entry
        16: .line 354
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.lowestCompilationDebugScopeId:J
            lcmp
            iflt 17
            aload 12 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lload 1 /* lastId */
            lcmp
            ifle 18
        17: .line 355
      StackMap locals: java.util.List long java.util.List java.util.Set jdk.vm.ci.meta.ResolvedJavaMethod java.util.Iterator org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.util.Map java.util.Iterator org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData java.util.Map java.util.Map$Entry java.util.Iterator
      StackMap stack:
            aload 12 /* entry */
            aconst_null
            invokeinterface java.util.Map$Entry.setValue:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 12 // java.util.Map$Entry entry
        18: .line 353
      StackMap locals: java.util.List long java.util.List java.util.Set jdk.vm.ci.meta.ResolvedJavaMethod java.util.Iterator org.graalvm.compiler.debug.internal.method.MethodMetricsImpl java.util.Map java.util.Iterator org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData java.util.Map top java.util.Iterator
      StackMap stack:
            aload 13
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 15
        19: .line 358
            aload 7 /* impl */
            getfield org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.collected:Ljava/util/List;
            aload 11 /* snapshot */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 11 // java.util.Map snapshot
        end local 10 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData threadMethodData
        end local 8 // java.util.Map threadMap
        20: .line 347
      StackMap locals: java.util.List long java.util.List java.util.Set jdk.vm.ci.meta.ResolvedJavaMethod java.util.Iterator org.graalvm.compiler.debug.internal.method.MethodMetricsImpl top java.util.Iterator
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        21: .line 361
            aload 3 /* finalMetrics */
            aload 7 /* impl */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl impl
        end local 5 // jdk.vm.ci.meta.ResolvedJavaMethod method
        22: .line 344
      StackMap locals: java.util.List long java.util.List java.util.Set top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        23: .line 364
            aload 3 /* finalMetrics */
            aload 0
            monitorexit
        24: areturn
        end local 4 // java.util.Set methods
        end local 3 // java.util.List finalMetrics
        end local 1 // long lastId
        25: .line 330
      StackMap locals: java.util.List
      StackMap stack: java.lang.Throwable
            aload 0
            monitorexit
        26: athrow
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            2   25     1            lastId  J
            3   25     3      finalMetrics  Ljava/util/List<Lorg/graalvm/compiler/debug/DebugMethodMetrics;>;
            4   25     4           methods  Ljava/util/Set<Ljdk/vm/ci/meta/ResolvedJavaMethod;>;
            7   22     5            method  Ljdk/vm/ci/meta/ResolvedJavaMethod;
            8   22     7              impl  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
           11   20     8         threadMap  Ljava/util/Map<Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;>;
           12   20    10  threadMethodData  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;
           14   20    11          snapshot  Ljava/util/Map<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;
           16   18    12             entry  Ljava/util/Map$Entry<Ljava/lang/Long;Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;>;
      Exception table:
        from    to  target  type
           1    24      25  any
          25    26      25  any
    Signature: ()Ljava/util/Collection<Lorg/graalvm/compiler/debug/DebugMethodMetrics;>;

  public static void clearMM();
    descriptor: ()V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=0, locals=0, args_size=0
         0: .line 369
            invokestatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.clearData:()V
         1: .line 370
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static void recordInlinee(jdk.vm.ci.meta.ResolvedJavaMethod, jdk.vm.ci.meta.ResolvedJavaMethod, jdk.vm.ci.meta.ResolvedJavaMethod);
    descriptor: (Ljdk/vm/ci/meta/ResolvedJavaMethod;Ljdk/vm/ci/meta/ResolvedJavaMethod;Ljdk/vm/ci/meta/ResolvedJavaMethod;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=0, locals=3, args_size=3
        start local 0 // jdk.vm.ci.meta.ResolvedJavaMethod root
        start local 1 // jdk.vm.ci.meta.ResolvedJavaMethod caller
        start local 2 // jdk.vm.ci.meta.ResolvedJavaMethod inlinee
         0: .line 379
            return
        end local 2 // jdk.vm.ci.meta.ResolvedJavaMethod inlinee
        end local 1 // jdk.vm.ci.meta.ResolvedJavaMethod caller
        end local 0 // jdk.vm.ci.meta.ResolvedJavaMethod root
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     root  Ljdk/vm/ci/meta/ResolvedJavaMethod;
            0    1     1   caller  Ljdk/vm/ci/meta/ResolvedJavaMethod;
            0    1     2  inlinee  Ljdk/vm/ci/meta/ResolvedJavaMethod;
    MethodParameters:
         Name  Flags
      root     
      caller   
      inlinee  

  public static void addToCurrentScopeMethodMetrics(java.lang.String, long);
    descriptor: (Ljava/lang/String;J)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=10, args_size=2
        start local 0 // java.lang.String metricName
        start local 1 // long value
         0: .line 402
            invokestatic org.graalvm.compiler.debug.internal.DebugScope.getInstance:()Lorg/graalvm/compiler/debug/internal/DebugScope;
            astore 3 /* currScope */
        start local 3 // org.graalvm.compiler.debug.internal.DebugScope currScope
         1: .line 403
            aload 3 /* currScope */
            invokevirtual org.graalvm.compiler.debug.internal.DebugScope.getExtraInfo:()Lorg/graalvm/compiler/debug/internal/DebugScope$ExtraInfo;
            astore 4 /* metaInfo */
        start local 4 // org.graalvm.compiler.debug.internal.DebugScope$ExtraInfo metaInfo
         2: .line 404
            aload 3 /* currScope */
            invokevirtual org.graalvm.compiler.debug.internal.DebugScope.scopeId:()J
            lstore 5 /* currScopeId */
        start local 5 // long currScopeId
         3: .line 405
            aload 4 /* metaInfo */
            instanceof org.graalvm.compiler.debug.internal.method.MethodMetricsRootScopeInfo
            ifeq 15
         4: .line 406
            aload 4 /* metaInfo */
            checkcast org.graalvm.compiler.debug.internal.method.MethodMetricsRootScopeInfo
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsRootScopeInfo.getRootMethod:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            astore 7 /* rootMethod */
        start local 7 // jdk.vm.ci.meta.ResolvedJavaMethod rootMethod
         5: .line 407
            aload 4 /* metaInfo */
            instanceof org.graalvm.compiler.debug.internal.method.MethodMetricsInlineeScopeInfo
            ifeq 7
         6: .line 421
            goto 15
         7: .line 423
      StackMap locals: java.lang.String long org.graalvm.compiler.debug.internal.DebugScope org.graalvm.compiler.debug.internal.DebugScope$ExtraInfo long jdk.vm.ci.meta.ResolvedJavaMethod
      StackMap stack:
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.interceptionCache:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.lang.Long
            astore 8 /* cachedId */
        start local 8 // java.lang.Long cachedId
         8: .line 424
            aload 8 /* cachedId */
            ifnull 11
            aload 8 /* cachedId */
            invokevirtual java.lang.Long.longValue:()J
            lload 5 /* currScopeId */
            lcmp
            ifne 11
         9: .line 425
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.interceptionMetrics:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.debug.internal.method.MethodMetricsImpl
            lload 1 /* value */
            aload 0 /* metricName */
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.addToMetric:(JLjava/lang/String;)V
        10: .line 429
            goto 15
        11: .line 431
      StackMap locals: java.lang.Long
      StackMap stack:
            aload 7 /* rootMethod */
            invokestatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.getMethodMetrics:(Ljdk/vm/ci/meta/ResolvedJavaMethod;)Lorg/graalvm/compiler/debug/DebugMethodMetrics;
            checkcast org.graalvm.compiler.debug.internal.method.MethodMetricsImpl
            astore 9 /* impl */
        start local 9 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl impl
        12: .line 432
            aload 9 /* impl */
            lload 1 /* value */
            aload 0 /* metricName */
            invokevirtual org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.addToMetric:(JLjava/lang/String;)V
        13: .line 434
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.interceptionCache:Ljava/lang/ThreadLocal;
            lload 5 /* currScopeId */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        14: .line 435
            getstatic org.graalvm.compiler.debug.internal.method.MethodMetricsImpl.interceptionMetrics:Ljava/lang/ThreadLocal;
            aload 9 /* impl */
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        end local 9 // org.graalvm.compiler.debug.internal.method.MethodMetricsImpl impl
        end local 8 // java.lang.Long cachedId
        end local 7 // jdk.vm.ci.meta.ResolvedJavaMethod rootMethod
        15: .line 442
      StackMap locals:
      StackMap stack:
            return
        end local 5 // long currScopeId
        end local 4 // org.graalvm.compiler.debug.internal.DebugScope$ExtraInfo metaInfo
        end local 3 // org.graalvm.compiler.debug.internal.DebugScope currScope
        end local 1 // long value
        end local 0 // java.lang.String metricName
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   16     0   metricName  Ljava/lang/String;
            0   16     1        value  J
            1   16     3    currScope  Lorg/graalvm/compiler/debug/internal/DebugScope;
            2   16     4     metaInfo  Lorg/graalvm/compiler/debug/internal/DebugScope$ExtraInfo;
            3   16     5  currScopeId  J
            5   15     7   rootMethod  Ljdk/vm/ci/meta/ResolvedJavaMethod;
            8   15     8     cachedId  Ljava/lang/Long;
           12   15     9         impl  Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl;
    MethodParameters:
            Name  Flags
      metricName  
      value       

  private static boolean lambda$0(java.lang.Long);
    descriptor: (Ljava/lang/Long;)Z
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // java.lang.Long x
         0: .line 266
            aload 0 /* x */
            invokevirtual java.lang.Long.longValue:()J
            lconst_0
            lcmp
            ifle 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 0 // java.lang.Long x
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0     x  Ljava/lang/Long;

  private static int lambda$1(java.util.Map$Entry, java.util.Map$Entry);
    descriptor: (Ljava/util/Map$Entry;Ljava/util/Map$Entry;)I
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.Map$Entry x
        start local 1 // java.util.Map$Entry y
         0: .line 270
            aload 0 /* x */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            aload 1 /* y */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.String.compareTo:(Ljava/lang/String;)I
            ireturn
        end local 1 // java.util.Map$Entry y
        end local 0 // java.util.Map$Entry x
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0     x  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;
            0    1     1     y  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;

  private static int lambda$2(java.util.Map$Entry, java.util.Map$Entry);
    descriptor: (Ljava/util/Map$Entry;Ljava/util/Map$Entry;)I
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.Map$Entry x
        start local 1 // java.util.Map$Entry y
         0: .line 319
            aload 0 /* x */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            aload 1 /* y */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.String.compareTo:(Ljava/lang/String;)I
            ireturn
        end local 1 // java.util.Map$Entry y
        end local 0 // java.util.Map$Entry x
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0     x  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;
            0    1     1     y  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;

  private static void lambda$3(java.util.Set, java.util.Map);
    descriptor: (Ljava/util/Set;Ljava/util/Map;)V
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=2
        start local 1 // java.util.Map x
         0: .line 339
            new java.util.HashMap
            dup
            aload 1 /* x */
            invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
            astore 2 /* snapShot */
        start local 2 // java.util.HashMap snapShot
         1: .line 340
            aload 2 /* snapShot */
            invokevirtual java.util.HashMap.keySet:()Ljava/util/Set;
            aload 0
            invokedynamic accept(Ljava/util/Set;)Ljava/util/function/Consumer;
              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
                  org/graalvm/compiler/debug/internal/method/MethodMetricsImpl.lambda$4(Ljava/util/Set;Ljdk/vm/ci/meta/ResolvedJavaMethod;)V (6)
                  (Ljdk/vm/ci/meta/ResolvedJavaMethod;)V
            invokeinterface java.util.Set.forEach:(Ljava/util/function/Consumer;)V
        end local 2 // java.util.HashMap snapShot
         2: .line 341
            return
        end local 1 // java.util.Map x
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     1         x  Ljava/util/Map<Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;>;
            1    2     2  snapShot  Ljava/util/HashMap<Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/debug/internal/method/MethodMetricsImpl$CompilationData;>;

  private static void lambda$4(java.util.Set, jdk.vm.ci.meta.ResolvedJavaMethod);
    descriptor: (Ljava/util/Set;Ljdk/vm/ci/meta/ResolvedJavaMethod;)V
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 1 // jdk.vm.ci.meta.ResolvedJavaMethod y
         0: .line 340
            aload 0
            aload 1 /* y */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            return
        end local 1 // jdk.vm.ci.meta.ResolvedJavaMethod y
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     1     y  Ljdk/vm/ci/meta/ResolvedJavaMethod;
}
SourceFile: "MethodMetricsImpl.java"
NestMembers:
  org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  public abstract Entry = java.util.Map$Entry of java.util.Map
  public final Escape = org.graalvm.compiler.debug.CSVUtil$Escape of org.graalvm.compiler.debug.CSVUtil
  public Options = org.graalvm.compiler.debug.GraalDebugConfig$Options of org.graalvm.compiler.debug.GraalDebugConfig
  public abstract ExtraInfo = org.graalvm.compiler.debug.internal.DebugScope$ExtraInfo of org.graalvm.compiler.debug.internal.DebugScope
  public CompilationData = org.graalvm.compiler.debug.internal.method.MethodMetricsImpl$CompilationData of org.graalvm.compiler.debug.internal.method.MethodMetricsImpl