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 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
putfield com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats.entries:Ljava/util/List;
2: return
end local 0 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 start local 1 0: invokestatic java.lang.System.nanoTime:()J
lstore 2
start local 2 1: aload 0
aload 1
lload 2
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 end local 1 end local 0 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 0: aload 0
getfield com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats.entries:Ljava/util/List;
invokeinterface java.util.List.isEmpty:()Z
ifeq 2
1: return
2: StackMap locals:
StackMap stack:
lconst_0
lstore 1
start local 1 3: aload 0
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
start local 3 5: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "%s: %.02f ms\n"
iconst_2
anewarray java.lang.Object
dup
iconst_0
aload 3
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
aastore
dup
iconst_1
aload 3
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: lload 1
aload 3
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast java.lang.Long
invokevirtual java.lang.Long.longValue:()J
ladd
lstore 1
end local 3 7: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
8: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Total: %.02f ms\n"
iconst_1
anewarray java.lang.Object
dup
iconst_0
lload 1
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: return
end local 1 end local 0 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 0: invokestatic java.lang.System.nanoTime:()J
lstore 4
start local 4 1: aload 0
getfield com.oracle.truffle.js.snapshot.SnapshotTool$TimeStats.entries:Ljava/util/List;
new java.util.AbstractMap$SimpleImmutableEntry
dup
aload 1
lload 4
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 2: return
end local 0 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