public final class org.graalvm.compiler.hotspot.CompilationStatistics
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.graalvm.compiler.hotspot.CompilationStatistics
  super_class: java.lang.Object
{
  private static final long RESOLUTION;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 100000000

  private static final org.graalvm.compiler.hotspot.CompilationStatistics DUMMY;
    descriptor: Lorg/graalvm/compiler/hotspot/CompilationStatistics;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static java.util.concurrent.ConcurrentLinkedDeque<org.graalvm.compiler.hotspot.CompilationStatistics> list;
    descriptor: Ljava/util/concurrent/ConcurrentLinkedDeque;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Signature: Ljava/util/concurrent/ConcurrentLinkedDeque<Lorg/graalvm/compiler/hotspot/CompilationStatistics;>;

  private static final java.lang.ThreadLocal<java.util.Deque<org.graalvm.compiler.hotspot.CompilationStatistics>> current;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Ljava/util/Deque<Lorg/graalvm/compiler/hotspot/CompilationStatistics;>;>;

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

  private final long startTime;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.hotspot.CompilationStatistics$NotReported()

  private long threadAllocatedBytesStart;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.hotspot.CompilationStatistics$NotReported()

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

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

  private long duration;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.hotspot.CompilationStatistics$TimeValue()

  private long memoryUsed;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

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

  private final java.lang.String holder;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String name;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String signature;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  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 53
            ldc Lorg/graalvm/compiler/hotspot/CompilationStatistics;
            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.hotspot.CompilationStatistics.$assertionsDisabled:Z
         3: .line 64
            new org.graalvm.compiler.hotspot.CompilationStatistics
            dup
            aconst_null
            iconst_0
            invokespecial org.graalvm.compiler.hotspot.CompilationStatistics.<init>:(Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethod;Z)V
            putstatic org.graalvm.compiler.hotspot.CompilationStatistics.DUMMY:Lorg/graalvm/compiler/hotspot/CompilationStatistics;
         4: .line 66
            new java.util.concurrent.ConcurrentLinkedDeque
            dup
            invokespecial java.util.concurrent.ConcurrentLinkedDeque.<init>:()V
            putstatic org.graalvm.compiler.hotspot.CompilationStatistics.list:Ljava/util/concurrent/ConcurrentLinkedDeque;
         5: .line 68
            new org.graalvm.compiler.hotspot.CompilationStatistics$1
            dup
            invokespecial org.graalvm.compiler.hotspot.CompilationStatistics$1.<init>:()V
            putstatic org.graalvm.compiler.hotspot.CompilationStatistics.current:Ljava/lang/ThreadLocal;
         6: .line 86
            invokestatic java.lang.System.nanoTime:()J
            putstatic org.graalvm.compiler.hotspot.CompilationStatistics.zeroTime:J
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static long getThreadAllocatedBytes();
    descriptor: ()J
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 89
            invokestatic org.graalvm.compiler.serviceprovider.GraalServices.getCurrentThreadAllocatedBytes:()J
            lreturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod, boolean);
    descriptor: (Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethod;Z)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.hotspot.CompilationStatistics this
        start local 1 // jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod method
        start local 2 // boolean osr
         0: .line 104
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 105
            aload 0 /* this */
            iload 2 /* osr */
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.osr:Z
         2: .line 106
            aload 1 /* method */
            ifnull 10
         3: .line 107
            aload 0 /* this */
            aload 1 /* method */
            invokeinterface jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod.getDeclaringClass:()Ljdk/vm/ci/hotspot/HotSpotResolvedObjectType;
            invokeinterface jdk.vm.ci.hotspot.HotSpotResolvedObjectType.getName:()Ljava/lang/String;
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.holder:Ljava/lang/String;
         4: .line 108
            aload 0 /* this */
            aload 1 /* method */
            invokeinterface jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod.getName:()Ljava/lang/String;
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.name:Ljava/lang/String;
         5: .line 109
            aload 0 /* this */
            aload 1 /* method */
            invokeinterface jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod.getSignature:()Ljdk/vm/ci/meta/Signature;
            invokeinterface jdk.vm.ci.meta.Signature.toMethodDescriptor:()Ljava/lang/String;
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.signature:Ljava/lang/String;
         6: .line 110
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.startTime:J
         7: .line 111
            aload 0 /* this */
            aload 1 /* method */
            invokeinterface jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod.getCodeSize:()I
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.bytecodeCount:I
         8: .line 112
            aload 0 /* this */
            invokestatic org.graalvm.compiler.hotspot.CompilationStatistics.getThreadAllocatedBytes:()J
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.threadAllocatedBytesStart:J
         9: .line 113
            goto 15
        10: .line 114
      StackMap locals: org.graalvm.compiler.hotspot.CompilationStatistics jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod int
      StackMap stack:
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.$assertionsDisabled:Z
            ifne 11
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.DUMMY:Lorg/graalvm/compiler/hotspot/CompilationStatistics;
            ifnull 11
            new java.lang.AssertionError
            dup
            ldc "only DUMMY has no method"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        11: .line 115
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc ""
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.holder:Ljava/lang/String;
        12: .line 116
            aload 0 /* this */
            ldc ""
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.name:Ljava/lang/String;
        13: .line 117
            aload 0 /* this */
            ldc ""
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.signature:Ljava/lang/String;
        14: .line 118
            aload 0 /* this */
            lconst_0
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.startTime:J
        15: .line 120
      StackMap locals:
      StackMap stack:
            return
        end local 2 // boolean osr
        end local 1 // jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod method
        end local 0 // org.graalvm.compiler.hotspot.CompilationStatistics this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   16     0    this  Lorg/graalvm/compiler/hotspot/CompilationStatistics;
            0   16     1  method  Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethod;
            0   16     2     osr  Z
    MethodParameters:
        Name  Flags
      method  
      osr     

  public void finish(jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod, jdk.vm.ci.hotspot.HotSpotInstalledCode);
    descriptor: (Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethod;Ljdk/vm/ci/hotspot/HotSpotInstalledCode;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.hotspot.CompilationStatistics this
        start local 1 // jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod method
        start local 2 // jdk.vm.ci.hotspot.HotSpotInstalledCode code
         0: .line 123
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.hotspot.CompilationStatistics.isEnabled:()Z
            ifeq 7
         1: .line 124
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            aload 0 /* this */
            getfield org.graalvm.compiler.hotspot.CompilationStatistics.startTime:J
            lsub
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.duration:J
         2: .line 125
            aload 0 /* this */
            aload 2 /* code */
            invokevirtual jdk.vm.ci.hotspot.HotSpotInstalledCode.getCodeSize:()J
            l2i
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.codeSize:I
         3: .line 126
            aload 0 /* this */
            invokestatic org.graalvm.compiler.hotspot.CompilationStatistics.getThreadAllocatedBytes:()J
            aload 0 /* this */
            getfield org.graalvm.compiler.hotspot.CompilationStatistics.threadAllocatedBytesStart:J
            lsub
            putfield org.graalvm.compiler.hotspot.CompilationStatistics.memoryUsed:J
         4: .line 127
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.current:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.util.Deque
            invokeinterface java.util.Deque.getLast:()Ljava/lang/Object;
            aload 0 /* this */
            if_acmpeq 6
         5: .line 128
            new java.lang.RuntimeException
            dup
            ldc "mismatch in finish()"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 130
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.current:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.util.Deque
            invokeinterface java.util.Deque.removeLast:()Ljava/lang/Object;
            pop
         7: .line 132
      StackMap locals:
      StackMap stack:
            return
        end local 2 // jdk.vm.ci.hotspot.HotSpotInstalledCode code
        end local 1 // jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod method
        end local 0 // org.graalvm.compiler.hotspot.CompilationStatistics this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lorg/graalvm/compiler/hotspot/CompilationStatistics;
            0    8     1  method  Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethod;
            0    8     2    code  Ljdk/vm/ci/hotspot/HotSpotInstalledCode;
    MethodParameters:
        Name  Flags
      method  
      code    

  public static org.graalvm.compiler.hotspot.CompilationStatistics current();
    descriptor: ()Lorg/graalvm/compiler/hotspot/CompilationStatistics;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 135
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.current:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.util.Deque
            invokeinterface java.util.Deque.isEmpty:()Z
            ifeq 1
            aconst_null
            goto 2
      StackMap locals:
      StackMap stack:
         1: getstatic org.graalvm.compiler.hotspot.CompilationStatistics.current:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.util.Deque
            invokeinterface java.util.Deque.getLast:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.hotspot.CompilationStatistics
      StackMap locals:
      StackMap stack: org.graalvm.compiler.hotspot.CompilationStatistics
         2: areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static org.graalvm.compiler.hotspot.CompilationStatistics create(org.graalvm.compiler.options.OptionValues, jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod, boolean);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethod;Z)Lorg/graalvm/compiler/hotspot/CompilationStatistics;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // org.graalvm.compiler.options.OptionValues options
        start local 1 // jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod method
        start local 2 // boolean isOSR
         0: .line 139
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics$Options.UseCompilationStatistics:Lorg/graalvm/compiler/options/OptionKey;
            aload 0 /* options */
            invokevirtual org.graalvm.compiler.options.OptionKey.getValue:(Lorg/graalvm/compiler/options/OptionValues;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 5
         1: .line 140
            new org.graalvm.compiler.hotspot.CompilationStatistics
            dup
            aload 1 /* method */
            iload 2 /* isOSR */
            invokespecial org.graalvm.compiler.hotspot.CompilationStatistics.<init>:(Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethod;Z)V
            astore 3 /* stats */
        start local 3 // org.graalvm.compiler.hotspot.CompilationStatistics stats
         2: .line 141
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.list:Ljava/util/concurrent/ConcurrentLinkedDeque;
            aload 3 /* stats */
            invokevirtual java.util.concurrent.ConcurrentLinkedDeque.add:(Ljava/lang/Object;)Z
            pop
         3: .line 142
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.current:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.util.Deque
            aload 3 /* stats */
            invokeinterface java.util.Deque.addLast:(Ljava/lang/Object;)V
         4: .line 143
            aload 3 /* stats */
            areturn
        end local 3 // org.graalvm.compiler.hotspot.CompilationStatistics stats
         5: .line 145
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.DUMMY:Lorg/graalvm/compiler/hotspot/CompilationStatistics;
            areturn
        end local 2 // boolean isOSR
        end local 1 // jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod method
        end local 0 // org.graalvm.compiler.options.OptionValues options
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0  options  Lorg/graalvm/compiler/options/OptionValues;
            0    6     1   method  Ljdk/vm/ci/hotspot/HotSpotResolvedJavaMethod;
            0    6     2    isOSR  Z
            2    5     3    stats  Lorg/graalvm/compiler/hotspot/CompilationStatistics;
    MethodParameters:
         Name  Flags
      options  
      method   
      isOSR    

  public boolean isEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.hotspot.CompilationStatistics this
         0: .line 150
            aload 0 /* this */
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.DUMMY:Lorg/graalvm/compiler/hotspot/CompilationStatistics;
            if_acmpeq 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.graalvm.compiler.hotspot.CompilationStatistics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/graalvm/compiler/hotspot/CompilationStatistics;

  public static void clear(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=8, locals=21, args_size=1
        start local 0 // java.lang.String dumpName
         0: .line 156
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.list:Ljava/util/concurrent/ConcurrentLinkedDeque;
            astore 1 /* snapshot */
        start local 1 // java.util.concurrent.ConcurrentLinkedDeque snapshot
         1: .line 157
            getstatic org.graalvm.compiler.hotspot.CompilationStatistics.zeroTime:J
            lstore 2 /* snapshotZeroTime */
        start local 2 // long snapshotZeroTime
         2: .line 159
            new java.util.concurrent.ConcurrentLinkedDeque
            dup
            invokespecial java.util.concurrent.ConcurrentLinkedDeque.<init>:()V
            putstatic org.graalvm.compiler.hotspot.CompilationStatistics.list:Ljava/util/concurrent/ConcurrentLinkedDeque;
         3: .line 160
            invokestatic java.lang.System.nanoTime:()J
            putstatic org.graalvm.compiler.hotspot.CompilationStatistics.zeroTime:J
         4: .line 162
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 4 /* now */
        start local 4 // java.util.Date now
         5: .line 163
            new java.lang.StringBuilder
            dup
            aload 4 /* now */
            invokevirtual java.util.Date.getYear:()I
            sipush 1900
            iadd
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "-"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* now */
            invokevirtual java.util.Date.getMonth:()I
            iconst_1
            iadd
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "-"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* now */
            invokevirtual java.util.Date.getDate:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "-"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* now */
            invokevirtual java.util.Date.getHours:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            aload 4 /* now */
            invokevirtual java.util.Date.getMinutes:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 5 /* dateString */
        start local 5 // java.lang.String dateString
         6: .line 165
            aload 1 /* snapshot */
            aload 0 /* dumpName */
            aload 5 /* dateString */
            invokestatic org.graalvm.compiler.hotspot.CompilationStatistics.dumpCompilations:(Ljava/util/concurrent/ConcurrentLinkedDeque;Ljava/lang/String;Ljava/lang/String;)V
         7: .line 167
            aconst_null
            astore 6
            aconst_null
            astore 7
         8: new java.io.FileOutputStream
            dup
            new java.lang.StringBuilder
            dup
            ldc "timeline_"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* dateString */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "_"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* dumpName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".csv"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_1
            invokespecial java.io.FileOutputStream.<init>:(Ljava/lang/String;Z)V
            astore 8 /* fos */
        start local 8 // java.io.FileOutputStream fos
         9: new java.io.PrintStream
            dup
            aload 8 /* fos */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 9 /* out */
        start local 9 // java.io.PrintStream out
        10: .line 169
            sipush 10000
            newarray 11
            astore 10 /* timeSpent */
        start local 10 // long[] timeSpent
        11: .line 170
            iconst_0
            istore 11 /* maxTick */
        start local 11 // int maxTick
        12: .line 171
            aload 1 /* snapshot */
            invokevirtual java.util.concurrent.ConcurrentLinkedDeque.iterator:()Ljava/util/Iterator;
            astore 13
            goto 29
      StackMap locals: java.lang.String java.util.concurrent.ConcurrentLinkedDeque long java.util.Date java.lang.String java.lang.Throwable java.lang.Throwable java.io.FileOutputStream java.io.PrintStream long[] int top java.util.Iterator
      StackMap stack:
        13: aload 13
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.hotspot.CompilationStatistics
            astore 12 /* stats */
        start local 12 // org.graalvm.compiler.hotspot.CompilationStatistics stats
        14: .line 172
            aload 12 /* stats */
            getfield org.graalvm.compiler.hotspot.CompilationStatistics.startTime:J
            lload 2 /* snapshotZeroTime */
            lsub
            lstore 14 /* start */
        start local 14 // long start
        15: .line 173
            aload 12 /* stats */
            getfield org.graalvm.compiler.hotspot.CompilationStatistics.duration:J
            lstore 16 /* duration */
        start local 16 // long duration
        16: .line 174
            lload 14 /* start */
            lconst_0
            lcmp
            ifge 19
        17: .line 175
            lload 16 /* duration */
            lload 14 /* start */
            lneg
            lsub
            lstore 16 /* duration */
        18: .line 176
            lconst_0
            lstore 14 /* start */
        19: .line 179
      StackMap locals: java.lang.String java.util.concurrent.ConcurrentLinkedDeque long java.util.Date java.lang.String java.lang.Throwable java.lang.Throwable java.io.FileOutputStream java.io.PrintStream long[] int org.graalvm.compiler.hotspot.CompilationStatistics java.util.Iterator long long
      StackMap stack:
            lload 14 /* start */
            ldc 100000000
            ldiv
            l2i
            istore 18 /* tick */
        start local 18 // int tick
        20: .line 180
            ldc 100000000
            lload 14 /* start */
            ldc 100000000
            lrem
            lsub
            lstore 19 /* timeLeft */
        start local 19 // long timeLeft
        21: .line 182
            goto 28
        22: .line 183
      StackMap locals: int long
      StackMap stack:
            iload 18 /* tick */
            iload 11 /* maxTick */
            if_icmple 24
        23: .line 184
            iload 18 /* tick */
            istore 11 /* maxTick */
        24: .line 186
      StackMap locals:
      StackMap stack:
            aload 10 /* timeSpent */
            iload 18 /* tick */
            dup2
            laload
            lload 19 /* timeLeft */
            lload 16 /* duration */
            invokestatic java.lang.Math.min:(JJ)J
            ladd
            lastore
        25: .line 187
            lload 16 /* duration */
            lload 19 /* timeLeft */
            lsub
            lstore 16 /* duration */
        26: .line 188
            iinc 18 /* tick */ 1
        27: .line 189
            ldc 100000000
            lstore 19 /* timeLeft */
        28: .line 182
      StackMap locals:
      StackMap stack:
            iload 18 /* tick */
            aload 10 /* timeSpent */
            arraylength
            if_icmpge 29
            lload 16 /* duration */
            lconst_0
            lcmp
            ifgt 22
        end local 19 // long timeLeft
        end local 18 // int tick
        end local 16 // long duration
        end local 14 // long start
        end local 12 // org.graalvm.compiler.hotspot.CompilationStatistics stats
        29: .line 171
      StackMap locals: java.lang.String java.util.concurrent.ConcurrentLinkedDeque long java.util.Date java.lang.String java.lang.Throwable java.lang.Throwable java.io.FileOutputStream java.io.PrintStream long[] int top java.util.Iterator
      StackMap stack:
            aload 13
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        30: .line 192
            ldc "stats.timeline.name"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 12 /* timelineName */
        start local 12 // java.lang.String timelineName
        31: .line 193
            aload 12 /* timelineName */
            ifnull 33
            aload 12 /* timelineName */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 33
        32: .line 194
            aload 9 /* out */
            ldc "%s%c"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 12 /* timelineName */
            invokestatic org.graalvm.compiler.debug.CSVUtil$Escape.escape:(Ljava/lang/String;)Ljava/lang/String;
            aastore
            dup
            iconst_1
            bipush 59
            invokestatic java.lang.Character.valueOf:(C)Ljava/lang/Character;
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        33: .line 196
      StackMap locals: java.lang.String java.util.concurrent.ConcurrentLinkedDeque long java.util.Date java.lang.String java.lang.Throwable java.lang.Throwable java.io.FileOutputStream java.io.PrintStream long[] int java.lang.String
      StackMap stack:
            iconst_0
            istore 13 /* i */
        start local 13 // int i
        34: goto 37
        35: .line 197
      StackMap locals: int
      StackMap stack:
            aload 9 /* out */
            ldc "%d%c"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 10 /* timeSpent */
            iload 13 /* i */
            laload
            invokestatic org.graalvm.compiler.hotspot.CompilationStatistics.normalize:(J)J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_1
            bipush 59
            invokestatic java.lang.Character.valueOf:(C)Ljava/lang/Character;
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        36: .line 196
            iinc 13 /* i */ 1
      StackMap locals:
      StackMap stack:
        37: iload 13 /* i */
            iload 11 /* maxTick */
            if_icmplt 35
        end local 13 // int i
        38: .line 200
            aload 9 /* out */
            ldc "%d"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 10 /* timeSpent */
            iload 11 /* maxTick */
            laload
            invokestatic org.graalvm.compiler.hotspot.CompilationStatistics.normalize:(J)J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        39: .line 201
            aload 9 /* out */
            invokevirtual java.io.PrintStream.println:()V
        end local 12 // java.lang.String timelineName
        end local 11 // int maxTick
        end local 10 // long[] timeSpent
        40: .line 202
            aload 9 /* out */
            ifnull 43
            aload 9 /* out */
            invokevirtual java.io.PrintStream.close:()V
            goto 43
      StackMap locals: java.lang.String java.util.concurrent.ConcurrentLinkedDeque long java.util.Date java.lang.String java.lang.Throwable java.lang.Throwable java.io.FileOutputStream java.io.PrintStream
      StackMap stack: java.lang.Throwable
        41: astore 6
            aload 9 /* out */
            ifnull 42
            aload 9 /* out */
            invokevirtual java.io.PrintStream.close:()V
        end local 9 // java.io.PrintStream out
      StackMap locals:
      StackMap stack:
        42: aload 6
            athrow
      StackMap locals:
      StackMap stack:
        43: aload 8 /* fos */
            ifnull 53
            aload 8 /* fos */
            invokevirtual java.io.FileOutputStream.close:()V
            goto 53
      StackMap locals:
      StackMap stack: java.lang.Throwable
        44: astore 7
            aload 6
            ifnonnull 45
            aload 7
            astore 6
            goto 46
      StackMap locals:
      StackMap stack:
        45: aload 6
            aload 7
            if_acmpeq 46
            aload 6
            aload 7
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        46: aload 8 /* fos */
            ifnull 47
            aload 8 /* fos */
            invokevirtual java.io.FileOutputStream.close:()V
        end local 8 // java.io.FileOutputStream fos
      StackMap locals:
      StackMap stack:
        47: aload 6
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        48: astore 7
            aload 6
            ifnonnull 49
            aload 7
            astore 6
            goto 50
      StackMap locals:
      StackMap stack:
        49: aload 6
            aload 7
            if_acmpeq 50
            aload 6
            aload 7
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        50: aload 6
            athrow
        end local 5 // java.lang.String dateString
        end local 4 // java.util.Date now
        end local 2 // long snapshotZeroTime
        end local 1 // java.util.concurrent.ConcurrentLinkedDeque snapshot
        51: .line 203
      StackMap locals: java.lang.String
      StackMap stack: java.lang.Exception
            astore 1 /* e */
        start local 1 // java.lang.Exception e
        52: .line 204
            new java.lang.RuntimeException
            dup
            aload 1 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.lang.Exception e
        53: .line 206
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.lang.String dumpName
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   54     0          dumpName  Ljava/lang/String;
            1   51     1          snapshot  Ljava/util/concurrent/ConcurrentLinkedDeque<Lorg/graalvm/compiler/hotspot/CompilationStatistics;>;
            2   51     2  snapshotZeroTime  J
            5   51     4               now  Ljava/util/Date;
            6   51     5        dateString  Ljava/lang/String;
            9   47     8               fos  Ljava/io/FileOutputStream;
           10   42     9               out  Ljava/io/PrintStream;
           11   40    10         timeSpent  [J
           12   40    11           maxTick  I
           14   29    12             stats  Lorg/graalvm/compiler/hotspot/CompilationStatistics;
           15   29    14             start  J
           16   29    16          duration  J
           20   29    18              tick  I
           21   29    19          timeLeft  J
           31   40    12      timelineName  Ljava/lang/String;
           34   38    13                 i  I
           52   53     1                 e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          10    40      41  any
           9    43      44  any
           8    48      48  any
           0    51      51  Class java.lang.Exception
    MethodParameters:
          Name  Flags
      dumpName  

  private static long normalize(long);
    descriptor: (J)J
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // long time
         0: .line 209
            lload 0 /* time */
            ldc 100
            lmul
            ldc 100000000
            ldiv
            lreturn
        end local 0 // long time
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  time  J
    MethodParameters:
      Name  Flags
      time  

  protected static void dumpCompilations(java.util.concurrent.ConcurrentLinkedDeque<org.graalvm.compiler.hotspot.CompilationStatistics>, java.lang.String, java.lang.String);
    descriptor: (Ljava/util/concurrent/ConcurrentLinkedDeque;Ljava/lang/String;Ljava/lang/String;)V
    flags: (0x000c) ACC_PROTECTED, ACC_STATIC
    Code:
      stack=9, locals=18, args_size=3
        start local 0 // java.util.concurrent.ConcurrentLinkedDeque snapshot
        start local 1 // java.lang.String dumpName
        start local 2 // java.lang.String dateString
         0: .line 213
            new java.lang.StringBuilder
            dup
            ldc "compilations_"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* dateString */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "_"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* dumpName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".csv"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* fileName */
        start local 3 // java.lang.String fileName
         1: .line 214
            bipush 9
            istore 4 /* separator */
        start local 4 // char separator
         2: .line 215
            aconst_null
            astore 5
            aconst_null
            astore 6
         3: new java.io.PrintStream
            dup
            aload 3 /* fileName */
            invokespecial java.io.PrintStream.<init>:(Ljava/lang/String;)V
            astore 7 /* out */
        start local 7 // java.io.PrintStream out
         4: .line 218
            ldc Lorg/graalvm/compiler/hotspot/CompilationStatistics;
            invokevirtual java.lang.Class.getDeclaredFields:()[Ljava/lang/reflect/Field;
            astore 8 /* declaredFields */
        start local 8 // java.lang.reflect.Field[] declaredFields
         5: .line 219
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 9 /* fields */
        start local 9 // java.util.ArrayList fields
         6: .line 220
            aload 8 /* declaredFields */
            dup
            astore 13
            arraylength
            istore 12
            iconst_0
            istore 11
            goto 11
      StackMap locals: java.util.concurrent.ConcurrentLinkedDeque java.lang.String java.lang.String java.lang.String int java.lang.Throwable java.lang.Throwable java.io.PrintStream java.lang.reflect.Field[] java.util.ArrayList top int int java.lang.reflect.Field[]
      StackMap stack:
         7: aload 13
            iload 11
            aaload
            astore 10 /* field */
        start local 10 // java.lang.reflect.Field field
         8: .line 221
            aload 10 /* field */
            invokevirtual java.lang.reflect.Field.getModifiers:()I
            invokestatic java.lang.reflect.Modifier.isStatic:(I)Z
            ifne 10
            aload 10 /* field */
            ldc Lorg/graalvm/compiler/hotspot/CompilationStatistics$NotReported;
            invokevirtual java.lang.reflect.Field.isAnnotationPresent:(Ljava/lang/Class;)Z
            ifne 10
         9: .line 222
            aload 9 /* fields */
            aload 10 /* field */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 10 // java.lang.reflect.Field field
        10: .line 220
      StackMap locals:
      StackMap stack:
            iinc 11 1
      StackMap locals:
      StackMap stack:
        11: iload 11
            iload 12
            if_icmplt 7
        12: .line 225
            ldc "%s"
            iload 4 /* separator */
            aload 9 /* fields */
            invokevirtual java.util.ArrayList.size:()I
            invokestatic org.graalvm.compiler.debug.CSVUtil.buildFormatString:(Ljava/lang/String;CI)Ljava/lang/String;
            astore 10 /* format */
        start local 10 // java.lang.String format
        13: .line 226
            aload 7 /* out */
            iload 4 /* separator */
            bipush 34
            bipush 92
            aload 10 /* format */
            aload 9 /* fields */
            invokevirtual java.util.ArrayList.toArray:()[Ljava/lang/Object;
            invokestatic org.graalvm.compiler.debug.CSVUtil$Escape.println:(Ljava/io/PrintStream;CCCLjava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        14: .line 227
            aload 0 /* snapshot */
            invokevirtual java.util.concurrent.ConcurrentLinkedDeque.iterator:()Ljava/util/Iterator;
            astore 12
            goto 28
      StackMap locals: java.util.concurrent.ConcurrentLinkedDeque java.lang.String java.lang.String java.lang.String int java.lang.Throwable java.lang.Throwable java.io.PrintStream java.lang.reflect.Field[] java.util.ArrayList java.lang.String top java.util.Iterator
      StackMap stack:
        15: aload 12
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.hotspot.CompilationStatistics
            astore 11 /* stats */
        start local 11 // org.graalvm.compiler.hotspot.CompilationStatistics stats
        16: .line 228
            aload 9 /* fields */
            invokevirtual java.util.ArrayList.size:()I
            anewarray java.lang.Object
            astore 13 /* values */
        start local 13 // java.lang.Object[] values
        17: .line 229
            iconst_0
            istore 14 /* i */
        start local 14 // int i
        18: goto 26
        19: .line 230
      StackMap locals: java.util.concurrent.ConcurrentLinkedDeque java.lang.String java.lang.String java.lang.String int java.lang.Throwable java.lang.Throwable java.io.PrintStream java.lang.reflect.Field[] java.util.ArrayList java.lang.String org.graalvm.compiler.hotspot.CompilationStatistics java.util.Iterator java.lang.Object[] int
      StackMap stack:
            aload 9 /* fields */
            iload 14 /* i */
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast java.lang.reflect.Field
            astore 15 /* field */
        start local 15 // java.lang.reflect.Field field
        20: .line 231
            aload 15 /* field */
            ldc Lorg/graalvm/compiler/hotspot/CompilationStatistics$TimeValue;
            invokevirtual java.lang.reflect.Field.isAnnotationPresent:(Ljava/lang/Class;)Z
            ifeq 24
        21: .line 232
            aload 15 /* field */
            aload 11 /* stats */
            invokevirtual java.lang.reflect.Field.getLong:(Ljava/lang/Object;)J
            l2d
            ldc 1000000.0
            ddiv
            dstore 16 /* value */
        start local 16 // double value
        22: .line 233
            aload 13 /* values */
            iload 14 /* i */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            ldc "%.3f"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            dload 16 /* value */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            aastore
        end local 16 // double value
        23: .line 234
            goto 25
        24: .line 235
      StackMap locals: java.lang.reflect.Field
      StackMap stack:
            aload 13 /* values */
            iload 14 /* i */
            aload 15 /* field */
            aload 11 /* stats */
            invokevirtual java.lang.reflect.Field.get:(Ljava/lang/Object;)Ljava/lang/Object;
            aastore
        end local 15 // java.lang.reflect.Field field
        25: .line 229
      StackMap locals:
      StackMap stack:
            iinc 14 /* i */ 1
      StackMap locals:
      StackMap stack:
        26: iload 14 /* i */
            aload 9 /* fields */
            invokevirtual java.util.ArrayList.size:()I
            if_icmplt 19
        end local 14 // int i
        27: .line 238
            aload 7 /* out */
            iload 4 /* separator */
            bipush 34
            bipush 92
            aload 10 /* format */
            aload 13 /* values */
            invokestatic org.graalvm.compiler.debug.CSVUtil$Escape.println:(Ljava/io/PrintStream;CCCLjava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        end local 13 // java.lang.Object[] values
        end local 11 // org.graalvm.compiler.hotspot.CompilationStatistics stats
        28: .line 227
      StackMap locals: java.util.concurrent.ConcurrentLinkedDeque java.lang.String java.lang.String java.lang.String int java.lang.Throwable java.lang.Throwable java.io.PrintStream java.lang.reflect.Field[] java.util.ArrayList java.lang.String top java.util.Iterator
      StackMap stack:
            aload 12
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 15
        end local 10 // java.lang.String format
        end local 9 // java.util.ArrayList fields
        end local 8 // java.lang.reflect.Field[] declaredFields
        29: .line 240
            aload 7 /* out */
            ifnull 35
            aload 7 /* out */
            invokevirtual java.io.PrintStream.close:()V
            goto 35
      StackMap locals: java.util.concurrent.ConcurrentLinkedDeque java.lang.String java.lang.String java.lang.String int java.lang.Throwable java.lang.Throwable java.io.PrintStream
      StackMap stack: java.lang.Throwable
        30: astore 5
            aload 7 /* out */
            ifnull 31
            aload 7 /* out */
            invokevirtual java.io.PrintStream.close:()V
        end local 7 // java.io.PrintStream out
      StackMap locals:
      StackMap stack:
        31: aload 5
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        32: astore 6
            aload 5
            ifnonnull 33
            aload 6
            astore 5
            goto 34
      StackMap locals:
      StackMap stack:
        33: aload 5
            aload 6
            if_acmpeq 34
            aload 5
            aload 6
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        34: aload 5
            athrow
        35: .line 241
      StackMap locals:
      StackMap stack:
            return
        end local 4 // char separator
        end local 3 // java.lang.String fileName
        end local 2 // java.lang.String dateString
        end local 1 // java.lang.String dumpName
        end local 0 // java.util.concurrent.ConcurrentLinkedDeque snapshot
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   36     0        snapshot  Ljava/util/concurrent/ConcurrentLinkedDeque<Lorg/graalvm/compiler/hotspot/CompilationStatistics;>;
            0   36     1        dumpName  Ljava/lang/String;
            0   36     2      dateString  Ljava/lang/String;
            1   36     3        fileName  Ljava/lang/String;
            2   36     4       separator  C
            4   31     7             out  Ljava/io/PrintStream;
            5   29     8  declaredFields  [Ljava/lang/reflect/Field;
            6   29     9          fields  Ljava/util/ArrayList<Ljava/lang/reflect/Field;>;
            8   10    10           field  Ljava/lang/reflect/Field;
           13   29    10          format  Ljava/lang/String;
           16   28    11           stats  Lorg/graalvm/compiler/hotspot/CompilationStatistics;
           17   28    13          values  [Ljava/lang/Object;
           18   27    14               i  I
           20   25    15           field  Ljava/lang/reflect/Field;
           22   23    16           value  D
      Exception table:
        from    to  target  type
           4    29      30  any
           3    32      32  any
    Exceptions:
      throws java.lang.IllegalAccessException, java.io.FileNotFoundException
    Signature: (Ljava/util/concurrent/ConcurrentLinkedDeque<Lorg/graalvm/compiler/hotspot/CompilationStatistics;>;Ljava/lang/String;Ljava/lang/String;)V
    MethodParameters:
            Name  Flags
      snapshot    
      dumpName    
      dateString  
}
SourceFile: "CompilationStatistics.java"
NestMembers:
  org.graalvm.compiler.hotspot.CompilationStatistics$1  org.graalvm.compiler.hotspot.CompilationStatistics$NotReported  org.graalvm.compiler.hotspot.CompilationStatistics$Options  org.graalvm.compiler.hotspot.CompilationStatistics$TimeValue
InnerClasses:
  public final Escape = org.graalvm.compiler.debug.CSVUtil$Escape of org.graalvm.compiler.debug.CSVUtil
  org.graalvm.compiler.hotspot.CompilationStatistics$1
  private abstract NotReported = org.graalvm.compiler.hotspot.CompilationStatistics$NotReported of org.graalvm.compiler.hotspot.CompilationStatistics
  public Options = org.graalvm.compiler.hotspot.CompilationStatistics$Options of org.graalvm.compiler.hotspot.CompilationStatistics
  private abstract TimeValue = org.graalvm.compiler.hotspot.CompilationStatistics$TimeValue of org.graalvm.compiler.hotspot.CompilationStatistics