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: .line 32
            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: .line 34
            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 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
         0: .line 58
            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 /* listener */
            invokevirtual org.eclipse.core.runtime.ListenerList.add:(Ljava/lang/Object;)V
         1: .line 59
            return
        end local 0 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
      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 // org.eclipse.core.runtime.PerformanceStats stats
         0: .line 67
            getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
            dup
            astore 1
            monitorenter
         1: .line 68
            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 /* stats */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
         2: .line 67
            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: .line 70
      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: .line 71
            return
        end local 0 // org.eclipse.core.runtime.PerformanceStats stats
      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 // org.eclipse.core.runtime.PerformanceStats stats
        start local 1 // java.lang.String pluginId
        start local 2 // long elapsed
         0: .line 82
            getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
            dup
            astore 4
            monitorenter
         1: .line 83
            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 /* stats */
            lload 2 /* elapsed */
            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: .line 82
            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: .line 85
      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: .line 86
            getstatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.instance:Lorg/eclipse/core/internal/runtime/PerformanceStatsProcessor;
            aload 0 /* stats */
            aload 1 /* pluginId */
            lload 2 /* elapsed */
            invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.logFailure:(Lorg/eclipse/core/runtime/PerformanceStats;Ljava/lang/String;J)V
         8: .line 87
            return
        end local 2 // long elapsed
        end local 1 // java.lang.String pluginId
        end local 0 // org.eclipse.core.runtime.PerformanceStats stats
      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 // java.io.PrintWriter out
         0: .line 94
            lconst_0
            lstore 1 /* totalTime */
        start local 1 // long totalTime
         1: .line 95
            iconst_0
            istore 3 /* totalCount */
        start local 3 // int totalCount
         2: .line 96
            invokestatic org.eclipse.core.runtime.PerformanceStats.getAllStats:()[Lorg/eclipse/core/runtime/PerformanceStats;
            astore 4 /* allStats */
        start local 4 // org.eclipse.core.runtime.PerformanceStats[] allStats
         3: .line 97
            aload 4 /* allStats */
            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 /* stats */
        start local 5 // org.eclipse.core.runtime.PerformanceStats stats
         5: .line 98
            lload 1 /* totalTime */
            aload 5 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getRunningTime:()J
            ladd
            lstore 1 /* totalTime */
         6: .line 99
            iload 3 /* totalCount */
            aload 5 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getRunCount:()I
            iadd
            istore 3 /* totalCount */
        end local 5 // org.eclipse.core.runtime.PerformanceStats stats
         7: .line 97
            iinc 6 1
      StackMap locals:
      StackMap stack:
         8: iload 6
            iload 7
            if_icmplt 4
         9: .line 102
            aload 0 /* out */
            ldc "---------------------------------------------------------------"
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
        10: .line 103
            aload 4 /* allStats */
            dup
            astore 8
            arraylength
            istore 7
            iconst_0
            istore 6
            goto 36
      StackMap locals:
      StackMap stack:
        11: aload 8
            iload 6
            aaload
            astore 5 /* stats */
        start local 5 // org.eclipse.core.runtime.PerformanceStats stats
        12: .line 104
            aload 0 /* out */
            ldc "Event: "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        13: .line 105
            aload 0 /* out */
            aload 5 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getEvent:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        14: .line 106
            aload 0 /* out */
            ldc " Blame: "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        15: .line 107
            aload 0 /* out */
            aload 5 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getBlameString:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        16: .line 108
            aload 5 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getContext:()Ljava/lang/String;
            ifnull 19
        17: .line 109
            aload 0 /* out */
            ldc " Context: "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        18: .line 110
            aload 0 /* out */
            aload 5 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getContext:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        19: .line 112
      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 /* out */
            invokevirtual java.io.PrintWriter.println:()V
        20: .line 114
            aload 5 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getRunCount:()I
            istore 9 /* runCount */
        start local 9 // int runCount
        21: .line 115
            iload 9 /* runCount */
            ifle 27
        22: .line 116
            aload 0 /* out */
            ldc "Run count: "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        23: .line 117
            aload 0 /* out */
            iload 9 /* runCount */
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        24: .line 118
            aload 0 /* out */
            ldc " ("
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        25: .line 119
            aload 0 /* out */
            iload 9 /* runCount */
            i2d
            ldc 100.0
            dmul
            iload 3 /* totalCount */
            i2d
            ddiv
            d2i
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        26: .line 120
            aload 0 /* out */
            ldc " % of total)"
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
        27: .line 123
      StackMap locals: int
      StackMap stack:
            aload 5 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getRunningTime:()J
            lstore 10 /* runTime */
        start local 10 // long runTime
        28: .line 124
            lload 10 /* runTime */
            lconst_0
            lcmp
            ifle 34
        29: .line 125
            aload 0 /* out */
            ldc "Duration (ms): "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        30: .line 126
            aload 0 /* out */
            lload 10 /* runTime */
            invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        31: .line 127
            aload 0 /* out */
            ldc " ("
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        32: .line 128
            aload 0 /* out */
            lload 10 /* runTime */
            l2d
            ldc 100.0
            dmul
            lload 1 /* totalTime */
            l2d
            ddiv
            d2i
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        33: .line 129
            aload 0 /* out */
            ldc " % of total)"
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
        34: .line 131
      StackMap locals: long
      StackMap stack:
            aload 0 /* out */
            ldc ""
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
        end local 10 // long runTime
        end local 9 // int runCount
        end local 5 // org.eclipse.core.runtime.PerformanceStats stats
        35: .line 103
            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: .line 133
            return
        end local 4 // org.eclipse.core.runtime.PerformanceStats[] allStats
        end local 3 // int totalCount
        end local 1 // long totalTime
        end local 0 // java.io.PrintWriter out
      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 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
         0: .line 139
            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 /* listener */
            invokevirtual org.eclipse.core.runtime.ListenerList.remove:(Ljava/lang/Object;)V
         1: .line 140
            return
        end local 0 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
      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 // org.eclipse.core.internal.runtime.PerformanceStatsProcessor this
         0: .line 146
            aload 0 /* this */
            ldc "Performance Stats"
            invokespecial org.eclipse.core.runtime.jobs.Job.<init>:(Ljava/lang/String;)V
         1: .line 39
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
         2: .line 45
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
         3: .line 50
            aload 0 /* this */
            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: .line 147
            aload 0 /* this */
            iconst_1
            invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.setSystem:(Z)V
         5: .line 148
            aload 0 /* this */
            bipush 50
            invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.setPriority:(I)V
         6: .line 149
            invokestatic org.eclipse.core.internal.runtime.PlatformActivator.getContext:()Lorg/osgi/framework/BundleContext;
            astore 1 /* context */
        start local 1 // org.osgi.framework.BundleContext context
         7: .line 150
            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 /* filter */
        start local 2 // java.lang.String filter
         8: .line 152
            aconst_null
            astore 4 /* perfLog */
        start local 4 // org.eclipse.osgi.framework.log.FrameworkLog perfLog
         9: .line 154
            aload 1 /* context */
            ldc Lorg/eclipse/osgi/framework/log/FrameworkLog;
            aload 2 /* filter */
            invokeinterface org.osgi.framework.BundleContext.getServiceReferences:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/Collection;
            astore 3 /* references */
        start local 3 // java.util.Collection references
        10: .line 155
            aload 3 /* references */
            ifnull 19
            aload 3 /* references */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 19
        11: .line 157
            aload 1 /* context */
            aload 3 /* references */
            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 /* perfLog */
        12: .line 159
            invokestatic org.eclipse.core.runtime.Platform.getLogFileLocation:()Lorg/eclipse/core/runtime/IPath;
            astore 5 /* logLocation */
        start local 5 // org.eclipse.core.runtime.IPath logLocation
        13: .line 160
            aload 5 /* logLocation */
            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 /* logLocation */
        14: .line 161
            aload 4 /* perfLog */
            aload 5 /* logLocation */
            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 // org.eclipse.core.runtime.IPath logLocation
        15: .line 163
            goto 19
        end local 3 // java.util.Collection references
      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 /* e */
        start local 5 // java.lang.Exception e
        17: .line 164
            new org.eclipse.core.runtime.Status
            dup
            iconst_4
            ldc "org.eclipse.core.runtime"
            iconst_1
            ldc "Error loading performance log"
            aload 5 /* e */
            invokespecial org.eclipse.core.runtime.Status.<init>:(ILjava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
            astore 6 /* error */
        start local 6 // org.eclipse.core.runtime.IStatus error
        18: .line 165
            aload 6 /* error */
            invokestatic org.eclipse.core.internal.runtime.RuntimeLog.log:(Lorg/eclipse/core/runtime/IStatus;)V
        end local 6 // org.eclipse.core.runtime.IStatus error
        end local 5 // java.lang.Exception e
        19: .line 168
      StackMap locals:
      StackMap stack:
            aload 4 /* perfLog */
            ifnonnull 21
        20: .line 169
            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 /* perfLog */
        21: .line 170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 4 /* perfLog */
            putfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.log:Lorg/eclipse/osgi/framework/log/FrameworkLog;
        22: .line 171
            return
        end local 4 // org.eclipse.osgi.framework.log.FrameworkLog perfLog
        end local 2 // java.lang.String filter
        end local 1 // org.osgi.framework.BundleContext context
        end local 0 // org.eclipse.core.internal.runtime.PerformanceStatsProcessor this
      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 // org.eclipse.core.internal.runtime.PerformanceStatsProcessor this
        start local 1 // org.eclipse.core.runtime.PerformanceStats stats
        start local 2 // java.lang.String pluginId
        start local 3 // long elapsed
         0: .line 178
            aload 0 /* this */
            getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.log:Lorg/eclipse/osgi/framework/log/FrameworkLog;
            ifnonnull 2
         1: .line 179
            return
         2: .line 180
      StackMap locals:
      StackMap stack:
            aload 2 /* pluginId */
            ifnonnull 4
         3: .line 181
            ldc "org.eclipse.core.runtime"
            astore 2 /* pluginId */
         4: .line 182
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            ldc "Performance failure: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* stats */
            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 /* stats */
            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 /* stats */
            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 /* elapsed */
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 5 /* msg */
        start local 5 // java.lang.String msg
         5: .line 183
            new org.eclipse.core.runtime.Status
            dup
            iconst_2
            aload 2 /* pluginId */
            iconst_1
            aload 5 /* msg */
            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 /* status */
        start local 6 // org.eclipse.core.runtime.Status status
         6: .line 184
            aload 0 /* this */
            getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.log:Lorg/eclipse/osgi/framework/log/FrameworkLog;
            new org.eclipse.osgi.framework.log.FrameworkLogEntry
            dup
            aload 6 /* status */
            aload 6 /* status */
            invokevirtual org.eclipse.core.runtime.Status.getPlugin:()Ljava/lang/String;
            aload 6 /* status */
            invokevirtual org.eclipse.core.runtime.Status.getSeverity:()I
            aload 6 /* status */
            invokevirtual org.eclipse.core.runtime.Status.getCode:()I
            aload 6 /* status */
            invokevirtual org.eclipse.core.runtime.Status.getMessage:()Ljava/lang/String;
            iconst_0
            aload 6 /* status */
            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: .line 186
            return
        end local 6 // org.eclipse.core.runtime.Status status
        end local 5 // java.lang.String msg
        end local 3 // long elapsed
        end local 2 // java.lang.String pluginId
        end local 1 // org.eclipse.core.runtime.PerformanceStats stats
        end local 0 // org.eclipse.core.internal.runtime.PerformanceStatsProcessor this
      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 // org.eclipse.core.internal.runtime.PerformanceStatsProcessor this
        start local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
         0: .line 196
            aload 0 /* this */
            dup
            astore 5
            monitorenter
         1: .line 197
            aload 0 /* this */
            getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
            aload 0 /* this */
            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 /* events */
        start local 2 // org.eclipse.core.runtime.PerformanceStats[] events
         2: .line 198
            aload 0 /* this */
            getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
         3: .line 199
            aload 0 /* this */
            getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
            invokevirtual java.util.HashMap.keySet:()Ljava/util/Set;
            aload 0 /* this */
            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 /* failedEvents */
        start local 3 // org.eclipse.core.runtime.PerformanceStats[] failedEvents
         4: .line 200
            aload 0 /* this */
            getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
            invokevirtual java.util.HashMap.values:()Ljava/util/Collection;
            aload 0 /* this */
            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 /* failedTimes */
        start local 4 // java.lang.Long[] failedTimes
         5: .line 201
            aload 0 /* this */
            getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failures:Ljava/util/HashMap;
            invokevirtual java.util.HashMap.clear:()V
         6: .line 196
            aload 5
            monitorexit
         7: goto 10
        end local 4 // java.lang.Long[] failedTimes
        end local 3 // org.eclipse.core.runtime.PerformanceStats[] failedEvents
        end local 2 // org.eclipse.core.runtime.PerformanceStats[] events
      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 // org.eclipse.core.runtime.PerformanceStats[] events
        start local 3 // org.eclipse.core.runtime.PerformanceStats[] failedEvents
        start local 4 // java.lang.Long[] failedTimes
        10: .line 205
      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 /* this */
            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 /* listener */
        start local 5 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
        12: .line 206
            aload 2 /* events */
            arraylength
            ifle 14
        13: .line 207
            aload 5 /* listener */
            aload 2 /* events */
            invokevirtual org.eclipse.core.runtime.PerformanceStats$PerformanceListener.eventsOccurred:([Lorg/eclipse/core/runtime/PerformanceStats;)V
        14: .line 208
      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 /* j */
        start local 7 // int j
        15: goto 18
        16: .line 209
      StackMap locals: int
      StackMap stack:
            aload 5 /* listener */
            aload 3 /* failedEvents */
            iload 7 /* j */
            aaload
            aload 4 /* failedTimes */
            iload 7 /* j */
            aaload
            invokevirtual java.lang.Long.longValue:()J
            invokevirtual org.eclipse.core.runtime.PerformanceStats$PerformanceListener.eventFailed:(Lorg/eclipse/core/runtime/PerformanceStats;J)V
        17: .line 208
            iinc 7 /* j */ 1
      StackMap locals:
      StackMap stack:
        18: iload 7 /* j */
            aload 3 /* failedEvents */
            arraylength
            if_icmplt 16
        end local 7 // int j
        end local 5 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
        19: .line 205
      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: .line 211
            aload 0 /* this */
            ldc 2000
            invokevirtual org.eclipse.core.internal.runtime.PerformanceStatsProcessor.schedule:(J)V
        21: .line 212
            getstatic org.eclipse.core.runtime.Status.OK_STATUS:Lorg/eclipse/core/runtime/IStatus;
            areturn
        end local 4 // java.lang.Long[] failedTimes
        end local 3 // org.eclipse.core.runtime.PerformanceStats[] failedEvents
        end local 2 // org.eclipse.core.runtime.PerformanceStats[] events
        end local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
        end local 0 // org.eclipse.core.internal.runtime.PerformanceStatsProcessor this
      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 // org.eclipse.core.internal.runtime.PerformanceStatsProcessor this
         0: .line 220
            aload 0 /* this */
            getfield org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changes:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.isEmpty:()Z
            ifeq 1
            aload 0 /* this */
            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 // org.eclipse.core.internal.runtime.PerformanceStatsProcessor this
      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