public class org.eclipse.core.internal.runtime.PerformanceStatsProcessor extends org.eclipse.core.runtime.jobs.Job
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.eclipse.core.internal.runtime.PerformanceStatsProcessor
super_class: org.eclipse.core.runtime.jobs.Job
{
private static final org.eclipse.core.internal.runtime.PerformanceStatsProcessor instance;
descriptor: Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final long SCHEDULE_DELAY;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 2000
private final java.util.ArrayList<org.eclipse.core.runtime.PerformanceStats> changes;
descriptor: Ljava/util/ArrayList;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/ArrayList<Lorg/eclipse/core/runtime/PerformanceStats;>;
private final java.util.HashMap<org.eclipse.core.runtime.PerformanceStats, java.lang.Long> failures;
descriptor: Ljava/util/HashMap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/HashMap<Lorg/eclipse/core/runtime/PerformanceStats;Ljava/lang/Long;>;
private final org.eclipse.core.runtime.ListenerList<org.eclipse.core.runtime.PerformanceStats$PerformanceListener> listeners;
descriptor: Lorg/eclipse/core/runtime/ListenerList;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lorg/eclipse/core/runtime/ListenerList<Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;>;
private org.eclipse.osgi.framework.log.FrameworkLog log;
descriptor: Lorg/eclipse/osgi/framework/log/FrameworkLog;
flags: (0x0002) ACC_PRIVATE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new org.eclipse.core.internal.runtime.PerformanceStatsProcessor
dup
invokespecial org.eclipse.core.internal.runtime.PerformanceStatsProcessor.<init>:()V
putstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
1: return
LocalVariableTable:
Start End Slot Name Signature
public static void addListener(org.eclipse.core.runtime.PerformanceStats$PerformanceListener);
descriptor: (Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.listeners:Lorg/eclipse/core/runtime/ListenerList;
aload 0
invokevirtual org.eclipse.core.runtime.ListenerList.add:(Ljava/lang/Object;)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 listener Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;
MethodParameters:
Name Flags
listener
public static void changed(org.eclipse.core.runtime.PerformanceStats);
descriptor: (Lorg/eclipse/core/runtime/PerformanceStats;)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=3, locals=2, args_size=1
start local 0 0: getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
dup
astore 1
monitorenter
1: getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
aload 0
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
2: aload 1
monitorexit
3: goto 6
StackMap locals: org.eclipse.core.runtime.PerformanceStats org.eclipse.core.internal.runtime.PerformanceStatsProcessor
StackMap stack: java.lang.Throwable
4: aload 1
monitorexit
5: athrow
6: StackMap locals:
StackMap stack:
getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
ldc 2000
invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.schedule:(J)V
7: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 stats Lorg/eclipse/core/runtime/PerformanceStats;
Exception table:
from to target type
1 3 4 any
4 5 4 any
MethodParameters:
Name Flags
stats
public static void failed(org.eclipse.core.runtime.PerformanceStats, java.lang.String, long);
descriptor: (Lorg/eclipse/core/runtime/PerformanceStats;Ljava/lang/String;J)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=5, locals=5, args_size=3
start local 0 start local 1 start local 2 0: getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
dup
astore 4
monitorenter
1: getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
aload 0
lload 2
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
2: aload 4
monitorexit
3: goto 6
StackMap locals: org.eclipse.core.runtime.PerformanceStats java.lang.String long org.eclipse.core.internal.runtime.PerformanceStatsProcessor
StackMap stack: java.lang.Throwable
4: aload 4
monitorexit
5: athrow
6: StackMap locals:
StackMap stack:
getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
ldc 2000
invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.schedule:(J)V
7: getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
aload 0
aload 1
lload 2
invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.logFailure:(Lorg/eclipse/core/runtime/PerformanceStats;Ljava/lang/String;J)V
8: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 stats Lorg/eclipse/core/runtime/PerformanceStats;
0 9 1 pluginId Ljava/lang/String;
0 9 2 elapsed J
Exception table:
from to target type
1 3 4 any
4 5 4 any
MethodParameters:
Name Flags
stats
pluginId
elapsed
public static void printStats(java.io.PrintWriter);
descriptor: (Ljava/io/PrintWriter;)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=5, locals=12, args_size=1
start local 0 0: lconst_0
lstore 1
start local 1 1: iconst_0
istore 3
start local 3 2: invokestatic org.eclipse.core.runtime.PerformanceStats.getAllStats:()[Lorg/eclipse/core/runtime/PerformanceStats;
astore 4
start local 4 3: aload 4
dup
astore 8
arraylength
istore 7
iconst_0
istore 6
goto 8
StackMap locals: java.io.PrintWriter long int org.eclipse.core.runtime.PerformanceStats[] top int int org.eclipse.core.runtime.PerformanceStats[]
StackMap stack:
4: aload 8
iload 6
aaload
astore 5
start local 5 5: lload 1
aload 5
invokevirtual org.eclipse.core.runtime.PerformanceStats.getRunningTime:()J
ladd
lstore 1
6: iload 3
aload 5
invokevirtual org.eclipse.core.runtime.PerformanceStats.getRunCount:()I
iadd
istore 3
end local 5 7: iinc 6 1
StackMap locals:
StackMap stack:
8: iload 6
iload 7
if_icmplt 4
9: aload 0
ldc "---------------------------------------------------------------"
invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
10: aload 4
dup
astore 8
arraylength
istore 7
iconst_0
istore 6
goto 36
StackMap locals:
StackMap stack:
11: aload 8
iload 6
aaload
astore 5
start local 5 12: aload 0
ldc "Event: "
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
13: aload 0
aload 5
invokevirtual org.eclipse.core.runtime.PerformanceStats.getEvent:()Ljava/lang/String;
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
14: aload 0
ldc " Blame: "
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
15: aload 0
aload 5
invokevirtual org.eclipse.core.runtime.PerformanceStats.getBlameString:()Ljava/lang/String;
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
16: aload 5
invokevirtual org.eclipse.core.runtime.PerformanceStats.getContext:()Ljava/lang/String;
ifnull 19
17: aload 0
ldc " Context: "
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
18: aload 0
aload 5
invokevirtual org.eclipse.core.runtime.PerformanceStats.getContext:()Ljava/lang/String;
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
19: StackMap locals: java.io.PrintWriter long int org.eclipse.core.runtime.PerformanceStats[] org.eclipse.core.runtime.PerformanceStats int int org.eclipse.core.runtime.PerformanceStats[]
StackMap stack:
aload 0
invokevirtual java.io.PrintWriter.println:()V
20: aload 5
invokevirtual org.eclipse.core.runtime.PerformanceStats.getRunCount:()I
istore 9
start local 9 21: iload 9
ifle 27
22: aload 0
ldc "Run count: "
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
23: aload 0
iload 9
invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
24: aload 0
ldc " ("
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
25: aload 0
iload 9
i2d
ldc 100.0
dmul
iload 3
i2d
ddiv
d2i
invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
26: aload 0
ldc " % of total)"
invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
27: StackMap locals: int
StackMap stack:
aload 5
invokevirtual org.eclipse.core.runtime.PerformanceStats.getRunningTime:()J
lstore 10
start local 10 28: lload 10
lconst_0
lcmp
ifle 34
29: aload 0
ldc "Duration (ms): "
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
30: aload 0
lload 10
invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
31: aload 0
ldc " ("
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
32: aload 0
lload 10
l2d
ldc 100.0
dmul
lload 1
l2d
ddiv
d2i
invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
33: aload 0
ldc " % of total)"
invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
34: StackMap locals: long
StackMap stack:
aload 0
ldc ""
invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
end local 10 end local 9 end local 5 35: iinc 6 1
StackMap locals: java.io.PrintWriter long int org.eclipse.core.runtime.PerformanceStats[] top int int org.eclipse.core.runtime.PerformanceStats[]
StackMap stack:
36: iload 6
iload 7
if_icmplt 11
37: return
end local 4 end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 38 0 out Ljava/io/PrintWriter;
1 38 1 totalTime J
2 38 3 totalCount I
3 38 4 allStats [Lorg/eclipse/core/runtime/PerformanceStats;
5 7 5 stats Lorg/eclipse/core/runtime/PerformanceStats;
12 35 5 stats Lorg/eclipse/core/runtime/PerformanceStats;
21 35 9 runCount I
28 35 10 runTime J
MethodParameters:
Name Flags
out
public static void removeListener(org.eclipse.core.runtime.PerformanceStats$PerformanceListener);
descriptor: (Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.listeners:Lorg/eclipse/core/runtime/ListenerList;
aload 0
invokevirtual org.eclipse.core.runtime.ListenerList.remove:(Ljava/lang/Object;)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 listener Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;
MethodParameters:
Name Flags
listener
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=7, locals=7, args_size=1
start local 0 0: aload 0
ldc "Performance Stats"
invokespecial org.eclipse.core.runtime.jobs.Job.<init>:(Ljava/lang/String;)V
1: aload 0
new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
putfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
2: aload 0
new java.util.HashMap
dup
invokespecial java.util.HashMap.<init>:()V
putfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
3: aload 0
new org.eclipse.core.runtime.ListenerList
dup
invokespecial org.eclipse.core.runtime.ListenerList.<init>:()V
putfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.listeners:Lorg/eclipse/core/runtime/ListenerList;
4: aload 0
iconst_1
invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.setSystem:(Z)V
5: aload 0
bipush 50
invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.setPriority:(I)V
6: invokestatic org.eclipse.core.internal.runtime.PlatformActivator.getContext:()Lorg/osgi/framework/BundleContext;
astore 1
start local 1 7: new java.lang.StringBuilder
dup
ldc "(performance="
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
bipush 41
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
astore 2
start local 2 8: aconst_null
astore 4
start local 4 9: aload 1
ldc Lorg/eclipse/osgi/framework/log/FrameworkLog;
aload 2
invokeinterface org.osgi.framework.BundleContext.getServiceReferences:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/Collection;
astore 3
start local 3 10: aload 3
ifnull 19
aload 3
invokeinterface java.util.Collection.isEmpty:()Z
ifne 19
11: aload 1
aload 3
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.osgi.framework.ServiceReference
invokeinterface org.osgi.framework.BundleContext.getService:(Lorg/osgi/framework/ServiceReference;)Ljava/lang/Object;
checkcast org.eclipse.osgi.framework.log.FrameworkLog
astore 4
12: invokestatic org.eclipse.core.runtime.Platform.getLogFileLocation:()Lorg/eclipse/core/runtime/IPath;
astore 5
start local 5 13: aload 5
iconst_1
invokeinterface org.eclipse.core.runtime.IPath.removeLastSegments:(I)Lorg/eclipse/core/runtime/IPath;
ldc "performance.log"
invokeinterface org.eclipse.core.runtime.IPath.append:(Ljava/lang/String;)Lorg/eclipse/core/runtime/IPath;
astore 5
14: aload 4
aload 5
invokeinterface org.eclipse.core.runtime.IPath.toFile:()Ljava/io/File;
iconst_0
invokeinterface org.eclipse.osgi.framework.log.FrameworkLog.setFile:(Ljava/io/File;Z)V
end local 5 15: goto 19
end local 3 StackMap locals: org.eclipse.core.internal.runtime.PerformanceStatsProcessor org.osgi.framework.BundleContext java.lang.String top org.eclipse.osgi.framework.log.FrameworkLog
StackMap stack: java.lang.Exception
16: astore 5
start local 5 17: new org.eclipse.core.runtime.Status
dup
iconst_4
ldc "org.eclipse.core.runtime"
iconst_1
ldc "Error loading performance log"
aload 5
invokespecial org.eclipse.core.runtime.Status.<init>:(ILjava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
astore 6
start local 6 18: aload 6
invokestatic org.eclipse.core.internal.runtime.RuntimeLog.log:(Lorg/eclipse/core/runtime/IStatus;)V
end local 6 end local 5 19: StackMap locals:
StackMap stack:
aload 4
ifnonnull 21
20: invokestatic org.eclipse.core.internal.runtime.InternalPlatform.getDefault:()Lorg/eclipse/core/internal/runtime/InternalPlatform;
invokevirtual org.eclipse.core.internal.runtime.InternalPlatform.getFrameworkLog:()Lorg/eclipse/osgi/framework/log/FrameworkLog;
astore 4
21: StackMap locals:
StackMap stack:
aload 0
aload 4
putfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.log:Lorg/eclipse/osgi/framework/log/FrameworkLog;
22: return
end local 4 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 23 0 this Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
7 23 1 context Lorg/osgi/framework/BundleContext;
8 23 2 filter Ljava/lang/String;
10 16 3 references Ljava/util/Collection<Lorg/osgi/framework/ServiceReference<Lorg/eclipse/osgi/framework/log/FrameworkLog;>;>;
9 23 4 perfLog Lorg/eclipse/osgi/framework/log/FrameworkLog;
13 15 5 logLocation Lorg/eclipse/core/runtime/IPath;
17 19 5 e Ljava/lang/Exception;
18 19 6 error Lorg/eclipse/core/runtime/IStatus;
Exception table:
from to target type
9 15 16 Class java.lang.Exception
private void logFailure(org.eclipse.core.runtime.PerformanceStats, java.lang.String, long);
descriptor: (Lorg/eclipse/core/runtime/PerformanceStats;Ljava/lang/String;J)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=11, locals=7, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.log:Lorg/eclipse/osgi/framework/log/FrameworkLog;
ifnonnull 2
1: return
2: StackMap locals:
StackMap stack:
aload 2
ifnonnull 4
3: ldc "org.eclipse.core.runtime"
astore 2
4: StackMap locals:
StackMap stack:
new java.lang.StringBuilder
dup
ldc "Performance failure: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual org.eclipse.core.runtime.PerformanceStats.getEvent:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " blame: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual org.eclipse.core.runtime.PerformanceStats.getBlameString:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " context: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual org.eclipse.core.runtime.PerformanceStats.getContext:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " duration: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
lload 3
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
astore 5
start local 5 5: new org.eclipse.core.runtime.Status
dup
iconst_2
aload 2
iconst_1
aload 5
new java.lang.RuntimeException
dup
invokespecial java.lang.RuntimeException.<init>:()V
invokespecial org.eclipse.core.runtime.Status.<init>:(ILjava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
astore 6
start local 6 6: aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.log:Lorg/eclipse/osgi/framework/log/FrameworkLog;
new org.eclipse.osgi.framework.log.FrameworkLogEntry
dup
aload 6
aload 6
invokevirtual org.eclipse.core.runtime.Status.getPlugin:()Ljava/lang/String;
aload 6
invokevirtual org.eclipse.core.runtime.Status.getSeverity:()I
aload 6
invokevirtual org.eclipse.core.runtime.Status.getCode:()I
aload 6
invokevirtual org.eclipse.core.runtime.Status.getMessage:()Ljava/lang/String;
iconst_0
aload 6
invokevirtual org.eclipse.core.runtime.Status.getException:()Ljava/lang/Throwable;
aconst_null
invokespecial org.eclipse.osgi.framework.log.FrameworkLogEntry.<init>:(Ljava/lang/Object;Ljava/lang/String;IILjava/lang/String;ILjava/lang/Throwable;[Lorg/eclipse/osgi/framework/log/FrameworkLogEntry;)V
invokeinterface org.eclipse.osgi.framework.log.FrameworkLog.log:(Lorg/eclipse/osgi/framework/log/FrameworkLogEntry;)V
7: return
end local 6 end local 5 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
0 8 1 stats Lorg/eclipse/core/runtime/PerformanceStats;
0 8 2 pluginId Ljava/lang/String;
0 8 3 elapsed J
5 8 5 msg Ljava/lang/String;
6 8 6 status Lorg/eclipse/core/runtime/Status;
MethodParameters:
Name Flags
stats
pluginId
elapsed
protected org.eclipse.core.runtime.IStatus run(org.eclipse.core.runtime.IProgressMonitor);
descriptor: (Lorg/eclipse/core/runtime/IProgressMonitor;)Lorg/eclipse/core/runtime/IStatus;
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=8, args_size=2
start local 0 start local 1 0: aload 0
dup
astore 5
monitorenter
1: aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
invokevirtual java.util.ArrayList.size:()I
anewarray org.eclipse.core.runtime.PerformanceStats
invokevirtual java.util.ArrayList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
checkcast org.eclipse.core.runtime.PerformanceStats[]
astore 2
start local 2 2: aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
invokevirtual java.util.ArrayList.clear:()V
3: aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
invokevirtual java.util.HashMap.keySet:()Ljava/util/Set;
aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
invokevirtual java.util.HashMap.size:()I
anewarray org.eclipse.core.runtime.PerformanceStats
invokeinterface java.util.Set.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
checkcast org.eclipse.core.runtime.PerformanceStats[]
astore 3
start local 3 4: aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
invokevirtual java.util.HashMap.values:()Ljava/util/Collection;
aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
invokevirtual java.util.HashMap.size:()I
anewarray java.lang.Long
invokeinterface java.util.Collection.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
checkcast java.lang.Long[]
astore 4
start local 4 5: aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
invokevirtual java.util.HashMap.clear:()V
6: aload 5
monitorexit
7: goto 10
end local 4 end local 3 end local 2 StackMap locals: org.eclipse.core.internal.runtime.PerformanceStatsProcessor org.eclipse.core.runtime.IProgressMonitor top top top org.eclipse.core.internal.runtime.PerformanceStatsProcessor
StackMap stack: java.lang.Throwable
8: aload 5
monitorexit
9: athrow
start local 2 start local 3 start local 4 10: StackMap locals: org.eclipse.core.internal.runtime.PerformanceStatsProcessor org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.runtime.PerformanceStats[] org.eclipse.core.runtime.PerformanceStats[] java.lang.Long[]
StackMap stack:
aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.listeners:Lorg/eclipse/core/runtime/ListenerList;
invokevirtual org.eclipse.core.runtime.ListenerList.iterator:()Ljava/util/Iterator;
astore 6
goto 19
StackMap locals: org.eclipse.core.internal.runtime.PerformanceStatsProcessor org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.runtime.PerformanceStats[] org.eclipse.core.runtime.PerformanceStats[] java.lang.Long[] top java.util.Iterator
StackMap stack:
11: aload 6
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.eclipse.core.runtime.PerformanceStats$PerformanceListener
astore 5
start local 5 12: aload 2
arraylength
ifle 14
13: aload 5
aload 2
invokevirtual org.eclipse.core.runtime.PerformanceStats$PerformanceListener.eventsOccurred:([Lorg/eclipse/core/runtime/PerformanceStats;)V
14: StackMap locals: org.eclipse.core.internal.runtime.PerformanceStatsProcessor org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.runtime.PerformanceStats[] org.eclipse.core.runtime.PerformanceStats[] java.lang.Long[] org.eclipse.core.runtime.PerformanceStats$PerformanceListener java.util.Iterator
StackMap stack:
iconst_0
istore 7
start local 7 15: goto 18
16: StackMap locals: int
StackMap stack:
aload 5
aload 3
iload 7
aaload
aload 4
iload 7
aaload
invokevirtual java.lang.Long.longValue:()J
invokevirtual org.eclipse.core.runtime.PerformanceStats$PerformanceListener.eventFailed:(Lorg/eclipse/core/runtime/PerformanceStats;J)V
17: iinc 7 1
StackMap locals:
StackMap stack:
18: iload 7
aload 3
arraylength
if_icmplt 16
end local 7 end local 5 19: StackMap locals: org.eclipse.core.internal.runtime.PerformanceStatsProcessor org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.runtime.PerformanceStats[] org.eclipse.core.runtime.PerformanceStats[] java.lang.Long[] top java.util.Iterator
StackMap stack:
aload 6
invokeinterface java.util.Iterator.hasNext:()Z
ifne 11
20: aload 0
ldc 2000
invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.schedule:(J)V
21: getstatic org.eclipse.core.runtime.Status.OK_STATUS:Lorg/eclipse/core/runtime/IStatus;
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 22 0 this Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
0 22 1 monitor Lorg/eclipse/core/runtime/IProgressMonitor;
2 8 2 events [Lorg/eclipse/core/runtime/PerformanceStats;
10 22 2 events [Lorg/eclipse/core/runtime/PerformanceStats;
4 8 3 failedEvents [Lorg/eclipse/core/runtime/PerformanceStats;
10 22 3 failedEvents [Lorg/eclipse/core/runtime/PerformanceStats;
5 8 4 failedTimes [Ljava/lang/Long;
10 22 4 failedTimes [Ljava/lang/Long;
12 19 5 listener Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;
15 19 7 j I
Exception table:
from to target type
1 7 8 any
8 9 8 any
MethodParameters:
Name Flags
monitor
public boolean shouldRun();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
invokevirtual java.util.ArrayList.isEmpty:()Z
ifeq 1
aload 0
getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
invokevirtual java.util.HashMap.isEmpty:()Z
ifeq 1
iconst_0
ireturn
StackMap locals:
StackMap stack:
1: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
}
SourceFile: "PerformanceStatsProcessor.java"
InnerClasses:
public abstract PerformanceListener = org.eclipse.core.runtime.PerformanceStats$PerformanceListener of org.eclipse.core.runtime.PerformanceStats