public final class org.graalvm.compiler.core.common.alloc.TraceStatisticsPrinter
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.graalvm.compiler.core.common.alloc.TraceStatisticsPrinter
  super_class: java.lang.Object
{
  private static final java.lang.String SEP;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: ";"

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

  public static void printTraceStatistics(org.graalvm.compiler.debug.DebugContext, org.graalvm.compiler.core.common.alloc.TraceBuilderResult, java.lang.String);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;Lorg/graalvm/compiler/core/common/alloc/TraceBuilderResult;Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=3
        start local 0 // org.graalvm.compiler.debug.DebugContext debug
        start local 1 // org.graalvm.compiler.core.common.alloc.TraceBuilderResult result
        start local 2 // java.lang.String compilationUnitName
         0: .line 38
            aconst_null
            astore 3
            aconst_null
            astore 4
         1: aload 0 /* debug */
            ldc "DumpTraceStatistics"
            invokevirtual org.graalvm.compiler.debug.DebugContext.scope:(Ljava/lang/Object;)Lorg/graalvm/compiler/debug/DebugContext$Scope;
            astore 5 /* s */
        start local 5 // org.graalvm.compiler.debug.DebugContext$Scope s
         2: .line 39
            aload 0 /* debug */
            iconst_3
            invokevirtual org.graalvm.compiler.debug.DebugContext.isLogEnabled:(I)Z
            ifeq 4
         3: .line 40
            aload 0 /* debug */
            aload 1 /* result */
            aload 2 /* compilationUnitName */
            invokestatic org.graalvm.compiler.core.common.alloc.TraceStatisticsPrinter.print:(Lorg/graalvm/compiler/debug/DebugContext;Lorg/graalvm/compiler/core/common/alloc/TraceBuilderResult;Ljava/lang/String;)V
         4: .line 42
      StackMap locals: java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugContext$Scope
      StackMap stack:
            aload 5 /* s */
            ifnull 12
            aload 5 /* s */
            invokeinterface org.graalvm.compiler.debug.DebugContext$Scope.close:()V
            goto 12
      StackMap locals:
      StackMap stack: java.lang.Throwable
         5: astore 3
            aload 5 /* s */
            ifnull 6
            aload 5 /* s */
            invokeinterface org.graalvm.compiler.debug.DebugContext$Scope.close:()V
        end local 5 // org.graalvm.compiler.debug.DebugContext$Scope s
      StackMap locals:
      StackMap stack:
         6: aload 3
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
         7: astore 4
            aload 3
            ifnonnull 8
            aload 4
            astore 3
            goto 9
      StackMap locals:
      StackMap stack:
         8: aload 3
            aload 4
            if_acmpeq 9
            aload 3
            aload 4
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
         9: aload 3
            athrow
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String
      StackMap stack: java.lang.Throwable
        10: astore 3 /* e */
        start local 3 // java.lang.Throwable e
        11: .line 43
            aload 0 /* debug */
            aload 3 /* e */
            invokevirtual org.graalvm.compiler.debug.DebugContext.handle:(Ljava/lang/Throwable;)Ljava/lang/RuntimeException;
            pop
        end local 3 // java.lang.Throwable e
        12: .line 45
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String compilationUnitName
        end local 1 // org.graalvm.compiler.core.common.alloc.TraceBuilderResult result
        end local 0 // org.graalvm.compiler.debug.DebugContext debug
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   13     0                debug  Lorg/graalvm/compiler/debug/DebugContext;
            0   13     1               result  Lorg/graalvm/compiler/core/common/alloc/TraceBuilderResult;
            0   13     2  compilationUnitName  Ljava/lang/String;
            2    6     5                    s  Lorg/graalvm/compiler/debug/DebugContext$Scope;
           11   12     3                    e  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           2     4       5  any
           1     7       7  any
           0    10      10  Class java.lang.Throwable
    MethodParameters:
                     Name  Flags
      debug                
      result               
      compilationUnitName  

  protected static void print(org.graalvm.compiler.debug.DebugContext, org.graalvm.compiler.core.common.alloc.TraceBuilderResult, java.lang.String);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;Lorg/graalvm/compiler/core/common/alloc/TraceBuilderResult;Ljava/lang/String;)V
    flags: (0x000c) ACC_PROTECTED, ACC_STATIC
    Code:
      stack=9, locals=25, args_size=3
        start local 0 // org.graalvm.compiler.debug.DebugContext debug
        start local 1 // org.graalvm.compiler.core.common.alloc.TraceBuilderResult result
        start local 2 // java.lang.String compilationUnitName
         0: .line 49
            aload 1 /* result */
            invokevirtual org.graalvm.compiler.core.common.alloc.TraceBuilderResult.getTraces:()Ljava/util/ArrayList;
            astore 3 /* traces */
        start local 3 // java.util.List traces
         1: .line 50
            aload 3 /* traces */
            invokeinterface java.util.List.size:()I
            istore 4 /* numTraces */
        start local 4 // int numTraces
         2: .line 52
            aconst_null
            astore 5
            aconst_null
            astore 6
         3: aload 0 /* debug */
            iconst_3
            ldc "<tracestatistics>"
            invokevirtual org.graalvm.compiler.debug.DebugContext.logAndIndent:(ILjava/lang/String;)Lorg/graalvm/compiler/debug/Indent;
            astore 7 /* indent0 */
        start local 7 // org.graalvm.compiler.debug.Indent indent0
         4: .line 53
            aload 0 /* debug */
            iconst_3
            ldc "<name>%s</name>"
            aload 2 /* compilationUnitName */
            ifnull 5
            aload 2 /* compilationUnitName */
            goto 6
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String java.util.List int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent
      StackMap stack: org.graalvm.compiler.debug.DebugContext int java.lang.String
         5: ldc "null"
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String java.util.List int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent
      StackMap stack: org.graalvm.compiler.debug.DebugContext int java.lang.String java.lang.String
         6: invokevirtual org.graalvm.compiler.debug.DebugContext.log:(ILjava/lang/String;Ljava/lang/Object;)V
         7: .line 54
            aconst_null
            astore 8
            aconst_null
            astore 9
         8: aload 0 /* debug */
            iconst_3
            ldc "<traces>"
            invokevirtual org.graalvm.compiler.debug.DebugContext.logAndIndent:(ILjava/lang/String;)Lorg/graalvm/compiler/debug/Indent;
            astore 10 /* indent1 */
        start local 10 // org.graalvm.compiler.debug.Indent indent1
         9: .line 55
            aload 0 /* debug */
            ldc "tracenumber"
            ldc "total"
            ldc "min"
            ldc "max"
            ldc "numBlocks"
            invokestatic org.graalvm.compiler.core.common.alloc.TraceStatisticsPrinter.printRawLine:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        10: .line 56
            iconst_0
            istore 11 /* i */
        start local 11 // int i
        11: goto 28
        12: .line 57
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String java.util.List int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent int
      StackMap stack:
            aload 3 /* traces */
            iload 11 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.graalvm.compiler.core.common.alloc.Trace
            invokevirtual org.graalvm.compiler.core.common.alloc.Trace.getBlocks:()[Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase;
            astore 12 /* t */
        start local 12 // org.graalvm.compiler.core.common.cfg.AbstractBlockBase[] t
        13: .line 58
            dconst_0
            dstore 13 /* total */
        start local 13 // double total
        14: .line 59
            ldc -Infinity
            dstore 15 /* max */
        start local 15 // double max
        15: .line 60
            ldc Infinity
            dstore 17 /* min */
        start local 17 // double min
        16: .line 61
            aload 12 /* t */
            dup
            astore 22
            arraylength
            istore 21
            iconst_0
            istore 20
            goto 25
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String java.util.List int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent int org.graalvm.compiler.core.common.cfg.AbstractBlockBase[] double double double top int int org.graalvm.compiler.core.common.cfg.AbstractBlockBase[]
      StackMap stack:
        17: aload 22
            iload 20
            aaload
            astore 19 /* block */
        start local 19 // org.graalvm.compiler.core.common.cfg.AbstractBlockBase block
        18: .line 62
            aload 19 /* block */
            invokevirtual org.graalvm.compiler.core.common.cfg.AbstractBlockBase.probability:()D
            dstore 23 /* probability */
        start local 23 // double probability
        19: .line 63
            dload 13 /* total */
            dload 23 /* probability */
            dadd
            dstore 13 /* total */
        20: .line 64
            dload 23 /* probability */
            dload 17 /* min */
            dcmpg
            ifge 22
        21: .line 65
            dload 23 /* probability */
            dstore 17 /* min */
        22: .line 67
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String java.util.List int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent int org.graalvm.compiler.core.common.cfg.AbstractBlockBase[] double double double org.graalvm.compiler.core.common.cfg.AbstractBlockBase int int org.graalvm.compiler.core.common.cfg.AbstractBlockBase[] double
      StackMap stack:
            dload 23 /* probability */
            dload 15 /* max */
            dcmpl
            ifle 24
        23: .line 68
            dload 23 /* probability */
            dstore 15 /* max */
        end local 23 // double probability
        end local 19 // org.graalvm.compiler.core.common.cfg.AbstractBlockBase block
        24: .line 61
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String java.util.List int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent int org.graalvm.compiler.core.common.cfg.AbstractBlockBase[] double double double top int int org.graalvm.compiler.core.common.cfg.AbstractBlockBase[]
      StackMap stack:
            iinc 20 1
      StackMap locals:
      StackMap stack:
        25: iload 20
            iload 21
            if_icmplt 17
        26: .line 71
            aload 0 /* debug */
            iload 11 /* i */
            dload 13 /* total */
            dload 17 /* min */
            dload 15 /* max */
            aload 12 /* t */
            arraylength
            invokestatic org.graalvm.compiler.core.common.alloc.TraceStatisticsPrinter.printLine:(Lorg/graalvm/compiler/debug/DebugContext;IDDDI)V
        end local 17 // double min
        end local 15 // double max
        end local 13 // double total
        end local 12 // org.graalvm.compiler.core.common.cfg.AbstractBlockBase[] t
        27: .line 56
            iinc 11 /* i */ 1
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String java.util.List int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent int
      StackMap stack:
        28: iload 11 /* i */
            iload 4 /* numTraces */
            if_icmplt 12
        end local 11 // int i
        29: .line 73
            aload 10 /* indent1 */
            ifnull 35
            aload 10 /* indent1 */
            invokeinterface org.graalvm.compiler.debug.Indent.close:()V
            goto 35
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.core.common.alloc.TraceBuilderResult java.lang.String java.util.List int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.Indent
      StackMap stack: java.lang.Throwable
        30: astore 8
            aload 10 /* indent1 */
            ifnull 31
            aload 10 /* indent1 */
            invokeinterface org.graalvm.compiler.debug.Indent.close:()V
        end local 10 // org.graalvm.compiler.debug.Indent indent1
      StackMap locals:
      StackMap stack:
        31: aload 8
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        32: astore 9
            aload 8
            ifnonnull 33
            aload 9
            astore 8
            goto 34
      StackMap locals:
      StackMap stack:
        33: aload 8
            aload 9
            if_acmpeq 34
            aload 8
            aload 9
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        34: aload 8
            athrow
        35: .line 74
      StackMap locals:
      StackMap stack:
            aload 0 /* debug */
            iconst_3
            ldc "</traces>"
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(ILjava/lang/String;)V
        36: .line 75
            aload 7 /* indent0 */
            ifnull 42
            aload 7 /* indent0 */
            invokeinterface org.graalvm.compiler.debug.Indent.close:()V
            goto 42
      StackMap locals:
      StackMap stack: java.lang.Throwable
        37: astore 5
            aload 7 /* indent0 */
            ifnull 38
            aload 7 /* indent0 */
            invokeinterface org.graalvm.compiler.debug.Indent.close:()V
        end local 7 // org.graalvm.compiler.debug.Indent indent0
      StackMap locals:
      StackMap stack:
        38: aload 5
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        39: astore 6
            aload 5
            ifnonnull 40
            aload 6
            astore 5
            goto 41
      StackMap locals:
      StackMap stack:
        40: aload 5
            aload 6
            if_acmpeq 41
            aload 5
            aload 6
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        41: aload 5
            athrow
        42: .line 76
      StackMap locals:
      StackMap stack:
            aload 0 /* debug */
            iconst_3
            ldc "</tracestatistics>"
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(ILjava/lang/String;)V
        43: .line 78
            return
        end local 4 // int numTraces
        end local 3 // java.util.List traces
        end local 2 // java.lang.String compilationUnitName
        end local 1 // org.graalvm.compiler.core.common.alloc.TraceBuilderResult result
        end local 0 // org.graalvm.compiler.debug.DebugContext debug
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   44     0                debug  Lorg/graalvm/compiler/debug/DebugContext;
            0   44     1               result  Lorg/graalvm/compiler/core/common/alloc/TraceBuilderResult;
            0   44     2  compilationUnitName  Ljava/lang/String;
            1   44     3               traces  Ljava/util/List<Lorg/graalvm/compiler/core/common/alloc/Trace;>;
            2   44     4            numTraces  I
            4   38     7              indent0  Lorg/graalvm/compiler/debug/Indent;
            9   31    10              indent1  Lorg/graalvm/compiler/debug/Indent;
           11   29    11                    i  I
           13   27    12                    t  [Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase;
           14   27    13                total  D
           15   27    15                  max  D
           16   27    17                  min  D
           18   24    19                block  Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase<*>;
           19   24    23          probability  D
      Exception table:
        from    to  target  type
           9    29      30  any
           8    32      32  any
           4    36      37  any
           3    39      39  any
    MethodParameters:
                     Name  Flags
      debug                
      result               
      compilationUnitName  

  private static void printRawLine(org.graalvm.compiler.debug.DebugContext, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=6, args_size=6
        start local 0 // org.graalvm.compiler.debug.DebugContext debug
        start local 1 // java.lang.Object tracenr
        start local 2 // java.lang.Object totalTime
        start local 3 // java.lang.Object minProb
        start local 4 // java.lang.Object maxProb
        start local 5 // java.lang.Object numBlocks
         0: .line 81
            aload 0 /* debug */
            iconst_3
            ldc "%s"
            ldc ";"
            iconst_5
            anewarray java.lang.CharSequence
            dup
            iconst_0
            aload 1 /* tracenr */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            aastore
            dup
            iconst_1
            aload 2 /* totalTime */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            aastore
            dup
            iconst_2
            aload 3 /* minProb */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            aastore
            dup
            iconst_3
            aload 4 /* maxProb */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            aastore
            dup
            iconst_4
            aload 5 /* numBlocks */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            aastore
            invokestatic java.lang.String.join:(Ljava/lang/CharSequence;[Ljava/lang/CharSequence;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(ILjava/lang/String;Ljava/lang/Object;)V
         1: .line 82
            return
        end local 5 // java.lang.Object numBlocks
        end local 4 // java.lang.Object maxProb
        end local 3 // java.lang.Object minProb
        end local 2 // java.lang.Object totalTime
        end local 1 // java.lang.Object tracenr
        end local 0 // org.graalvm.compiler.debug.DebugContext debug
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0      debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    2     1    tracenr  Ljava/lang/Object;
            0    2     2  totalTime  Ljava/lang/Object;
            0    2     3    minProb  Ljava/lang/Object;
            0    2     4    maxProb  Ljava/lang/Object;
            0    2     5  numBlocks  Ljava/lang/Object;
    MethodParameters:
           Name  Flags
      debug      
      tracenr    
      totalTime  
      minProb    
      maxProb    
      numBlocks  

  private static void printLine(org.graalvm.compiler.debug.DebugContext, int, double, double, double, int);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;IDDDI)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=9, args_size=6
        start local 0 // org.graalvm.compiler.debug.DebugContext debug
        start local 1 // int tracenr
        start local 2 // double totalTime
        start local 4 // double minProb
        start local 6 // double maxProb
        start local 8 // int numBlocks
         0: .line 85
            aload 0 /* debug */
            iload 1 /* tracenr */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            dload 2 /* totalTime */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            dload 4 /* minProb */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            dload 6 /* maxProb */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            iload 8 /* numBlocks */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokestatic org.graalvm.compiler.core.common.alloc.TraceStatisticsPrinter.printRawLine:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 86
            return
        end local 8 // int numBlocks
        end local 6 // double maxProb
        end local 4 // double minProb
        end local 2 // double totalTime
        end local 1 // int tracenr
        end local 0 // org.graalvm.compiler.debug.DebugContext debug
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0      debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    2     1    tracenr  I
            0    2     2  totalTime  D
            0    2     4    minProb  D
            0    2     6    maxProb  D
            0    2     8  numBlocks  I
    MethodParameters:
           Name  Flags
      debug      
      tracenr    
      totalTime  
      minProb    
      maxProb    
      numBlocks  
}
SourceFile: "TraceStatisticsPrinter.java"
InnerClasses:
  public abstract Scope = org.graalvm.compiler.debug.DebugContext$Scope of org.graalvm.compiler.debug.DebugContext