class com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats
  super_class: java.lang.Object
{
  private final java.util.List<java.util.Map$Entry<java.lang.String, java.lang.Long>> entries;
    descriptor: Ljava/util/List;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/List<Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;>;

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats this
         0: .line 158
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 159
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats.entries:Ljava/util/List;
         2: .line 158
            return
        end local 0 // com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/oracle/truffle/js/snapshot/SnapshotTool$TimeStats;

  public com.oracle.truffle.js.snapshot.SnapshotTool$TimerCloseable file(java.lang.String);
    descriptor: (Ljava/lang/String;)Lcom/oracle/truffle/js/snapshot/SnapshotTool$TimerCloseable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats this
        start local 1 // java.lang.String fileName
         0: .line 162
            invokestatic java.lang.System.nanoTime:()J
            lstore 2 /* startTime */
        start local 2 // long startTime
         1: .line 163
            aload 0 /* this */
            aload 1 /* fileName */
            lload 2 /* startTime */
            invokedynamic close(Lcom/oracle/truffle/js/snapshot/SnapshotTool$TimeStats;Ljava/lang/String;J)Lcom/oracle/truffle/js/snapshot/SnapshotTool$TimerCloseable;
              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:
                  ()V
                  com/oracle/truffle/js/snapshot/SnapshotTool$TimeStats.lambda$0(Ljava/lang/String;J)V (7)
                  ()V
            areturn
        end local 2 // long startTime
        end local 1 // java.lang.String fileName
        end local 0 // com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lcom/oracle/truffle/js/snapshot/SnapshotTool$TimeStats;
            0    2     1   fileName  Ljava/lang/String;
            1    2     2  startTime  J
    MethodParameters:
          Name  Flags
      fileName  

  public void print();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=5, args_size=1
        start local 0 // com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats this
         0: .line 170
            aload 0 /* this */
            getfield com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats.entries:Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 2
         1: .line 171
            return
         2: .line 173
      StackMap locals:
      StackMap stack:
            lconst_0
            lstore 1 /* total */
        start local 1 // long total
         3: .line 174
            aload 0 /* this */
            getfield com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats.entries:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 7
      StackMap locals: com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats long top java.util.Iterator
      StackMap stack:
         4: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 3 /* entry */
        start local 3 // java.util.Map$Entry entry
         5: .line 175
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "%s: %.02f ms\n"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            aastore
            dup
            iconst_1
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            l2d
            ldc 1000000.0
            ddiv
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
         6: .line 176
            lload 1 /* total */
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            ladd
            lstore 1 /* total */
        end local 3 // java.util.Map$Entry entry
         7: .line 174
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         8: .line 178
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Total: %.02f ms\n"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            lload 1 /* total */
            l2d
            ldc 1000000.0
            ddiv
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
         9: .line 179
            return
        end local 1 // long total
        end local 0 // com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   10     0   this  Lcom/oracle/truffle/js/snapshot/SnapshotTool$TimeStats;
            3   10     1  total  J
            5    7     3  entry  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;

  private void lambda$0(java.lang.String, long);
    descriptor: (Ljava/lang/String;J)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=8, locals=6, args_size=3
        start local 0 // com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats this
         0: .line 164
            invokestatic java.lang.System.nanoTime:()J
            lstore 4 /* endTime */
        start local 4 // long endTime
         1: .line 165
            aload 0 /* this */
            getfield com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats.entries:Ljava/util/List;
            new java.util.AbstractMap$SimpleImmutableEntry
            dup
            aload 1
            lload 4 /* endTime */
            lload 2
            lsub
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokespecial java.util.AbstractMap$SimpleImmutableEntry.<init>:(Ljava/lang/Object;Ljava/lang/Object;)V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // long endTime
         2: .line 166
            return
        end local 0 // com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lcom/oracle/truffle/js/snapshot/SnapshotTool$TimeStats;
            1    2     4  endTime  J
}
SourceFile: "SnapshotTool.java"
NestHost: com.oracle.truffle.js.snapshot.SnapshotTool
InnerClasses:
  private TimeStats = com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats of com.oracle.truffle.js.snapshot.SnapshotTool
  private abstract TimerCloseable = com.oracle.truffle.js.snapshot.SnapshotTool$TimerCloseable of com.oracle.truffle.js.snapshot.SnapshotTool
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  public SimpleImmutableEntry = java.util.AbstractMap$SimpleImmutableEntry of java.util.AbstractMap
  public abstract Entry = java.util.Map$Entry of java.util.Map