public class org.jruby.runtime.profile.builtin.GraphProfilePrinter extends org.jruby.runtime.profile.builtin.ProfilePrinter
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.jruby.runtime.profile.builtin.GraphProfilePrinter
  super_class: org.jruby.runtime.profile.builtin.ProfilePrinter
{
  public void <init>(org.jruby.runtime.profile.builtin.ProfileData);
    descriptor: (Lorg/jruby/runtime/profile/builtin/ProfileData;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.jruby.runtime.profile.builtin.GraphProfilePrinter this
        start local 1 // org.jruby.runtime.profile.builtin.ProfileData profileData
         0: .line 38
            aload 0 /* this */
            aload 1 /* profileData */
            invokespecial org.jruby.runtime.profile.builtin.ProfilePrinter.<init>:(Lorg/jruby/runtime/profile/builtin/ProfileData;)V
         1: .line 39
            return
        end local 1 // org.jruby.runtime.profile.builtin.ProfileData profileData
        end local 0 // org.jruby.runtime.profile.builtin.GraphProfilePrinter this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    2     0         this  Lorg/jruby/runtime/profile/builtin/GraphProfilePrinter;
            0    2     1  profileData  Lorg/jruby/runtime/profile/builtin/ProfileData;
    MethodParameters:
             Name  Flags
      profileData  

  void <init>(org.jruby.runtime.profile.builtin.ProfileData, org.jruby.runtime.profile.builtin.Invocation);
    descriptor: (Lorg/jruby/runtime/profile/builtin/ProfileData;Lorg/jruby/runtime/profile/builtin/Invocation;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.jruby.runtime.profile.builtin.GraphProfilePrinter this
        start local 1 // org.jruby.runtime.profile.builtin.ProfileData profileData
        start local 2 // org.jruby.runtime.profile.builtin.Invocation topInvocation
         0: .line 42
            aload 0 /* this */
            aload 1 /* profileData */
            aload 2 /* topInvocation */
            invokespecial org.jruby.runtime.profile.builtin.ProfilePrinter.<init>:(Lorg/jruby/runtime/profile/builtin/ProfileData;Lorg/jruby/runtime/profile/builtin/Invocation;)V
         1: .line 43
            return
        end local 2 // org.jruby.runtime.profile.builtin.Invocation topInvocation
        end local 1 // org.jruby.runtime.profile.builtin.ProfileData profileData
        end local 0 // org.jruby.runtime.profile.builtin.GraphProfilePrinter this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    2     0           this  Lorg/jruby/runtime/profile/builtin/GraphProfilePrinter;
            0    2     1    profileData  Lorg/jruby/runtime/profile/builtin/ProfileData;
            0    2     2  topInvocation  Lorg/jruby/runtime/profile/builtin/Invocation;
    MethodParameters:
               Name  Flags
      profileData    
      topInvocation  

  public void printHeader(java.io.PrintStream);
    descriptor: (Ljava/io/PrintStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // org.jruby.runtime.profile.builtin.GraphProfilePrinter this
        start local 1 // java.io.PrintStream out
         0: .line 46
            aload 1 /* out */
            ldc "\n%s profile results:\n"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            invokevirtual org.jruby.runtime.profile.builtin.GraphProfilePrinter.getThreadName:()Ljava/lang/String;
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
         1: .line 47
            return
        end local 1 // java.io.PrintStream out
        end local 0 // org.jruby.runtime.profile.builtin.GraphProfilePrinter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/jruby/runtime/profile/builtin/GraphProfilePrinter;
            0    2     1   out  Ljava/io/PrintStream;
    MethodParameters:
      Name  Flags
      out   

  public void printProfile(java.io.PrintStream, boolean);
    descriptor: (Ljava/io/PrintStream;Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=20, args_size=3
        start local 0 // org.jruby.runtime.profile.builtin.GraphProfilePrinter this
        start local 1 // java.io.PrintStream out
        start local 2 // boolean first
         0: .line 50
            aload 0 /* this */
            invokevirtual org.jruby.runtime.profile.builtin.GraphProfilePrinter.getTopInvocation:()Lorg/jruby/runtime/profile/builtin/Invocation;
            astore 3 /* topInvocation */
        start local 3 // org.jruby.runtime.profile.builtin.Invocation topInvocation
         1: .line 52
            iload 2 /* first */
            ifne 3
         2: .line 53
            aload 1 /* out */
            invokevirtual java.io.PrintStream.println:()V
         3: .line 56
      StackMap locals: org.jruby.runtime.profile.builtin.Invocation
      StackMap stack:
            aload 1 /* out */
            ldc "Total time: %s\n\n"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* topInvocation */
            invokevirtual org.jruby.runtime.profile.builtin.Invocation.getDuration:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
         4: .line 58
            aload 1 /* out */
            ldc " %total   %self       total        self    children                 calls  name"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         5: .line 60
            aload 3 /* topInvocation */
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.methodData:(Lorg/jruby/runtime/profile/builtin/Invocation;)Lorg/jruby/util/collections/IntHashMap;
            astore 4 /* methods */
        start local 4 // org.jruby.util.collections.IntHashMap methods
         6: .line 61
            aload 4 /* methods */
            invokevirtual org.jruby.util.collections.IntHashMap.values:()Ljava/util/Collection;
            aload 4 /* methods */
            invokevirtual org.jruby.util.collections.IntHashMap.size:()I
            anewarray org.jruby.runtime.profile.builtin.MethodData
            invokeinterface java.util.Collection.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast org.jruby.runtime.profile.builtin.MethodData[]
            astore 5 /* sortedMethods */
        start local 5 // org.jruby.runtime.profile.builtin.MethodData[] sortedMethods
         7: .line 63
            aload 5 /* sortedMethods */
            new org.jruby.runtime.profile.builtin.GraphProfilePrinter$1
            dup
            aload 0 /* this */
            invokespecial org.jruby.runtime.profile.builtin.GraphProfilePrinter$1.<init>:(Lorg/jruby/runtime/profile/builtin/GraphProfilePrinter;)V
            invokestatic java.util.Arrays.sort:([Ljava/lang/Object;Ljava/util/Comparator;)V
         8: .line 71
            aload 5 /* sortedMethods */
            dup
            astore 9
            arraylength
            istore 8
            iconst_0
            istore 7
            goto 87
      StackMap locals: org.jruby.runtime.profile.builtin.GraphProfilePrinter java.io.PrintStream int org.jruby.runtime.profile.builtin.Invocation org.jruby.util.collections.IntHashMap org.jruby.runtime.profile.builtin.MethodData[] top int int org.jruby.runtime.profile.builtin.MethodData[]
      StackMap stack:
         9: aload 9
            iload 7
            aaload
            astore 6 /* data */
        start local 6 // org.jruby.runtime.profile.builtin.MethodData data
        10: .line 72
            aload 0 /* this */
            aload 6 /* data */
            getfield org.jruby.runtime.profile.builtin.MethodData.invocations:Ljava/util/List;
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.jruby.runtime.profile.builtin.Invocation
            invokevirtual org.jruby.runtime.profile.builtin.GraphProfilePrinter.isProfilerInvocation:(Lorg/jruby/runtime/profile/builtin/Invocation;)Z
            ifne 86
        11: .line 74
            aload 1 /* out */
            ldc "---------------------------------------------------------------------------------------------------------"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 75
            aload 6 /* data */
            getfield org.jruby.runtime.profile.builtin.MethodData.serialNumber:I
            istore 10 /* serial */
        start local 10 // int serial
        13: .line 77
            iload 10 /* serial */
            ifeq 40
        14: .line 78
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.parents:()[I
            astore 11 /* parentSerialsInts */
        start local 11 // int[] parentSerialsInts
        15: .line 79
            aload 11 /* parentSerialsInts */
            arraylength
            anewarray java.lang.Integer
            astore 12 /* parentSerials */
        start local 12 // java.lang.Integer[] parentSerials
        16: .line 80
            iconst_0
            istore 13 /* i */
        start local 13 // int i
        17: goto 20
        18: .line 81
      StackMap locals: org.jruby.runtime.profile.builtin.GraphProfilePrinter java.io.PrintStream int org.jruby.runtime.profile.builtin.Invocation org.jruby.util.collections.IntHashMap org.jruby.runtime.profile.builtin.MethodData[] org.jruby.runtime.profile.builtin.MethodData int int org.jruby.runtime.profile.builtin.MethodData[] int int[] java.lang.Integer[] int
      StackMap stack:
            aload 12 /* parentSerials */
            iload 13 /* i */
            aload 11 /* parentSerialsInts */
            iload 13 /* i */
            iaload
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
        19: .line 80
            iinc 13 /* i */ 1
      StackMap locals:
      StackMap stack:
        20: iload 13 /* i */
            aload 11 /* parentSerialsInts */
            arraylength
            if_icmplt 18
        end local 13 // int i
        21: .line 84
            aload 12 /* parentSerials */
            new org.jruby.runtime.profile.builtin.GraphProfilePrinter$2
            dup
            aload 0 /* this */
            aload 6 /* data */
            invokespecial org.jruby.runtime.profile.builtin.GraphProfilePrinter$2.<init>:(Lorg/jruby/runtime/profile/builtin/GraphProfilePrinter;Lorg/jruby/runtime/profile/builtin/MethodData;)V
            invokestatic java.util.Arrays.sort:([Ljava/lang/Object;Ljava/util/Comparator;)V
        22: .line 92
            aload 12 /* parentSerials */
            arraylength
            ifle 40
        23: .line 93
            aload 12 /* parentSerials */
            dup
            astore 16
            arraylength
            istore 15
            iconst_0
            istore 14
            goto 39
      StackMap locals: org.jruby.runtime.profile.builtin.GraphProfilePrinter java.io.PrintStream int org.jruby.runtime.profile.builtin.Invocation org.jruby.util.collections.IntHashMap org.jruby.runtime.profile.builtin.MethodData[] org.jruby.runtime.profile.builtin.MethodData int int org.jruby.runtime.profile.builtin.MethodData[] int int[] java.lang.Integer[] top int int java.lang.Integer[]
      StackMap stack:
        24: aload 16
            iload 14
            aaload
            invokevirtual java.lang.Integer.intValue:()I
            istore 13 /* parentSerial */
        start local 13 // int parentSerial
        25: .line 94
            aload 0 /* this */
            iload 13 /* parentSerial */
            invokevirtual org.jruby.runtime.profile.builtin.GraphProfilePrinter.methodName:(I)Ljava/lang/String;
            astore 17 /* callerName */
        start local 17 // java.lang.String callerName
        26: .line 95
            aload 6 /* data */
            iload 13 /* parentSerial */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.rootInvocationsFromParent:(I)Lorg/jruby/runtime/profile/builtin/InvocationSet;
            astore 18 /* invs */
        start local 18 // org.jruby.runtime.profile.builtin.InvocationSet invs
        27: .line 96
            aload 1 /* out */
            ldc "                 "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        28: .line 97
            aload 1 /* out */
            bipush 10
            aload 18 /* invs */
            invokevirtual org.jruby.runtime.profile.builtin.InvocationSet.totalTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        29: .line 98
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        30: .line 99
            aload 1 /* out */
            bipush 10
            aload 18 /* invs */
            invokevirtual org.jruby.runtime.profile.builtin.InvocationSet.selfTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        31: .line 100
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        32: .line 101
            aload 1 /* out */
            bipush 10
            aload 18 /* invs */
            invokevirtual org.jruby.runtime.profile.builtin.InvocationSet.childTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        33: .line 102
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        34: .line 103
            aload 1 /* out */
            bipush 20
            new java.lang.StringBuilder
            dup
            aload 6 /* data */
            iload 13 /* parentSerial */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.invocationsFromParent:(I)Lorg/jruby/runtime/profile/builtin/InvocationSet;
            invokevirtual org.jruby.runtime.profile.builtin.InvocationSet.totalCalls:()I
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "/"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.totalCalls:()I
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        35: .line 104
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        36: .line 105
            aload 1 /* out */
            aload 17 /* callerName */
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        37: .line 106
            aload 1 /* out */
            ldc ""
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 18 // org.jruby.runtime.profile.builtin.InvocationSet invs
        end local 17 // java.lang.String callerName
        end local 13 // int parentSerial
        38: .line 93
            iinc 14 1
      StackMap locals:
      StackMap stack:
        39: iload 14
            iload 15
            if_icmplt 24
        end local 12 // java.lang.Integer[] parentSerials
        end local 11 // int[] parentSerialsInts
        40: .line 111
      StackMap locals: org.jruby.runtime.profile.builtin.GraphProfilePrinter java.io.PrintStream int org.jruby.runtime.profile.builtin.Invocation org.jruby.util.collections.IntHashMap org.jruby.runtime.profile.builtin.MethodData[] org.jruby.runtime.profile.builtin.MethodData int int org.jruby.runtime.profile.builtin.MethodData[] int
      StackMap stack:
            aload 0 /* this */
            iload 10 /* serial */
            invokevirtual org.jruby.runtime.profile.builtin.GraphProfilePrinter.methodName:(I)Ljava/lang/String;
            astore 11 /* displayName */
        start local 11 // java.lang.String displayName
        41: .line 112
            aload 3 /* topInvocation */
            invokevirtual org.jruby.runtime.profile.builtin.Invocation.getDuration:()J
            lconst_0
            lcmp
            ifne 44
        42: .line 113
            aload 1 /* out */
            ldc "   100%    100%  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        43: .line 114
            goto 49
        44: .line 115
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        45: .line 116
            aload 1 /* out */
            iconst_4
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.totalTime:()J
            ldc 100
            lmul
            aload 3 /* topInvocation */
            invokevirtual org.jruby.runtime.profile.builtin.Invocation.getDuration:()J
            ldiv
            invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        46: .line 117
            aload 1 /* out */
            ldc "%   "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        47: .line 118
            aload 1 /* out */
            iconst_4
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.selfTime:()J
            ldc 100
            lmul
            aload 3 /* topInvocation */
            invokevirtual org.jruby.runtime.profile.builtin.Invocation.getDuration:()J
            ldiv
            invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        48: .line 119
            aload 1 /* out */
            ldc "%  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        49: .line 121
      StackMap locals:
      StackMap stack:
            aload 1 /* out */
            bipush 10
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.totalTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        50: .line 122
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        51: .line 123
            aload 1 /* out */
            bipush 10
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.selfTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        52: .line 124
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        53: .line 125
            aload 1 /* out */
            bipush 10
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.childTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        54: .line 126
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        55: .line 127
            aload 1 /* out */
            bipush 20
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.totalCalls:()I
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        56: .line 128
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        57: .line 129
            aload 1 /* out */
            aload 11 /* displayName */
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        58: .line 130
            aload 1 /* out */
            ldc ""
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        59: .line 132
            aload 6 /* data */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.children:()[I
            astore 12 /* childSerialsInts */
        start local 12 // int[] childSerialsInts
        60: .line 133
            aload 12 /* childSerialsInts */
            arraylength
            anewarray java.lang.Integer
            astore 13 /* childSerials */
        start local 13 // java.lang.Integer[] childSerials
        61: .line 134
            iconst_0
            istore 14 /* i */
        start local 14 // int i
        62: goto 65
        63: .line 135
      StackMap locals: int[] java.lang.Integer[] int
      StackMap stack:
            aload 13 /* childSerials */
            iload 14 /* i */
            aload 12 /* childSerialsInts */
            iload 14 /* i */
            iaload
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
        64: .line 134
            iinc 14 /* i */ 1
      StackMap locals:
      StackMap stack:
        65: iload 14 /* i */
            aload 12 /* childSerialsInts */
            arraylength
            if_icmplt 63
        end local 14 // int i
        66: .line 138
            aload 13 /* childSerials */
            new org.jruby.runtime.profile.builtin.GraphProfilePrinter$3
            dup
            aload 0 /* this */
            aload 6 /* data */
            invokespecial org.jruby.runtime.profile.builtin.GraphProfilePrinter$3.<init>:(Lorg/jruby/runtime/profile/builtin/GraphProfilePrinter;Lorg/jruby/runtime/profile/builtin/MethodData;)V
            invokestatic java.util.Arrays.sort:([Ljava/lang/Object;Ljava/util/Comparator;)V
        67: .line 146
            aload 13 /* childSerials */
            arraylength
            ifle 86
        68: .line 147
            aload 13 /* childSerials */
            dup
            astore 17
            arraylength
            istore 16
            iconst_0
            istore 15
            goto 85
      StackMap locals: org.jruby.runtime.profile.builtin.GraphProfilePrinter java.io.PrintStream int org.jruby.runtime.profile.builtin.Invocation org.jruby.util.collections.IntHashMap org.jruby.runtime.profile.builtin.MethodData[] org.jruby.runtime.profile.builtin.MethodData int int org.jruby.runtime.profile.builtin.MethodData[] int java.lang.String int[] java.lang.Integer[] top int int java.lang.Integer[]
      StackMap stack:
        69: aload 17
            iload 15
            aaload
            invokevirtual java.lang.Integer.intValue:()I
            istore 14 /* childSerial */
        start local 14 // int childSerial
        70: .line 148
            aload 0 /* this */
            iload 14 /* childSerial */
            invokevirtual org.jruby.runtime.profile.builtin.GraphProfilePrinter.isThisProfilerInvocation:(I)Z
            ifne 84
        71: .line 149
            aload 0 /* this */
            iload 14 /* childSerial */
            invokevirtual org.jruby.runtime.profile.builtin.GraphProfilePrinter.methodName:(I)Ljava/lang/String;
            astore 18 /* callerName */
        start local 18 // java.lang.String callerName
        72: .line 150
            aload 6 /* data */
            iload 14 /* childSerial */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.rootInvocationsOfChild:(I)Lorg/jruby/runtime/profile/builtin/InvocationSet;
            astore 19 /* invs */
        start local 19 // org.jruby.runtime.profile.builtin.InvocationSet invs
        73: .line 151
            aload 1 /* out */
            ldc "                 "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        74: .line 152
            aload 1 /* out */
            bipush 10
            aload 19 /* invs */
            invokevirtual org.jruby.runtime.profile.builtin.InvocationSet.totalTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        75: .line 153
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        76: .line 154
            aload 1 /* out */
            bipush 10
            aload 19 /* invs */
            invokevirtual org.jruby.runtime.profile.builtin.InvocationSet.selfTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        77: .line 155
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        78: .line 156
            aload 1 /* out */
            bipush 10
            aload 19 /* invs */
            invokevirtual org.jruby.runtime.profile.builtin.InvocationSet.childTime:()J
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.nanoString:(J)Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        79: .line 157
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        80: .line 158
            aload 1 /* out */
            bipush 20
            new java.lang.StringBuilder
            dup
            aload 6 /* data */
            iload 14 /* childSerial */
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.invocationsOfChild:(I)Lorg/jruby/runtime/profile/builtin/InvocationSet;
            invokevirtual org.jruby.runtime.profile.builtin.InvocationSet.totalCalls:()I
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "/"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* methods */
            iload 14 /* childSerial */
            invokevirtual org.jruby.util.collections.IntHashMap.get:(I)Ljava/lang/Object;
            checkcast org.jruby.runtime.profile.builtin.MethodData
            invokevirtual org.jruby.runtime.profile.builtin.MethodData.totalCalls:()I
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.jruby.runtime.profile.builtin.GraphProfilePrinter.pad:(Ljava/io/PrintStream;ILjava/lang/String;)V
        81: .line 159
            aload 1 /* out */
            ldc "  "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        82: .line 160
            aload 1 /* out */
            aload 18 /* callerName */
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        83: .line 161
            aload 1 /* out */
            ldc ""
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 19 // org.jruby.runtime.profile.builtin.InvocationSet invs
        end local 18 // java.lang.String callerName
        end local 14 // int childSerial
        84: .line 147
      StackMap locals:
      StackMap stack:
            iinc 15 1
      StackMap locals:
      StackMap stack:
        85: iload 15
            iload 16
            if_icmplt 69
        end local 13 // java.lang.Integer[] childSerials
        end local 12 // int[] childSerialsInts
        end local 11 // java.lang.String displayName
        end local 10 // int serial
        end local 6 // org.jruby.runtime.profile.builtin.MethodData data
        86: .line 71
      StackMap locals: org.jruby.runtime.profile.builtin.GraphProfilePrinter java.io.PrintStream int org.jruby.runtime.profile.builtin.Invocation org.jruby.util.collections.IntHashMap org.jruby.runtime.profile.builtin.MethodData[] top int int org.jruby.runtime.profile.builtin.MethodData[]
      StackMap stack:
            iinc 7 1
      StackMap locals:
      StackMap stack:
        87: iload 7
            iload 8
            if_icmplt 9
        88: .line 167
            return
        end local 5 // org.jruby.runtime.profile.builtin.MethodData[] sortedMethods
        end local 4 // org.jruby.util.collections.IntHashMap methods
        end local 3 // org.jruby.runtime.profile.builtin.Invocation topInvocation
        end local 2 // boolean first
        end local 1 // java.io.PrintStream out
        end local 0 // org.jruby.runtime.profile.builtin.GraphProfilePrinter this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   89     0               this  Lorg/jruby/runtime/profile/builtin/GraphProfilePrinter;
            0   89     1                out  Ljava/io/PrintStream;
            0   89     2              first  Z
            1   89     3      topInvocation  Lorg/jruby/runtime/profile/builtin/Invocation;
            6   89     4            methods  Lorg/jruby/util/collections/IntHashMap<Lorg/jruby/runtime/profile/builtin/MethodData;>;
            7   89     5      sortedMethods  [Lorg/jruby/runtime/profile/builtin/MethodData;
           10   86     6               data  Lorg/jruby/runtime/profile/builtin/MethodData;
           13   86    10             serial  I
           15   40    11  parentSerialsInts  [I
           16   40    12      parentSerials  [Ljava/lang/Integer;
           17   21    13                  i  I
           25   38    13       parentSerial  I
           26   38    17         callerName  Ljava/lang/String;
           27   38    18               invs  Lorg/jruby/runtime/profile/builtin/InvocationSet;
           41   86    11        displayName  Ljava/lang/String;
           60   86    12   childSerialsInts  [I
           61   86    13       childSerials  [Ljava/lang/Integer;
           62   66    14                  i  I
           70   84    14        childSerial  I
           72   84    18         callerName  Ljava/lang/String;
           73   84    19               invs  Lorg/jruby/runtime/profile/builtin/InvocationSet;
    MethodParameters:
       Name  Flags
      out    
      first  
}
SourceFile: "GraphProfilePrinter.java"
NestMembers:
  org.jruby.runtime.profile.builtin.GraphProfilePrinter$1  org.jruby.runtime.profile.builtin.GraphProfilePrinter$2  org.jruby.runtime.profile.builtin.GraphProfilePrinter$3
InnerClasses:
  org.jruby.runtime.profile.builtin.GraphProfilePrinter$1
  org.jruby.runtime.profile.builtin.GraphProfilePrinter$2
  org.jruby.runtime.profile.builtin.GraphProfilePrinter$3