public class org.eclipse.core.runtime.PerformanceStats
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.eclipse.core.runtime.PerformanceStats
  super_class: java.lang.Object
{
  private static final org.eclipse.core.runtime.PerformanceStats EMPTY_STATS;
    descriptor: Lorg/eclipse/core/runtime/PerformanceStats;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  public static final boolean ENABLED;
    descriptor: Z
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  private static final long NOT_STARTED;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -1

  private static final java.util.Map<org.eclipse.core.runtime.PerformanceStats, org.eclipse.core.runtime.PerformanceStats> statMap;
    descriptor: Ljava/util/Map;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Map<Lorg/eclipse/core/runtime/PerformanceStats;Lorg/eclipse/core/runtime/PerformanceStats;>;

  private static final java.util.Map<java.lang.String, java.lang.Long> thresholdMap;
    descriptor: Ljava/util/Map;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  private static final boolean TRACE_SUCCESS;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private java.lang.String blame;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String blamePluginId;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String context;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

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

  private java.lang.String event;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private boolean isFailure;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

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

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 96
            new org.eclipse.core.runtime.PerformanceStats
            dup
            ldc ""
            ldc ""
            invokespecial org.eclipse.core.runtime.PerformanceStats.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
            putstatic org.eclipse.core.runtime.PerformanceStats.EMPTY_STATS:Lorg/eclipse/core/runtime/PerformanceStats;
         1: .line 112
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            invokestatic java.util.Collections.synchronizedMap:(Ljava/util/Map;)Ljava/util/Map;
         2: .line 111
            putstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
         3: .line 118
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            invokestatic java.util.Collections.synchronizedMap:(Ljava/util/Map;)Ljava/util/Map;
            putstatic org.eclipse.core.runtime.PerformanceStats.thresholdMap:Ljava/util/Map;
         4: .line 172
            invokestatic org.eclipse.core.internal.runtime.InternalPlatform.getDefault:()Lorg/eclipse/core/internal/runtime/InternalPlatform;
            ldc "org.eclipse.core.runtime/perf"
            iconst_0
            invokevirtual org.eclipse.core.internal.runtime.InternalPlatform.getBooleanOption:(Ljava/lang/String;Z)Z
            putstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
         5: .line 174
            invokestatic org.eclipse.core.internal.runtime.InternalPlatform.getDefault:()Lorg/eclipse/core/internal/runtime/InternalPlatform;
            ldc "org.eclipse.core.runtime/perf/success"
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            invokevirtual org.eclipse.core.internal.runtime.InternalPlatform.getBooleanOption:(Ljava/lang/String;Z)Z
            putstatic org.eclipse.core.runtime.PerformanceStats.TRACE_SUCCESS:Z
         6: .line 175
            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=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
         0: .line 185
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifeq 2
         1: .line 186
            aload 0 /* listener */
            invokestatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.addListener:(Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;)V
         2: .line 187
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0  listener  Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;
    MethodParameters:
          Name  Flags
      listener  

  public static void clear();
    descriptor: ()V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 193
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         1: .line 194
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static org.eclipse.core.runtime.PerformanceStats[] getAllStats();
    descriptor: ()[Lorg/eclipse/core/runtime/PerformanceStats;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 203
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.size:()I
            anewarray org.eclipse.core.runtime.PerformanceStats
            invokeinterface java.util.Collection.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast org.eclipse.core.runtime.PerformanceStats[]
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static org.eclipse.core.runtime.PerformanceStats getStats(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)Lorg/eclipse/core/runtime/PerformanceStats;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // java.lang.String eventName
        start local 1 // java.lang.Object blameObject
         0: .line 220
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifeq 1
            aload 0 /* eventName */
            ifnull 1
            aload 1 /* blameObject */
            ifnonnull 2
         1: .line 221
      StackMap locals:
      StackMap stack:
            getstatic org.eclipse.core.runtime.PerformanceStats.EMPTY_STATS:Lorg/eclipse/core/runtime/PerformanceStats;
            areturn
         2: .line 222
      StackMap locals:
      StackMap stack:
            new org.eclipse.core.runtime.PerformanceStats
            dup
            aload 0 /* eventName */
            aload 1 /* blameObject */
            invokespecial org.eclipse.core.runtime.PerformanceStats.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
            astore 2 /* newStats */
        start local 2 // org.eclipse.core.runtime.PerformanceStats newStats
         3: .line 223
            getstatic org.eclipse.core.runtime.PerformanceStats.TRACE_SUCCESS:Z
            ifne 5
         4: .line 224
            aload 2 /* newStats */
            areturn
         5: .line 226
      StackMap locals: org.eclipse.core.runtime.PerformanceStats
      StackMap stack:
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            aload 2 /* newStats */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.eclipse.core.runtime.PerformanceStats
            astore 3 /* oldStats */
        start local 3 // org.eclipse.core.runtime.PerformanceStats oldStats
         6: .line 227
            aload 3 /* oldStats */
            ifnull 8
         7: .line 228
            aload 3 /* oldStats */
            areturn
         8: .line 229
      StackMap locals: org.eclipse.core.runtime.PerformanceStats
      StackMap stack:
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            aload 2 /* newStats */
            aload 2 /* newStats */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         9: .line 230
            aload 2 /* newStats */
            areturn
        end local 3 // org.eclipse.core.runtime.PerformanceStats oldStats
        end local 2 // org.eclipse.core.runtime.PerformanceStats newStats
        end local 1 // java.lang.Object blameObject
        end local 0 // java.lang.String eventName
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   10     0    eventName  Ljava/lang/String;
            0   10     1  blameObject  Ljava/lang/Object;
            3   10     2     newStats  Lorg/eclipse/core/runtime/PerformanceStats;
            6   10     3     oldStats  Lorg/eclipse/core/runtime/PerformanceStats;
    MethodParameters:
             Name  Flags
      eventName    
      blameObject  

  public static boolean isEnabled(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.lang.String eventName
         0: .line 247
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifne 2
         1: .line 248
            iconst_0
            ireturn
         2: .line 249
      StackMap locals:
      StackMap stack:
            aload 0 /* eventName */
            invokestatic org.eclipse.core.runtime.Platform.getDebugOption:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* option */
        start local 1 // java.lang.String option
         3: .line 250
            aload 1 /* option */
            ifnull 4
            aload 1 /* option */
            ldc "false"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 4
            aload 1 /* option */
            ldc "-1"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 4
            iconst_1
            ireturn
      StackMap locals: java.lang.String
      StackMap stack:
         4: iconst_0
            ireturn
        end local 1 // java.lang.String option
        end local 0 // java.lang.String eventName
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    5     0  eventName  Ljava/lang/String;
            3    5     1     option  Ljava/lang/String;
    MethodParameters:
           Name  Flags
      eventName  

  public static void printStats();
    descriptor: ()V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 257
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifne 2
         1: .line 258
            return
         2: .line 259
      StackMap locals:
      StackMap stack:
            new java.io.PrintWriter
            dup
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokespecial java.io.PrintWriter.<init>:(Ljava/io/OutputStream;)V
            astore 0 /* writer */
        start local 0 // java.io.PrintWriter writer
         3: .line 260
            aload 0 /* writer */
            invokestatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.printStats:(Ljava/io/PrintWriter;)V
         4: .line 261
            aload 0 /* writer */
            invokevirtual java.io.PrintWriter.flush:()V
         5: .line 262
            return
        end local 0 // java.io.PrintWriter writer
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            3    6     0  writer  Ljava/io/PrintWriter;

  public static void printStats(java.io.PrintWriter);
    descriptor: (Ljava/io/PrintWriter;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.io.PrintWriter out
         0: .line 270
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifne 2
         1: .line 271
            return
         2: .line 272
      StackMap locals:
      StackMap stack:
            aload 0 /* out */
            invokestatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.printStats:(Ljava/io/PrintWriter;)V
         3: .line 273
            return
        end local 0 // java.io.PrintWriter out
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0   out  Ljava/io/PrintWriter;
    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=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
         0: .line 283
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifeq 2
         1: .line 284
            aload 0 /* listener */
            invokestatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.removeListener:(Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;)V
         2: .line 285
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.eclipse.core.runtime.PerformanceStats$PerformanceListener listener
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0  listener  Lorg/eclipse/core/runtime/PerformanceStats$PerformanceListener;
    MethodParameters:
          Name  Flags
      listener  

  public static void removeStats(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // java.lang.String eventName
        start local 1 // java.lang.Object blameObject
         0: .line 294
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            dup
            astore 2
            monitorenter
         1: .line 295
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3 /* it */
        start local 3 // java.util.Iterator it
         2: goto 6
         3: .line 296
      StackMap locals: java.util.Map java.util.Iterator
      StackMap stack:
            aload 3 /* it */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.eclipse.core.runtime.PerformanceStats
            astore 4 /* stats */
        start local 4 // org.eclipse.core.runtime.PerformanceStats stats
         4: .line 297
            aload 4 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getEvent:()Ljava/lang/String;
            aload 0 /* eventName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 6
            aload 4 /* stats */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getBlame:()Ljava/lang/Object;
            aload 1 /* blameObject */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 6
         5: .line 298
            aload 3 /* it */
            invokeinterface java.util.Iterator.remove:()V
        end local 4 // org.eclipse.core.runtime.PerformanceStats stats
         6: .line 295
      StackMap locals:
      StackMap stack:
            aload 3 /* it */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        end local 3 // java.util.Iterator it
         7: .line 294
            aload 2
            monitorexit
         8: goto 11
      StackMap locals: java.lang.String java.lang.Object java.util.Map
      StackMap stack: java.lang.Throwable
         9: aload 2
            monitorexit
        10: athrow
        11: .line 301
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object blameObject
        end local 0 // java.lang.String eventName
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   12     0    eventName  Ljava/lang/String;
            0   12     1  blameObject  Ljava/lang/Object;
            2    7     3           it  Ljava/util/Iterator<Lorg/eclipse/core/runtime/PerformanceStats;>;
            4    6     4        stats  Lorg/eclipse/core/runtime/PerformanceStats;
      Exception table:
        from    to  target  type
           1     8       9  any
           9    10       9  any
    MethodParameters:
             Name  Flags
      eventName    
      blameObject  

  private void <init>(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
        start local 1 // java.lang.String event
        start local 2 // java.lang.Object blame
         0: .line 307
            aload 0 /* this */
            aload 1 /* event */
            aload 2 /* blame */
            aconst_null
            invokespecial org.eclipse.core.runtime.PerformanceStats.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;)V
         1: .line 308
            return
        end local 2 // java.lang.Object blame
        end local 1 // java.lang.String event
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lorg/eclipse/core/runtime/PerformanceStats;
            0    2     1  event  Ljava/lang/String;
            0    2     2  blame  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      event  
      blame  

  private void <init>(java.lang.String, java.lang.Object, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
        start local 1 // java.lang.String event
        start local 2 // java.lang.Object blameObject
        start local 3 // java.lang.String context
         0: .line 313
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 148
            aload 0 /* this */
            ldc -1
            putfield org.eclipse.core.runtime.PerformanceStats.currentStart:J
         2: .line 164
            aload 0 /* this */
            iconst_0
            putfield org.eclipse.core.runtime.PerformanceStats.runCount:I
         3: .line 169
            aload 0 /* this */
            lconst_0
            putfield org.eclipse.core.runtime.PerformanceStats.runningTime:J
         4: .line 314
            aload 0 /* this */
            aload 1 /* event */
            putfield org.eclipse.core.runtime.PerformanceStats.event:Ljava/lang/String;
         5: .line 315
            aload 0 /* this */
            aload 2 /* blameObject */
            instanceof java.lang.String
            ifeq 6
            aload 2 /* blameObject */
            checkcast java.lang.String
            goto 7
      StackMap locals: org.eclipse.core.runtime.PerformanceStats java.lang.String java.lang.Object java.lang.String
      StackMap stack: org.eclipse.core.runtime.PerformanceStats
         6: aload 2 /* blameObject */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
      StackMap locals: org.eclipse.core.runtime.PerformanceStats java.lang.String java.lang.Object java.lang.String
      StackMap stack: org.eclipse.core.runtime.PerformanceStats java.lang.String
         7: putfield org.eclipse.core.runtime.PerformanceStats.blame:Ljava/lang/String;
         8: .line 316
            aload 0 /* this */
            invokestatic org.eclipse.core.internal.runtime.InternalPlatform.getDefault:()Lorg/eclipse/core/internal/runtime/InternalPlatform;
            aload 2 /* blameObject */
            invokevirtual org.eclipse.core.internal.runtime.InternalPlatform.getBundleId:(Ljava/lang/Object;)Ljava/lang/String;
            putfield org.eclipse.core.runtime.PerformanceStats.blamePluginId:Ljava/lang/String;
         9: .line 317
            aload 0 /* this */
            aload 3 /* context */
            putfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
        10: .line 318
            return
        end local 3 // java.lang.String context
        end local 2 // java.lang.Object blameObject
        end local 1 // java.lang.String event
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   11     0         this  Lorg/eclipse/core/runtime/PerformanceStats;
            0   11     1        event  Ljava/lang/String;
            0   11     2  blameObject  Ljava/lang/Object;
            0   11     3      context  Ljava/lang/String;
    MethodParameters:
             Name  Flags
      event        
      blameObject  
      context      

  public void addRun(long, java.lang.String);
    descriptor: (JLjava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
        start local 1 // long elapsed
        start local 3 // java.lang.String contextName
         0: .line 331
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifne 2
         1: .line 332
            return
         2: .line 333
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.eclipse.core.runtime.PerformanceStats.runCount:I
            iconst_1
            iadd
            putfield org.eclipse.core.runtime.PerformanceStats.runCount:I
         3: .line 334
            aload 0 /* this */
            dup
            getfield org.eclipse.core.runtime.PerformanceStats.runningTime:J
            lload 1 /* elapsed */
            ladd
            putfield org.eclipse.core.runtime.PerformanceStats.runningTime:J
         4: .line 335
            lload 1 /* elapsed */
            aload 0 /* this */
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.event:Ljava/lang/String;
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getThreshold:(Ljava/lang/String;)J
            lcmp
            ifle 6
         5: .line 336
            aload 0 /* this */
            aload 3 /* contextName */
            lload 1 /* elapsed */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.createFailureStats:(Ljava/lang/String;J)Lorg/eclipse/core/runtime/PerformanceStats;
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.blamePluginId:Ljava/lang/String;
            lload 1 /* elapsed */
            invokestatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.failed:(Lorg/eclipse/core/runtime/PerformanceStats;Ljava/lang/String;J)V
         6: .line 337
      StackMap locals:
      StackMap stack:
            getstatic org.eclipse.core.runtime.PerformanceStats.TRACE_SUCCESS:Z
            ifeq 8
         7: .line 338
            aload 0 /* this */
            invokestatic org.eclipse.core.internal.runtime.PerformanceStatsProcessor.changed:(Lorg/eclipse/core/runtime/PerformanceStats;)V
         8: .line 339
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.String contextName
        end local 1 // long elapsed
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    9     0         this  Lorg/eclipse/core/runtime/PerformanceStats;
            0    9     1      elapsed  J
            0    9     3  contextName  Ljava/lang/String;
    MethodParameters:
             Name  Flags
      elapsed      
      contextName  

  private org.eclipse.core.runtime.PerformanceStats createFailureStats(java.lang.String, long);
    descriptor: (Ljava/lang/String;J)Lorg/eclipse/core/runtime/PerformanceStats;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
        start local 1 // java.lang.String contextName
        start local 2 // long elapsed
         0: .line 349
            new org.eclipse.core.runtime.PerformanceStats
            dup
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.event:Ljava/lang/String;
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.blame:Ljava/lang/String;
            aload 1 /* contextName */
            invokespecial org.eclipse.core.runtime.PerformanceStats.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;)V
            astore 4 /* failedStat */
        start local 4 // org.eclipse.core.runtime.PerformanceStats failedStat
         1: .line 350
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            aload 4 /* failedStat */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.eclipse.core.runtime.PerformanceStats
            astore 5 /* old */
        start local 5 // org.eclipse.core.runtime.PerformanceStats old
         2: .line 351
            aload 5 /* old */
            ifnonnull 4
         3: .line 352
            getstatic org.eclipse.core.runtime.PerformanceStats.statMap:Ljava/util/Map;
            aload 4 /* failedStat */
            aload 4 /* failedStat */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
            goto 5
         4: .line 354
      StackMap locals: org.eclipse.core.runtime.PerformanceStats org.eclipse.core.runtime.PerformanceStats
      StackMap stack:
            aload 5 /* old */
            astore 4 /* failedStat */
         5: .line 355
      StackMap locals:
      StackMap stack:
            aload 4 /* failedStat */
            iconst_1
            putfield org.eclipse.core.runtime.PerformanceStats.isFailure:Z
         6: .line 356
            aload 4 /* failedStat */
            dup
            getfield org.eclipse.core.runtime.PerformanceStats.runCount:I
            iconst_1
            iadd
            putfield org.eclipse.core.runtime.PerformanceStats.runCount:I
         7: .line 357
            aload 4 /* failedStat */
            dup
            getfield org.eclipse.core.runtime.PerformanceStats.runningTime:J
            lload 2 /* elapsed */
            ladd
            putfield org.eclipse.core.runtime.PerformanceStats.runningTime:J
         8: .line 358
            aload 4 /* failedStat */
            areturn
        end local 5 // org.eclipse.core.runtime.PerformanceStats old
        end local 4 // org.eclipse.core.runtime.PerformanceStats failedStat
        end local 2 // long elapsed
        end local 1 // java.lang.String contextName
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    9     0         this  Lorg/eclipse/core/runtime/PerformanceStats;
            0    9     1  contextName  Ljava/lang/String;
            0    9     2      elapsed  J
            1    9     4   failedStat  Lorg/eclipse/core/runtime/PerformanceStats;
            2    9     5          old  Lorg/eclipse/core/runtime/PerformanceStats;
    MethodParameters:
             Name  Flags
      contextName  
      elapsed      

  public void endRun();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 374
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifeq 1
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.currentStart:J
            ldc -1
            lcmp
            ifne 2
         1: .line 375
      StackMap locals:
      StackMap stack:
            return
         2: .line 376
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokestatic java.lang.System.currentTimeMillis:()J
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.currentStart:J
            lsub
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
            invokevirtual org.eclipse.core.runtime.PerformanceStats.addRun:(JLjava/lang/String;)V
         3: .line 377
            aload 0 /* this */
            ldc -1
            putfield org.eclipse.core.runtime.PerformanceStats.currentStart:J
         4: .line 378
            return
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
        start local 1 // java.lang.Object obj
         0: .line 386
            aload 1 /* obj */
            instanceof org.eclipse.core.runtime.PerformanceStats
            ifne 2
         1: .line 387
            iconst_0
            ireturn
         2: .line 388
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            checkcast org.eclipse.core.runtime.PerformanceStats
            astore 2 /* that */
        start local 2 // org.eclipse.core.runtime.PerformanceStats that
         3: .line 389
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.event:Ljava/lang/String;
            aload 2 /* that */
            getfield org.eclipse.core.runtime.PerformanceStats.event:Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 6
            aload 0 /* this */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getBlameString:()Ljava/lang/String;
            aload 2 /* that */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getBlameString:()Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 6
         4: .line 390
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
            aload 2 /* that */
            getfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
            invokestatic java.util.Objects.equals:(Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 6
         5: .line 389
            iconst_1
            ireturn
      StackMap locals: org.eclipse.core.runtime.PerformanceStats
      StackMap stack:
         6: iconst_0
            ireturn
        end local 2 // org.eclipse.core.runtime.PerformanceStats that
        end local 1 // java.lang.Object obj
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/eclipse/core/runtime/PerformanceStats;
            0    7     1   obj  Ljava/lang/Object;
            3    7     2  that  Lorg/eclipse/core/runtime/PerformanceStats;
    MethodParameters:
      Name  Flags
      obj   

  public java.lang.Object getBlame();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 400
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.blame:Ljava/lang/String;
            areturn
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public java.lang.String getBlameString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 409
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.blame:Ljava/lang/String;
            areturn
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public java.lang.String getContext();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 419
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
            areturn
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public java.lang.String getEvent();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 428
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.event:Ljava/lang/String;
            areturn
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public int getRunCount();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 437
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.runCount:I
            ireturn
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public long getRunningTime();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 447
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.runningTime:J
            lreturn
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  private long getThreshold(java.lang.String);
    descriptor: (Ljava/lang/String;)J
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
        start local 1 // java.lang.String eventName
         0: .line 454
            getstatic org.eclipse.core.runtime.PerformanceStats.thresholdMap:Ljava/util/Map;
            aload 1 /* eventName */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            astore 2 /* value */
        start local 2 // java.lang.Long value
         1: .line 455
            aload 2 /* value */
            ifnonnull 10
         2: .line 456
            invokestatic org.eclipse.core.internal.runtime.InternalPlatform.getDefault:()Lorg/eclipse/core/internal/runtime/InternalPlatform;
            aload 1 /* eventName */
            invokevirtual org.eclipse.core.internal.runtime.InternalPlatform.getOption:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* option */
        start local 3 // java.lang.String option
         3: .line 457
            aload 3 /* option */
            ifnull 7
         4: .line 459
            aload 3 /* option */
            invokestatic java.lang.Long.valueOf:(Ljava/lang/String;)Ljava/lang/Long;
            astore 2 /* value */
         5: .line 460
            goto 7
      StackMap locals: org.eclipse.core.runtime.PerformanceStats java.lang.String java.lang.Long java.lang.String
      StackMap stack: java.lang.NumberFormatException
         6: pop
         7: .line 464
      StackMap locals:
      StackMap stack:
            aload 2 /* value */
            ifnonnull 9
         8: .line 465
            ldc 9223372036854775807
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            astore 2 /* value */
         9: .line 466
      StackMap locals:
      StackMap stack:
            getstatic org.eclipse.core.runtime.PerformanceStats.thresholdMap:Ljava/util/Map;
            aload 1 /* eventName */
            aload 2 /* value */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 3 // java.lang.String option
        10: .line 468
      StackMap locals:
      StackMap stack:
            aload 2 /* value */
            invokevirtual java.lang.Long.longValue:()J
            lreturn
        end local 2 // java.lang.Long value
        end local 1 // java.lang.String eventName
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0       this  Lorg/eclipse/core/runtime/PerformanceStats;
            0   11     1  eventName  Ljava/lang/String;
            1   11     2      value  Ljava/lang/Long;
            3   10     3     option  Ljava/lang/String;
      Exception table:
        from    to  target  type
           4     5       6  Class java.lang.NumberFormatException
    MethodParameters:
           Name  Flags
      eventName  

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 474
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.event:Ljava/lang/String;
            invokevirtual java.lang.String.hashCode:()I
            bipush 37
            imul
            aload 0 /* this */
            invokevirtual org.eclipse.core.runtime.PerformanceStats.getBlameString:()Ljava/lang/String;
            invokevirtual java.lang.String.hashCode:()I
            iadd
            istore 1 /* hash */
        start local 1 // int hash
         1: .line 475
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
            ifnull 3
         2: .line 476
            iload 1 /* hash */
            bipush 37
            imul
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
            invokevirtual java.lang.String.hashCode:()I
            iadd
            istore 1 /* hash */
         3: .line 477
      StackMap locals: int
      StackMap stack:
            iload 1 /* hash */
            ireturn
        end local 1 // int hash
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/eclipse/core/runtime/PerformanceStats;
            1    4     1  hash  I

  public boolean isFailure();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 487
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.isFailure:Z
            ireturn
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 494
            aload 0 /* this */
            lconst_0
            putfield org.eclipse.core.runtime.PerformanceStats.runningTime:J
         1: .line 495
            aload 0 /* this */
            iconst_0
            putfield org.eclipse.core.runtime.PerformanceStats.runCount:I
         2: .line 496
            return
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public void startRun();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 503
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifeq 2
         1: .line 504
            aload 0 /* this */
            aconst_null
            invokevirtual org.eclipse.core.runtime.PerformanceStats.startRun:(Ljava/lang/String;)V
         2: .line 505
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/eclipse/core/runtime/PerformanceStats;

  public void startRun(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
        start local 1 // java.lang.String contextName
         0: .line 517
            getstatic org.eclipse.core.runtime.PerformanceStats.ENABLED:Z
            ifne 2
         1: .line 518
            return
         2: .line 519
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* contextName */
            putfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
         3: .line 520
            aload 0 /* this */
            invokestatic java.lang.System.currentTimeMillis:()J
            putfield org.eclipse.core.runtime.PerformanceStats.currentStart:J
         4: .line 521
            return
        end local 1 // java.lang.String contextName
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Lorg/eclipse/core/runtime/PerformanceStats;
            0    5     1  contextName  Ljava/lang/String;
    MethodParameters:
             Name  Flags
      contextName  

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.eclipse.core.runtime.PerformanceStats this
         0: .line 528
            new java.lang.StringBuilder
            dup
            ldc "PerformanceStats("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 1 /* result */
        start local 1 // java.lang.StringBuilder result
         1: .line 529
            aload 1 /* result */
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.event:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         2: .line 530
            aload 1 /* result */
            bipush 44
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         3: .line 531
            aload 1 /* result */
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.blame:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 532
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
            ifnull 7
         5: .line 533
            aload 1 /* result */
            bipush 44
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         6: .line 534
            aload 1 /* result */
            aload 0 /* this */
            getfield org.eclipse.core.runtime.PerformanceStats.context:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         7: .line 536
      StackMap locals: java.lang.StringBuilder
      StackMap stack:
            aload 1 /* result */
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         8: .line 537
            aload 1 /* result */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder result
        end local 0 // org.eclipse.core.runtime.PerformanceStats this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lorg/eclipse/core/runtime/PerformanceStats;
            1    9     1  result  Ljava/lang/StringBuilder;
}
SourceFile: "PerformanceStats.java"
NestMembers:
  org.eclipse.core.runtime.PerformanceStats$PerformanceListener
InnerClasses:
  public abstract PerformanceListener = org.eclipse.core.runtime.PerformanceStats$PerformanceListener of org.eclipse.core.runtime.PerformanceStats