public class org.graalvm.compiler.printer.CompilationPrinter implements java.io.Closeable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.printer.CompilationPrinter
  super_class: java.lang.Object
{
  public static final java.lang.String COLUMN_END;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: " <|@"

  public static final java.lang.String HOVER_START;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "<@"

  public static final java.lang.String HOVER_SEP;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "|@"

  public static final java.lang.String HOVER_END;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: ">@"

  private static java.io.OutputStream globalOut;
    descriptor: Ljava/io/OutputStream;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  protected final org.graalvm.compiler.debug.LogStream out;
    descriptor: Lorg/graalvm/compiler/debug/LogStream;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  public static synchronized java.io.OutputStream globalOut();
    descriptor: ()Ljava/io/OutputStream;
    flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=1, args_size=0
         0: .line 71
            getstatic org.graalvm.compiler.printer.CompilationPrinter.globalOut:Ljava/io/OutputStream;
            ifnonnull 6
         1: .line 72
            new java.io.File
            dup
            new java.lang.StringBuilder
            dup
            ldc "compilations-"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            invokestatic java.lang.System.currentTimeMillis:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            ldc ".cfg"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 0 /* file */
        start local 0 // java.io.File file
         2: .line 74
            new java.io.FileOutputStream
            dup
            aload 0 /* file */
            invokespecial java.io.FileOutputStream.<init>:(Ljava/io/File;)V
            putstatic org.graalvm.compiler.printer.CompilationPrinter.globalOut:Ljava/io/OutputStream;
         3: .line 75
            goto 6
      StackMap locals: java.io.File
      StackMap stack: java.io.FileNotFoundException
         4: pop
         5: .line 76
            new java.lang.StringBuilder
            dup
            ldc "WARNING: Could not open "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* file */
            invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.graalvm.compiler.debug.TTY.println:(Ljava/lang/String;)V
        end local 0 // java.io.File file
         6: .line 79
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.printer.CompilationPrinter.globalOut:Ljava/io/OutputStream;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            2    6     0  file  Ljava/io/File;
      Exception table:
        from    to  target  type
           2     3       4  Class java.io.FileNotFoundException

  public void <init>(java.io.OutputStream);
    descriptor: (Ljava/io/OutputStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
        start local 1 // java.io.OutputStream os
         0: .line 89
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 90
            aload 0 /* this */
            new org.graalvm.compiler.debug.LogStream
            dup
            aload 1 /* os */
            invokespecial org.graalvm.compiler.debug.LogStream.<init>:(Ljava/io/OutputStream;)V
            putfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
         2: .line 91
            return
        end local 1 // java.io.OutputStream os
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/graalvm/compiler/printer/CompilationPrinter;
            0    3     1    os  Ljava/io/OutputStream;
    MethodParameters:
      Name  Flags
      os    

  public void flush();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
         0: .line 97
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            invokevirtual org.graalvm.compiler.debug.LogStream.flush:()V
         1: .line 98
            return
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/graalvm/compiler/printer/CompilationPrinter;

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
         0: .line 102
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            invokevirtual org.graalvm.compiler.debug.LogStream.out:()Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.close:()V
         1: .line 103
            return
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/graalvm/compiler/printer/CompilationPrinter;

  protected void begin(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
        start local 1 // java.lang.String string
         0: .line 106
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            new java.lang.StringBuilder
            dup
            ldc "begin_"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* string */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.LogStream.println:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            pop
         1: .line 107
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            iconst_2
            invokevirtual org.graalvm.compiler.debug.LogStream.adjustIndentation:(I)V
         2: .line 108
            return
        end local 1 // java.lang.String string
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/graalvm/compiler/printer/CompilationPrinter;
            0    3     1  string  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      string  

  protected void end(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
        start local 1 // java.lang.String string
         0: .line 111
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            bipush -2
            invokevirtual org.graalvm.compiler.debug.LogStream.adjustIndentation:(I)V
         1: .line 112
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            new java.lang.StringBuilder
            dup
            ldc "end_"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* string */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.LogStream.println:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            pop
         2: .line 113
            return
        end local 1 // java.lang.String string
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/graalvm/compiler/printer/CompilationPrinter;
            0    3     1  string  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      string  

  public void printCompilation(jdk.vm.ci.meta.JavaMethod);
    descriptor: (Ljdk/vm/ci/meta/JavaMethod;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
        start local 1 // jdk.vm.ci.meta.JavaMethod method
         0: .line 121
            aload 0 /* this */
            ldc "compilation"
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.begin:(Ljava/lang/String;)V
         1: .line 122
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            ldc "name \" "
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            aload 1 /* method */
            ldc "%H::%n"
            invokeinterface jdk.vm.ci.meta.JavaMethod.format:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            bipush 34
            invokevirtual org.graalvm.compiler.debug.LogStream.println:(C)Lorg/graalvm/compiler/debug/LogStream;
            pop
         2: .line 123
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            ldc "method \""
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            aload 1 /* method */
            ldc "%f %r %H.%n(%p)"
            invokeinterface jdk.vm.ci.meta.JavaMethod.format:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            bipush 34
            invokevirtual org.graalvm.compiler.debug.LogStream.println:(C)Lorg/graalvm/compiler/debug/LogStream;
            pop
         3: .line 124
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            ldc "date "
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            invokestatic java.lang.System.currentTimeMillis:()J
            invokevirtual org.graalvm.compiler.debug.LogStream.println:(J)Lorg/graalvm/compiler/debug/LogStream;
            pop
         4: .line 125
            aload 0 /* this */
            ldc "compilation"
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.end:(Ljava/lang/String;)V
         5: .line 126
            return
        end local 1 // jdk.vm.ci.meta.JavaMethod method
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lorg/graalvm/compiler/printer/CompilationPrinter;
            0    6     1  method  Ljdk/vm/ci/meta/JavaMethod;
    MethodParameters:
        Name  Flags
      method  

  protected java.lang.String debugInfoToString(jdk.vm.ci.code.BytecodePosition, jdk.vm.ci.code.ReferenceMap, org.graalvm.compiler.lir.util.IndexedValueMap, jdk.vm.ci.code.RegisterSaveLayout);
    descriptor: (Ljdk/vm/ci/code/BytecodePosition;Ljdk/vm/ci/code/ReferenceMap;Lorg/graalvm/compiler/lir/util/IndexedValueMap;Ljdk/vm/ci/code/RegisterSaveLayout;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=11, args_size=5
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
        start local 1 // jdk.vm.ci.code.BytecodePosition codePos
        start local 2 // jdk.vm.ci.code.ReferenceMap refMap
        start local 3 // org.graalvm.compiler.lir.util.IndexedValueMap liveBasePointers
        start local 4 // jdk.vm.ci.code.RegisterSaveLayout calleeSaveInfo
         0: .line 132
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 5 /* sb */
        start local 5 // java.lang.StringBuilder sb
         1: .line 133
            aload 2 /* refMap */
            ifnull 5
         2: .line 134
            aload 5 /* sb */
            ldc "reference-map: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         3: .line 135
            aload 5 /* sb */
            aload 2 /* refMap */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 136
            aload 5 /* sb */
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         5: .line 138
      StackMap locals: java.lang.StringBuilder
      StackMap stack:
            aload 3 /* liveBasePointers */
            ifnull 9
         6: .line 139
            aload 5 /* sb */
            ldc "live-base-pointers: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         7: .line 140
            aload 5 /* sb */
            aload 3 /* liveBasePointers */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         8: .line 141
            aload 5 /* sb */
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         9: .line 144
      StackMap locals:
      StackMap stack:
            aload 4 /* calleeSaveInfo */
            ifnull 16
        10: .line 145
            aload 5 /* sb */
            ldc "callee-save-info:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        11: .line 146
            aload 4 /* calleeSaveInfo */
            iconst_1
            invokevirtual jdk.vm.ci.code.RegisterSaveLayout.registersToSlots:(Z)Ljava/util/Map;
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 7
            goto 14
      StackMap locals: org.graalvm.compiler.printer.CompilationPrinter jdk.vm.ci.code.BytecodePosition jdk.vm.ci.code.ReferenceMap org.graalvm.compiler.lir.util.IndexedValueMap jdk.vm.ci.code.RegisterSaveLayout java.lang.StringBuilder top java.util.Iterator
      StackMap stack:
        12: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 6 /* e */
        start local 6 // java.util.Map$Entry e
        13: .line 147
            aload 5 /* sb */
            new java.lang.StringBuilder
            dup
            ldc " "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* e */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " -> s"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* e */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 6 // java.util.Map$Entry e
        14: .line 146
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        15: .line 149
            aload 5 /* sb */
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        16: .line 152
      StackMap locals: org.graalvm.compiler.printer.CompilationPrinter jdk.vm.ci.code.BytecodePosition jdk.vm.ci.code.ReferenceMap org.graalvm.compiler.lir.util.IndexedValueMap jdk.vm.ci.code.RegisterSaveLayout java.lang.StringBuilder
      StackMap stack:
            aload 1 /* codePos */
            ifnull 60
        17: .line 153
            aload 1 /* codePos */
            astore 6 /* curCodePos */
        start local 6 // jdk.vm.ci.code.BytecodePosition curCodePos
        18: .line 154
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 7 /* virtualObjects */
        start local 7 // java.util.List virtualObjects
        19: .line 156
      StackMap locals: jdk.vm.ci.code.BytecodePosition java.util.List
      StackMap stack:
            aload 5 /* sb */
            aload 6 /* curCodePos */
            invokevirtual jdk.vm.ci.code.BytecodePosition.getMethod:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            aload 6 /* curCodePos */
            invokevirtual jdk.vm.ci.code.BytecodePosition.getBCI:()I
            invokestatic jdk.vm.ci.meta.MetaUtil.toLocation:(Ljdk/vm/ci/meta/ResolvedJavaMethod;I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        20: .line 157
            aload 5 /* sb */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        21: .line 158
            aload 6 /* curCodePos */
            instanceof jdk.vm.ci.code.BytecodeFrame
            ifeq 46
        22: .line 159
            aload 6 /* curCodePos */
            checkcast jdk.vm.ci.code.BytecodeFrame
            astore 8 /* frame */
        start local 8 // jdk.vm.ci.code.BytecodeFrame frame
        23: .line 160
            aload 8 /* frame */
            getfield jdk.vm.ci.code.BytecodeFrame.numStack:I
            ifle 31
        24: .line 161
            aload 5 /* sb */
            ldc "stack: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        25: .line 162
            iconst_0
            istore 9 /* i */
        start local 9 // int i
        26: goto 29
        27: .line 163
      StackMap locals: jdk.vm.ci.code.BytecodeFrame int
      StackMap stack:
            aload 5 /* sb */
            aload 0 /* this */
            aload 8 /* frame */
            iload 9 /* i */
            invokevirtual jdk.vm.ci.code.BytecodeFrame.getStackValue:(I)Ljdk/vm/ci/meta/JavaValue;
            aload 7 /* virtualObjects */
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.valueToString:(Ljdk/vm/ci/meta/JavaValue;Ljava/util/List;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        28: .line 162
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        29: iload 9 /* i */
            aload 8 /* frame */
            getfield jdk.vm.ci.code.BytecodeFrame.numStack:I
            if_icmplt 27
        end local 9 // int i
        30: .line 165
            aload 5 /* sb */
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        31: .line 167
      StackMap locals:
      StackMap stack:
            aload 5 /* sb */
            ldc "locals: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        32: .line 168
            iconst_0
            istore 9 /* i */
        start local 9 // int i
        33: goto 36
        34: .line 169
      StackMap locals: int
      StackMap stack:
            aload 5 /* sb */
            aload 0 /* this */
            aload 8 /* frame */
            iload 9 /* i */
            invokevirtual jdk.vm.ci.code.BytecodeFrame.getLocalValue:(I)Ljdk/vm/ci/meta/JavaValue;
            aload 7 /* virtualObjects */
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.valueToString:(Ljdk/vm/ci/meta/JavaValue;Ljava/util/List;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        35: .line 168
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        36: iload 9 /* i */
            aload 8 /* frame */
            getfield jdk.vm.ci.code.BytecodeFrame.numLocals:I
            if_icmplt 34
        end local 9 // int i
        37: .line 171
            aload 5 /* sb */
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        38: .line 172
            aload 8 /* frame */
            getfield jdk.vm.ci.code.BytecodeFrame.numLocks:I
            ifle 46
        39: .line 173
            aload 5 /* sb */
            ldc "locks: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        40: .line 174
            iconst_0
            istore 9 /* i */
        start local 9 // int i
        41: goto 44
        42: .line 175
      StackMap locals:
      StackMap stack:
            aload 5 /* sb */
            aload 0 /* this */
            aload 8 /* frame */
            iload 9 /* i */
            invokevirtual jdk.vm.ci.code.BytecodeFrame.getLockValue:(I)Ljdk/vm/ci/meta/JavaValue;
            aload 7 /* virtualObjects */
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.valueToString:(Ljdk/vm/ci/meta/JavaValue;Ljava/util/List;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        43: .line 174
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        44: iload 9 /* i */
            aload 8 /* frame */
            getfield jdk.vm.ci.code.BytecodeFrame.numLocks:I
            if_icmplt 42
        end local 9 // int i
        45: .line 177
            aload 5 /* sb */
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 8 // jdk.vm.ci.code.BytecodeFrame frame
        46: .line 181
      StackMap locals:
      StackMap stack:
            aload 6 /* curCodePos */
            invokevirtual jdk.vm.ci.code.BytecodePosition.getCaller:()Ljdk/vm/ci/code/BytecodePosition;
            astore 6 /* curCodePos */
        47: .line 182
            aload 6 /* curCodePos */
            ifnonnull 19
        48: .line 184
            iconst_0
            istore 8 /* i */
        start local 8 // int i
        49: goto 59
        50: .line 185
      StackMap locals: int
      StackMap stack:
            aload 7 /* virtualObjects */
            iload 8 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast jdk.vm.ci.code.VirtualObject
            astore 9 /* obj */
        start local 9 // jdk.vm.ci.code.VirtualObject obj
        51: .line 186
            aload 5 /* sb */
            aload 9 /* obj */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 9 /* obj */
            invokevirtual jdk.vm.ci.code.VirtualObject.getType:()Ljdk/vm/ci/meta/ResolvedJavaType;
            invokeinterface jdk.vm.ci.meta.ResolvedJavaType.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        52: .line 187
            iconst_0
            istore 10 /* j */
        start local 10 // int j
        53: goto 56
        54: .line 188
      StackMap locals: jdk.vm.ci.code.VirtualObject int
      StackMap stack:
            aload 5 /* sb */
            aload 0 /* this */
            aload 9 /* obj */
            invokevirtual jdk.vm.ci.code.VirtualObject.getValues:()[Ljdk/vm/ci/meta/JavaValue;
            iload 10 /* j */
            aaload
            aload 7 /* virtualObjects */
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.valueToString:(Ljdk/vm/ci/meta/JavaValue;Ljava/util/List;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        55: .line 187
            iinc 10 /* j */ 1
      StackMap locals:
      StackMap stack:
        56: iload 10 /* j */
            aload 9 /* obj */
            invokevirtual jdk.vm.ci.code.VirtualObject.getValues:()[Ljdk/vm/ci/meta/JavaValue;
            arraylength
            if_icmplt 54
        end local 10 // int j
        57: .line 190
            aload 5 /* sb */
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 9 // jdk.vm.ci.code.VirtualObject obj
        58: .line 184
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        59: iload 8 /* i */
            aload 7 /* virtualObjects */
            invokeinterface java.util.List.size:()I
            if_icmplt 50
        end local 8 // int i
        end local 7 // java.util.List virtualObjects
        end local 6 // jdk.vm.ci.code.BytecodePosition curCodePos
        60: .line 194
      StackMap locals:
      StackMap stack:
            aload 5 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 5 // java.lang.StringBuilder sb
        end local 4 // jdk.vm.ci.code.RegisterSaveLayout calleeSaveInfo
        end local 3 // org.graalvm.compiler.lir.util.IndexedValueMap liveBasePointers
        end local 2 // jdk.vm.ci.code.ReferenceMap refMap
        end local 1 // jdk.vm.ci.code.BytecodePosition codePos
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   61     0              this  Lorg/graalvm/compiler/printer/CompilationPrinter;
            0   61     1           codePos  Ljdk/vm/ci/code/BytecodePosition;
            0   61     2            refMap  Ljdk/vm/ci/code/ReferenceMap;
            0   61     3  liveBasePointers  Lorg/graalvm/compiler/lir/util/IndexedValueMap;
            0   61     4    calleeSaveInfo  Ljdk/vm/ci/code/RegisterSaveLayout;
            1   61     5                sb  Ljava/lang/StringBuilder;
           13   14     6                 e  Ljava/util/Map$Entry<Ljdk/vm/ci/code/Register;Ljava/lang/Integer;>;
           18   60     6        curCodePos  Ljdk/vm/ci/code/BytecodePosition;
           19   60     7    virtualObjects  Ljava/util/List<Ljdk/vm/ci/code/VirtualObject;>;
           23   46     8             frame  Ljdk/vm/ci/code/BytecodeFrame;
           26   30     9                 i  I
           33   37     9                 i  I
           41   45     9                 i  I
           49   60     8                 i  I
           51   58     9               obj  Ljdk/vm/ci/code/VirtualObject;
           53   57    10                 j  I
    MethodParameters:
                  Name  Flags
      codePos           
      refMap            
      liveBasePointers  
      calleeSaveInfo    

  protected java.lang.String valueToString(jdk.vm.ci.meta.JavaValue, java.util.List<jdk.vm.ci.code.VirtualObject>);
    descriptor: (Ljdk/vm/ci/meta/JavaValue;Ljava/util/List;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
        start local 1 // jdk.vm.ci.meta.JavaValue value
        start local 2 // java.util.List virtualObjects
         0: .line 198
            aload 1 /* value */
            ifnonnull 2
         1: .line 199
            ldc "-"
            areturn
         2: .line 201
      StackMap locals:
      StackMap stack:
            aload 1 /* value */
            instanceof jdk.vm.ci.code.VirtualObject
            ifeq 4
            aload 2 /* virtualObjects */
            aload 1 /* value */
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifne 4
         3: .line 202
            aload 2 /* virtualObjects */
            aload 1 /* value */
            checkcast jdk.vm.ci.code.VirtualObject
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         4: .line 204
      StackMap locals:
      StackMap stack:
            aload 1 /* value */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            areturn
        end local 2 // java.util.List virtualObjects
        end local 1 // jdk.vm.ci.meta.JavaValue value
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    5     0            this  Lorg/graalvm/compiler/printer/CompilationPrinter;
            0    5     1           value  Ljdk/vm/ci/meta/JavaValue;
            0    5     2  virtualObjects  Ljava/util/List<Ljdk/vm/ci/code/VirtualObject;>;
    Signature: (Ljdk/vm/ci/meta/JavaValue;Ljava/util/List<Ljdk/vm/ci/code/VirtualObject;>;)Ljava/lang/String;
    MethodParameters:
                Name  Flags
      value           
      virtualObjects  

  public void printMachineCode(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
        start local 1 // java.lang.String code
        start local 2 // java.lang.String label
         0: .line 208
            aload 1 /* code */
            ifnull 1
            aload 1 /* code */
            invokevirtual java.lang.String.length:()I
            ifne 2
         1: .line 209
      StackMap locals:
      StackMap stack:
            return
         2: .line 211
      StackMap locals:
      StackMap stack:
            aload 2 /* label */
            ifnull 6
         3: .line 212
            aload 0 /* this */
            ldc "cfg"
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.begin:(Ljava/lang/String;)V
         4: .line 213
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            ldc "name \""
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            aload 2 /* label */
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            bipush 34
            invokevirtual org.graalvm.compiler.debug.LogStream.println:(C)Lorg/graalvm/compiler/debug/LogStream;
            pop
         5: .line 214
            aload 0 /* this */
            ldc "cfg"
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.end:(Ljava/lang/String;)V
         6: .line 216
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "nmethod"
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.begin:(Ljava/lang/String;)V
         7: .line 217
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            aload 1 /* code */
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            pop
         8: .line 218
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            ldc " <|@"
            invokevirtual org.graalvm.compiler.debug.LogStream.println:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            pop
         9: .line 219
            aload 0 /* this */
            ldc "nmethod"
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.end:(Ljava/lang/String;)V
        10: .line 220
            return
        end local 2 // java.lang.String label
        end local 1 // java.lang.String code
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   11     0   this  Lorg/graalvm/compiler/printer/CompilationPrinter;
            0   11     1   code  Ljava/lang/String;
            0   11     2  label  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      code   
      label  

  public void printBytecodes(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.printer.CompilationPrinter this
        start local 1 // java.lang.String code
         0: .line 223
            aload 1 /* code */
            ifnull 1
            aload 1 /* code */
            invokevirtual java.lang.String.length:()I
            ifne 2
         1: .line 224
      StackMap locals:
      StackMap stack:
            return
         2: .line 226
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "bytecodes"
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.begin:(Ljava/lang/String;)V
         3: .line 227
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            aload 1 /* code */
            invokevirtual org.graalvm.compiler.debug.LogStream.print:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            pop
         4: .line 228
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CompilationPrinter.out:Lorg/graalvm/compiler/debug/LogStream;
            ldc " <|@"
            invokevirtual org.graalvm.compiler.debug.LogStream.println:(Ljava/lang/String;)Lorg/graalvm/compiler/debug/LogStream;
            pop
         5: .line 229
            aload 0 /* this */
            ldc "bytecodes"
            invokevirtual org.graalvm.compiler.printer.CompilationPrinter.end:(Ljava/lang/String;)V
         6: .line 230
            return
        end local 1 // java.lang.String code
        end local 0 // org.graalvm.compiler.printer.CompilationPrinter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/graalvm/compiler/printer/CompilationPrinter;
            0    7     1  code  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      code  
}
SourceFile: "CompilationPrinter.java"
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map