public abstract class com.oracle.graal.pointsto.BigBang$BucketTiming implements com.oracle.graal.pointsto.util.CompletionExecutor$Timing
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: com.oracle.graal.pointsto.BigBang$BucketTiming
  super_class: java.lang.Object
{
  private static final int NUM_BUCKETS;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 10

  private final java.util.concurrent.atomic.AtomicLong numOperations;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicLong numAdded;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicLong numDone;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicLong numInQueue;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicLong totalTime;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicLongArray timeBuckets;
    descriptor: Ljava/util/concurrent/atomic/AtomicLongArray;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  protected void <init>();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
         0: .line 749
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 752
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield com.oracle.graal.pointsto.BigBang$BucketTiming.numOperations:Ljava/util/concurrent/atomic/AtomicLong;
         2: .line 753
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield com.oracle.graal.pointsto.BigBang$BucketTiming.numAdded:Ljava/util/concurrent/atomic/AtomicLong;
         3: .line 754
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield com.oracle.graal.pointsto.BigBang$BucketTiming.numDone:Ljava/util/concurrent/atomic/AtomicLong;
         4: .line 755
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield com.oracle.graal.pointsto.BigBang$BucketTiming.numInQueue:Ljava/util/concurrent/atomic/AtomicLong;
         5: .line 756
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield com.oracle.graal.pointsto.BigBang$BucketTiming.totalTime:Ljava/util/concurrent/atomic/AtomicLong;
         6: .line 757
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLongArray
            dup
            bipush 10
            invokespecial java.util.concurrent.atomic.AtomicLongArray.<init>:(I)V
            putfield com.oracle.graal.pointsto.BigBang$BucketTiming.timeBuckets:Ljava/util/concurrent/atomic/AtomicLongArray;
         7: .line 749
            return
        end local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lcom/oracle/graal/pointsto/BigBang$BucketTiming;

  public long getPrintIntervalNanos();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
         0: .line 761
            ldc 1000000000
            lreturn
        end local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/graal/pointsto/BigBang$BucketTiming;

  public void addScheduled(com.oracle.graal.pointsto.util.CompletionExecutor$DebugContextRunnable);
    descriptor: (Lcom/oracle/graal/pointsto/util/CompletionExecutor$DebugContextRunnable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
        start local 1 // com.oracle.graal.pointsto.util.CompletionExecutor$DebugContextRunnable r
         0: .line 766
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numOperations:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.incrementAndGet:()J
            pop2
         1: .line 767
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numInQueue:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.incrementAndGet:()J
            pop2
         2: .line 768
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numAdded:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.incrementAndGet:()J
            pop2
         3: .line 769
            return
        end local 1 // com.oracle.graal.pointsto.util.CompletionExecutor$DebugContextRunnable r
        end local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/oracle/graal/pointsto/BigBang$BucketTiming;
            0    4     1     r  Lcom/oracle/graal/pointsto/util/CompletionExecutor$DebugContextRunnable;
    MethodParameters:
      Name  Flags
      r     

  public void addCompleted(com.oracle.graal.pointsto.util.CompletionExecutor$DebugContextRunnable, long);
    descriptor: (Lcom/oracle/graal/pointsto/util/CompletionExecutor$DebugContextRunnable;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=9, args_size=3
        start local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
        start local 1 // com.oracle.graal.pointsto.util.CompletionExecutor$DebugContextRunnable r
        start local 2 // long nanos
         0: .line 773
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numInQueue:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.decrementAndGet:()J
            pop2
         1: .line 774
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numDone:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.incrementAndGet:()J
            pop2
         2: .line 775
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.totalTime:Ljava/util/concurrent/atomic/AtomicLong;
            lload 2 /* nanos */
            invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
            pop2
         3: .line 777
            iconst_0
            istore 4 /* bucket */
        start local 4 // int bucket
         4: .line 778
            lload 2 /* nanos */
            ldc 1000
            ldiv
            lstore 5 /* bucketTime */
        start local 5 // long bucketTime
         5: .line 779
            goto 8
         6: .line 780
      StackMap locals: int long
      StackMap stack:
            lload 5 /* bucketTime */
            ldc 10
            ldiv
            lstore 5 /* bucketTime */
         7: .line 781
            iinc 4 /* bucket */ 1
         8: .line 779
      StackMap locals:
      StackMap stack:
            lload 5 /* bucketTime */
            lconst_0
            lcmp
            ifeq 9
            iload 4 /* bucket */
            bipush 9
            if_icmplt 6
         9: .line 783
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.timeBuckets:Ljava/util/concurrent/atomic/AtomicLongArray;
            iload 4 /* bucket */
            invokevirtual java.util.concurrent.atomic.AtomicLongArray.incrementAndGet:(I)J
            pop2
        10: .line 785
            lload 2 /* nanos */
            ldc 500000000
            lcmp
            ifle 16
            aload 1 /* r */
            instanceof com.oracle.graal.pointsto.BigBang$TypeFlowRunnable
            ifeq 16
        11: .line 786
            aload 1 /* r */
            checkcast com.oracle.graal.pointsto.BigBang$TypeFlowRunnable
            invokeinterface com.oracle.graal.pointsto.BigBang$TypeFlowRunnable.getTypeFlow:()Lcom/oracle/graal/pointsto/flow/TypeFlow;
            astore 7 /* tf */
        start local 7 // com.oracle.graal.pointsto.flow.TypeFlow tf
        12: .line 787
            aload 7 /* tf */
            invokevirtual com.oracle.graal.pointsto.flow.TypeFlow.getSource:()Ljava/lang/Object;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            astore 8 /* source */
        start local 8 // java.lang.String source
        13: .line 788
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "LONG RUNNING  %.2f  %s %x %s  state %s %x  uses %d observers %d%n"
            bipush 8
            anewarray java.lang.Object
            dup
            iconst_0
            lload 2 /* nanos */
            l2d
            ldc 1.0E9
            ddiv
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_1
            aload 7 /* tf */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getSimpleName:()Ljava/lang/String;
            aastore
            dup
            iconst_2
            aload 7 /* tf */
            invokestatic java.lang.System.identityHashCode:(Ljava/lang/Object;)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_3
        14: .line 789
            aload 8 /* source */
            aastore
            dup
            iconst_4
            aload 7 /* tf */
            invokevirtual com.oracle.graal.pointsto.flow.TypeFlow.getState:()Lcom/oracle/graal/pointsto/typestate/TypeState;
            invokestatic com.oracle.graal.pointsto.typestate.PointsToStats.asString:(Lcom/oracle/graal/pointsto/typestate/TypeState;)Ljava/lang/String;
            aastore
            dup
            iconst_5
            aload 7 /* tf */
            invokevirtual com.oracle.graal.pointsto.flow.TypeFlow.getState:()Lcom/oracle/graal/pointsto/typestate/TypeState;
            invokestatic java.lang.System.identityHashCode:(Ljava/lang/Object;)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            bipush 6
            aload 7 /* tf */
            invokevirtual com.oracle.graal.pointsto.flow.TypeFlow.getUses:()Ljava/util/Collection;
            invokeinterface java.util.Collection.size:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            bipush 7
            aload 7 /* tf */
            invokevirtual com.oracle.graal.pointsto.flow.TypeFlow.getObservers:()Ljava/util/Collection;
            invokeinterface java.util.Collection.size:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
        15: .line 788
            invokevirtual java.io.PrintStream.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        end local 8 // java.lang.String source
        end local 7 // com.oracle.graal.pointsto.flow.TypeFlow tf
        16: .line 791
      StackMap locals:
      StackMap stack:
            return
        end local 5 // long bucketTime
        end local 4 // int bucket
        end local 2 // long nanos
        end local 1 // com.oracle.graal.pointsto.util.CompletionExecutor$DebugContextRunnable r
        end local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   17     0        this  Lcom/oracle/graal/pointsto/BigBang$BucketTiming;
            0   17     1           r  Lcom/oracle/graal/pointsto/util/CompletionExecutor$DebugContextRunnable;
            0   17     2       nanos  J
            4   17     4      bucket  I
            5   17     5  bucketTime  J
           12   16     7          tf  Lcom/oracle/graal/pointsto/flow/TypeFlow<*>;
           13   16     8      source  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      r      
      nanos  

  public void printHeader();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
         0: .line 795
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "%9s %6s %6s %6s %10s %8s  %5s %5s %5s %5s %5s %5s %5s %5s %5s %5s  |"
            bipush 16
            anewarray java.lang.Object
            dup
            iconst_0
            ldc "total"
            aastore
            dup
            iconst_1
            ldc "qlen"
            aastore
            dup
            iconst_2
            ldc "added"
            aastore
            dup
            iconst_3
            ldc "done"
            aastore
            dup
            iconst_4
            ldc "total us"
            aastore
            dup
            iconst_5
            ldc "avg us"
            aastore
            dup
            bipush 6
            ldc "<1us"
            aastore
            dup
            bipush 7
            ldc ">1us"
            aastore
            dup
            bipush 8
            ldc "10"
            aastore
            dup
            bipush 9
            ldc "100"
            aastore
            dup
            bipush 10
            ldc ">1ms"
            aastore
            dup
            bipush 11
         1: .line 796
            ldc "10"
            aastore
            dup
            bipush 12
            ldc "100"
            aastore
            dup
            bipush 13
            ldc ">1s"
            aastore
            dup
            bipush 14
            ldc "10"
            aastore
            dup
            bipush 15
            ldc "100"
            aastore
         2: .line 795
            invokevirtual java.io.PrintStream.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
         3: .line 797
            return
        end local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/oracle/graal/pointsto/BigBang$BucketTiming;

  public void print();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=13, args_size=1
        start local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
         0: .line 801
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numOperations:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            lstore 1 /* operations */
        start local 1 // long operations
         1: .line 802
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numInQueue:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            lstore 3 /* queued */
        start local 3 // long queued
         2: .line 803
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numAdded:Ljava/util/concurrent/atomic/AtomicLong;
            lconst_0
            invokevirtual java.util.concurrent.atomic.AtomicLong.getAndSet:(J)J
            lstore 5 /* scheduled */
        start local 5 // long scheduled
         3: .line 804
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.numDone:Ljava/util/concurrent/atomic/AtomicLong;
            lconst_0
            invokevirtual java.util.concurrent.atomic.AtomicLong.getAndSet:(J)J
            lstore 7 /* completed */
        start local 7 // long completed
         4: .line 805
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.totalTime:Ljava/util/concurrent/atomic/AtomicLong;
            lconst_0
            invokevirtual java.util.concurrent.atomic.AtomicLong.getAndSet:(J)J
            lstore 9 /* time */
        start local 9 // long time
         5: .line 807
            bipush 10
            newarray 11
            astore 11 /* buckets */
        start local 11 // long[] buckets
         6: .line 808
            iconst_0
            istore 12 /* i */
        start local 12 // int i
         7: goto 10
         8: .line 809
      StackMap locals: com.oracle.graal.pointsto.BigBang$BucketTiming long long long long long long[] int
      StackMap stack:
            aload 11 /* buckets */
            iload 12 /* i */
            aload 0 /* this */
            getfield com.oracle.graal.pointsto.BigBang$BucketTiming.timeBuckets:Ljava/util/concurrent/atomic/AtomicLongArray;
            iload 12 /* i */
            lconst_0
            invokevirtual java.util.concurrent.atomic.AtomicLongArray.getAndSet:(IJ)J
            lastore
         9: .line 808
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        10: iload 12 /* i */
            bipush 10
            if_icmplt 8
        end local 12 // int i
        11: .line 812
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "%9d %6d %6d %6d %10d %8d  "
            bipush 6
            anewarray java.lang.Object
            dup
            iconst_0
            lload 1 /* operations */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_1
            lload 3 /* queued */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_2
            lload 5 /* scheduled */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_3
            lload 7 /* completed */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_4
            lload 9 /* time */
            ldc 1000
            ldiv
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_5
            lload 7 /* completed */
            lconst_0
            lcmp
            ifeq 12
            lload 9 /* time */
            ldc 1000
            ldiv
            lload 7 /* completed */
            ldiv
            goto 13
      StackMap locals: com.oracle.graal.pointsto.BigBang$BucketTiming long long long long long long[]
      StackMap stack: java.io.PrintStream java.lang.String java.lang.Object[] java.lang.Object[] int
        12: lconst_0
      StackMap locals: com.oracle.graal.pointsto.BigBang$BucketTiming long long long long long long[]
      StackMap stack: java.io.PrintStream java.lang.String java.lang.Object[] java.lang.Object[] int long
        13: invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            invokevirtual java.io.PrintStream.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        14: .line 813
            iconst_0
            istore 12 /* i */
        start local 12 // int i
        15: goto 18
        16: .line 814
      StackMap locals: int
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "%5d "
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 11 /* buckets */
            iload 12 /* i */
            laload
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            invokevirtual java.io.PrintStream.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        17: .line 813
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        18: iload 12 /* i */
            bipush 10
            if_icmplt 16
        end local 12 // int i
        19: .line 816
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc " |"
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        20: .line 817
            return
        end local 11 // long[] buckets
        end local 9 // long time
        end local 7 // long completed
        end local 5 // long scheduled
        end local 3 // long queued
        end local 1 // long operations
        end local 0 // com.oracle.graal.pointsto.BigBang$BucketTiming this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   21     0        this  Lcom/oracle/graal/pointsto/BigBang$BucketTiming;
            1   21     1  operations  J
            2   21     3      queued  J
            3   21     5   scheduled  J
            4   21     7   completed  J
            5   21     9        time  J
            6   21    11     buckets  [J
            7   11    12           i  I
           15   19    12           i  I
}
SourceFile: "BigBang.java"
NestHost: com.oracle.graal.pointsto.BigBang
InnerClasses:
  protected abstract BucketTiming = com.oracle.graal.pointsto.BigBang$BucketTiming of com.oracle.graal.pointsto.BigBang
  public abstract TypeFlowRunnable = com.oracle.graal.pointsto.BigBang$TypeFlowRunnable of com.oracle.graal.pointsto.BigBang
  public abstract DebugContextRunnable = com.oracle.graal.pointsto.util.CompletionExecutor$DebugContextRunnable of com.oracle.graal.pointsto.util.CompletionExecutor
  public abstract Timing = com.oracle.graal.pointsto.util.CompletionExecutor$Timing of com.oracle.graal.pointsto.util.CompletionExecutor