public class org.graalvm.compiler.printer.CFGPrinterObserver implements org.graalvm.compiler.debug.DebugDumpHandler
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.printer.CFGPrinterObserver
  super_class: java.lang.Object
{
  private org.graalvm.compiler.printer.CFGPrinter cfgPrinter;
    descriptor: Lorg/graalvm/compiler/printer/CFGPrinter;
    flags: (0x0002) ACC_PRIVATE

  private java.io.File cfgFile;
    descriptor: Ljava/io/File;
    flags: (0x0002) ACC_PRIVATE

  private jdk.vm.ci.meta.JavaMethod curMethod;
    descriptor: Ljdk/vm/ci/meta/JavaMethod;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.compiler.core.common.CompilationIdentifier curCompilation;
    descriptor: Lorg/graalvm/compiler/core/common/CompilationIdentifier;
    flags: (0x0002) ACC_PRIVATE

  private java.util.List<java.lang.String> curDecorators;
    descriptor: Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/List<Ljava/lang/String;>;

  private org.graalvm.compiler.lir.LIR lastLIR;
    descriptor: Lorg/graalvm/compiler/lir/LIR;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.compiler.lir.debug.IntervalDumper delayedIntervals;
    descriptor: Lorg/graalvm/compiler/lir/debug/IntervalDumper;
    flags: (0x0002) ACC_PRIVATE

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
         0: .line 73
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 79
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.curDecorators:Ljava/util/List;
         2: .line 146
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.lastLIR:Lorg/graalvm/compiler/lir/LIR;
         3: .line 147
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.delayedIntervals:Lorg/graalvm/compiler/lir/debug/IntervalDumper;
         4: .line 73
            return
        end local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/graalvm/compiler/printer/CFGPrinterObserver;

  public void dump(org.graalvm.compiler.debug.DebugContext, java.lang.Object, java.lang.String, java.lang.Object[]);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=7, args_size=5
        start local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.lang.Object object
        start local 3 // java.lang.String format
        start local 4 // java.lang.Object[] arguments
         0: .line 83
            aload 3 /* format */
            aload 4 /* arguments */
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 5 /* message */
        start local 5 // java.lang.String message
         1: .line 85
            aload 0 /* this */
            aload 1 /* debug */
            aload 2 /* object */
            aload 5 /* message */
            invokevirtual org.graalvm.compiler.printer.CFGPrinterObserver.dumpSandboxed:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/Object;Ljava/lang/String;)V
         2: .line 86
            goto 6
      StackMap locals: org.graalvm.compiler.printer.CFGPrinterObserver org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String java.lang.Object[] java.lang.String
      StackMap stack: java.lang.Throwable
         3: astore 6 /* ex */
        start local 6 // java.lang.Throwable ex
         4: .line 87
            new java.lang.StringBuilder
            dup
            ldc "CFGPrinter: Exception during output of "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* message */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* ex */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.graalvm.compiler.debug.TTY.println:(Ljava/lang/String;)V
         5: .line 88
            aload 6 /* ex */
            invokevirtual java.lang.Throwable.printStackTrace:()V
        end local 6 // java.lang.Throwable ex
         6: .line 90
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.lang.String message
        end local 4 // java.lang.Object[] arguments
        end local 3 // java.lang.String format
        end local 2 // java.lang.Object object
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Lorg/graalvm/compiler/printer/CFGPrinterObserver;
            0    7     1      debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    7     2     object  Ljava/lang/Object;
            0    7     3     format  Ljava/lang/String;
            0    7     4  arguments  [Ljava/lang/Object;
            1    7     5    message  Ljava/lang/String;
            4    6     6         ex  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.Throwable
    MethodParameters:
           Name  Flags
      debug      
      object     
      format     
      arguments  

  private boolean checkMethodScope(org.graalvm.compiler.debug.DebugContext);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=8, args_size=2
        start local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
         0: .line 98
            aconst_null
            astore 2 /* method */
        start local 2 // jdk.vm.ci.meta.JavaMethod method
         1: .line 99
            aconst_null
            astore 3 /* compilation */
        start local 3 // org.graalvm.compiler.core.common.CompilationIdentifier compilation
         2: .line 100
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 4 /* decorators */
        start local 4 // java.util.ArrayList decorators
         3: .line 101
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.context:()Ljava/lang/Iterable;
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 6
            goto 24
      StackMap locals: org.graalvm.compiler.printer.CFGPrinterObserver org.graalvm.compiler.debug.DebugContext jdk.vm.ci.meta.JavaMethod org.graalvm.compiler.core.common.CompilationIdentifier java.util.ArrayList top java.util.Iterator
      StackMap stack:
         4: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 5 /* o */
        start local 5 // java.lang.Object o
         5: .line 102
            aload 5 /* o */
            instanceof jdk.vm.ci.meta.JavaMethod
            ifeq 9
         6: .line 103
            aload 5 /* o */
            checkcast jdk.vm.ci.meta.JavaMethod
            astore 2 /* method */
         7: .line 104
            aload 4 /* decorators */
            invokevirtual java.util.ArrayList.clear:()V
         8: .line 105
            goto 24
      StackMap locals: org.graalvm.compiler.printer.CFGPrinterObserver org.graalvm.compiler.debug.DebugContext jdk.vm.ci.meta.JavaMethod org.graalvm.compiler.core.common.CompilationIdentifier java.util.ArrayList java.lang.Object java.util.Iterator
      StackMap stack:
         9: aload 5 /* o */
            instanceof org.graalvm.compiler.nodes.StructuredGraph
            ifeq 16
        10: .line 106
            aload 5 /* o */
            checkcast org.graalvm.compiler.nodes.StructuredGraph
            astore 7 /* graph */
        start local 7 // org.graalvm.compiler.nodes.StructuredGraph graph
        11: .line 107
            aload 7 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.method:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            ifnull 24
        12: .line 108
            aload 7 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.method:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            astore 2 /* method */
        13: .line 109
            aload 4 /* decorators */
            invokevirtual java.util.ArrayList.clear:()V
        14: .line 110
            aload 7 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.compilationId:()Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            astore 3 /* compilation */
        end local 7 // org.graalvm.compiler.nodes.StructuredGraph graph
        15: .line 112
            goto 24
      StackMap locals:
      StackMap stack:
        16: aload 5 /* o */
            instanceof org.graalvm.compiler.debug.DebugDumpScope
            ifeq 21
        17: .line 113
            aload 5 /* o */
            checkcast org.graalvm.compiler.debug.DebugDumpScope
            astore 7 /* debugDumpScope */
        start local 7 // org.graalvm.compiler.debug.DebugDumpScope debugDumpScope
        18: .line 114
            aload 7 /* debugDumpScope */
            getfield org.graalvm.compiler.debug.DebugDumpScope.decorator:Z
            ifeq 24
        19: .line 115
            aload 4 /* decorators */
            aload 7 /* debugDumpScope */
            getfield org.graalvm.compiler.debug.DebugDumpScope.name:Ljava/lang/String;
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // org.graalvm.compiler.debug.DebugDumpScope debugDumpScope
        20: .line 117
            goto 24
      StackMap locals:
      StackMap stack:
        21: aload 5 /* o */
            instanceof org.graalvm.compiler.code.CompilationResult
            ifeq 24
        22: .line 118
            aload 5 /* o */
            checkcast org.graalvm.compiler.code.CompilationResult
            astore 7 /* compilationResult */
        start local 7 // org.graalvm.compiler.code.CompilationResult compilationResult
        23: .line 119
            aload 7 /* compilationResult */
            invokevirtual org.graalvm.compiler.code.CompilationResult.getCompilationId:()Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            astore 3 /* compilation */
        end local 7 // org.graalvm.compiler.code.CompilationResult compilationResult
        end local 5 // java.lang.Object o
        24: .line 101
      StackMap locals: org.graalvm.compiler.printer.CFGPrinterObserver org.graalvm.compiler.debug.DebugContext jdk.vm.ci.meta.JavaMethod org.graalvm.compiler.core.common.CompilationIdentifier java.util.ArrayList top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        25: .line 123
            aload 2 /* method */
            ifnonnull 27
            aload 3 /* compilation */
            ifnonnull 27
        26: .line 124
            iconst_0
            ireturn
        27: .line 127
      StackMap locals: org.graalvm.compiler.printer.CFGPrinterObserver org.graalvm.compiler.debug.DebugContext jdk.vm.ci.meta.JavaMethod org.graalvm.compiler.core.common.CompilationIdentifier java.util.ArrayList
      StackMap stack:
            aload 3 /* compilation */
            ifnull 31
        28: .line 128
            aload 3 /* compilation */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.curCompilation:Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 29
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.curDecorators:Ljava/util/List;
            aload 4 /* decorators */
            invokeinterface java.util.List.equals:(Ljava/lang/Object;)Z
            ifne 33
        29: .line 129
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* compilation */
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printCompilation:(Lorg/graalvm/compiler/core/common/CompilationIdentifier;)V
        30: .line 131
            goto 33
        31: .line 132
      StackMap locals:
      StackMap stack:
            aload 2 /* method */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.curMethod:Ljdk/vm/ci/meta/JavaMethod;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 32
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.curDecorators:Ljava/util/List;
            aload 4 /* decorators */
            invokeinterface java.util.List.equals:(Ljava/lang/Object;)Z
            ifne 33
        32: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 2 /* method */
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printCompilation:(Ljdk/vm/ci/meta/JavaMethod;)V
        33: .line 136
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* compilation */
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.curCompilation:Lorg/graalvm/compiler/core/common/CompilationIdentifier;
        34: .line 137
            aload 0 /* this */
            aload 2 /* method */
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.curMethod:Ljdk/vm/ci/meta/JavaMethod;
        35: .line 138
            aload 0 /* this */
            aload 4 /* decorators */
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.curDecorators:Ljava/util/List;
        36: .line 139
            iconst_1
            ireturn
        end local 4 // java.util.ArrayList decorators
        end local 3 // org.graalvm.compiler.core.common.CompilationIdentifier compilation
        end local 2 // jdk.vm.ci.meta.JavaMethod method
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   37     0               this  Lorg/graalvm/compiler/printer/CFGPrinterObserver;
            0   37     1              debug  Lorg/graalvm/compiler/debug/DebugContext;
            1   37     2             method  Ljdk/vm/ci/meta/JavaMethod;
            2   37     3        compilation  Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            3   37     4         decorators  Ljava/util/ArrayList<Ljava/lang/String;>;
            5   24     5                  o  Ljava/lang/Object;
           11   15     7              graph  Lorg/graalvm/compiler/nodes/StructuredGraph;
           18   20     7     debugDumpScope  Lorg/graalvm/compiler/debug/DebugDumpScope;
           23   24     7  compilationResult  Lorg/graalvm/compiler/code/CompilationResult;
    MethodParameters:
       Name  Flags
      debug  

  private static boolean isFrontendObject(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.lang.Object object
         0: .line 143
            aload 0 /* object */
            instanceof org.graalvm.compiler.graph.Graph
            ifne 1
            aload 0 /* object */
            instanceof org.graalvm.compiler.java.BciBlockMapping
            ifne 1
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_1
            ireturn
        end local 0 // java.lang.Object object
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0  object  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      object  

  public void dumpSandboxed(org.graalvm.compiler.debug.DebugContext, java.lang.Object, java.lang.String);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/Object;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=10, args_size=4
        start local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.lang.Object object
        start local 3 // java.lang.String message
         0: .line 150
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.getOptions:()Lorg/graalvm/compiler/options/OptionValues;
            astore 4 /* options */
        start local 4 // org.graalvm.compiler.options.OptionValues options
         1: .line 151
            getstatic org.graalvm.compiler.debug.DebugOptions.PrintCFG:Lorg/graalvm/compiler/options/OptionKey;
            aload 4 /* options */
            invokevirtual org.graalvm.compiler.options.OptionKey.getValue:(Lorg/graalvm/compiler/options/OptionValues;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            istore 5 /* dumpFrontend */
        start local 5 // boolean dumpFrontend
         2: .line 152
            iload 5 /* dumpFrontend */
            ifne 4
            aload 2 /* object */
            invokestatic org.graalvm.compiler.printer.CFGPrinterObserver.isFrontendObject:(Ljava/lang/Object;)Z
            ifeq 4
         3: .line 153
            return
         4: .line 156
      StackMap locals: org.graalvm.compiler.options.OptionValues int
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            ifnonnull 14
         5: .line 158
            aload 1 /* debug */
            ldc ".cfg"
            iconst_0
            invokevirtual org.graalvm.compiler.debug.DebugContext.getDumpPath:(Ljava/lang/String;Z)Ljava/nio/file/Path;
            astore 6 /* dumpFile */
        start local 6 // java.nio.file.Path dumpFile
         6: .line 159
            aload 0 /* this */
            aload 6 /* dumpFile */
            invokeinterface java.nio.file.Path.toFile:()Ljava/io/File;
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgFile:Ljava/io/File;
         7: .line 160
            new java.io.BufferedOutputStream
            dup
            new java.io.FileOutputStream
            dup
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgFile:Ljava/io/File;
            invokespecial java.io.FileOutputStream.<init>:(Ljava/io/File;)V
            invokespecial java.io.BufferedOutputStream.<init>:(Ljava/io/OutputStream;)V
            astore 7 /* out */
        start local 7 // java.io.OutputStream out
         8: .line 161
            aload 0 /* this */
            new org.graalvm.compiler.printer.CFGPrinter
            dup
            aload 7 /* out */
            invokespecial org.graalvm.compiler.printer.CFGPrinter.<init>:(Ljava/io/OutputStream;)V
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
        end local 7 // java.io.OutputStream out
        end local 6 // java.nio.file.Path dumpFile
         9: .line 162
            goto 14
      StackMap locals:
      StackMap stack: java.io.IOException
        10: astore 6 /* e */
        start local 6 // java.io.IOException e
        11: .line 163
            new org.graalvm.compiler.debug.GraalError
            dup
            ldc "Could not open %s"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgFile:Ljava/io/File;
            ifnonnull 12
            ldc "[null]"
            goto 13
      StackMap locals: org.graalvm.compiler.printer.CFGPrinterObserver org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String org.graalvm.compiler.options.OptionValues int java.io.IOException
      StackMap stack: new 11 new 11 java.lang.String java.lang.Object[] java.lang.Object[] int
        12: aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgFile:Ljava/io/File;
            invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
      StackMap locals: org.graalvm.compiler.printer.CFGPrinterObserver org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String org.graalvm.compiler.options.OptionValues int java.io.IOException
      StackMap stack: new 11 new 11 java.lang.String java.lang.Object[] java.lang.Object[] int java.lang.String
        13: aastore
            invokespecial org.graalvm.compiler.debug.GraalError.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            aload 6 /* e */
            invokevirtual org.graalvm.compiler.debug.GraalError.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            checkcast org.graalvm.compiler.debug.GraalError
            athrow
        end local 6 // java.io.IOException e
        14: .line 167
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.printer.CFGPrinterObserver.checkMethodScope:(Lorg/graalvm/compiler/debug/DebugContext;)Z
            ifne 16
        15: .line 168
            return
        16: .line 171
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.curMethod:Ljdk/vm/ci/meta/JavaMethod;
            instanceof jdk.vm.ci.meta.ResolvedJavaMethod
            ifeq 18
        17: .line 172
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.curMethod:Ljdk/vm/ci/meta/JavaMethod;
            checkcast jdk.vm.ci.meta.ResolvedJavaMethod
            putfield org.graalvm.compiler.printer.CFGPrinter.method:Ljdk/vm/ci/meta/ResolvedJavaMethod;
        18: .line 175
      StackMap locals:
      StackMap stack:
            aload 2 /* object */
            instanceof org.graalvm.compiler.lir.LIR
            ifeq 21
        19: .line 176
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 2 /* object */
            checkcast org.graalvm.compiler.lir.LIR
            putfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
        20: .line 177
            goto 22
        21: .line 178
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 1 /* debug */
            ldc Lorg/graalvm/compiler/lir/LIR;
            invokevirtual org.graalvm.compiler.debug.DebugContext.contextLookup:(Ljava/lang/Class;)Ljava/lang/Object;
            checkcast org.graalvm.compiler.lir.LIR
            putfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
        22: .line 180
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 1 /* debug */
            ldc Lorg/graalvm/compiler/core/gen/NodeLIRBuilder;
            invokevirtual org.graalvm.compiler.debug.DebugContext.contextLookup:(Ljava/lang/Class;)Ljava/lang/Object;
            checkcast org.graalvm.compiler.core.gen.NodeLIRBuilder
            putfield org.graalvm.compiler.printer.CFGPrinter.nodeLirGenerator:Lorg/graalvm/compiler/core/gen/NodeLIRBuilder;
        23: .line 181
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 1 /* debug */
            ldc Lorg/graalvm/compiler/lir/gen/LIRGenerationResult;
            invokevirtual org.graalvm.compiler.debug.DebugContext.contextLookup:(Ljava/lang/Class;)Ljava/lang/Object;
            checkcast org.graalvm.compiler.lir.gen.LIRGenerationResult
            putfield org.graalvm.compiler.printer.CFGPrinter.res:Lorg/graalvm/compiler/lir/gen/LIRGenerationResult;
        24: .line 182
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.nodeLirGenerator:Lorg/graalvm/compiler/core/gen/NodeLIRBuilder;
            ifnull 26
        25: .line 183
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.nodeLirGenerator:Lorg/graalvm/compiler/core/gen/NodeLIRBuilder;
            invokevirtual org.graalvm.compiler.core.gen.NodeLIRBuilder.getLIRGeneratorTool:()Lorg/graalvm/compiler/lir/gen/LIRGenerator;
            invokevirtual org.graalvm.compiler.lir.gen.LIRGenerator.target:()Ljdk/vm/ci/code/TargetDescription;
            putfield org.graalvm.compiler.printer.CFGPrinter.target:Ljdk/vm/ci/code/TargetDescription;
        26: .line 185
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
            ifnull 28
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
            invokevirtual org.graalvm.compiler.lir.LIR.getControlFlowGraph:()Lorg/graalvm/compiler/core/common/cfg/AbstractControlFlowGraph;
            instanceof org.graalvm.compiler.nodes.cfg.ControlFlowGraph
            ifeq 28
        27: .line 186
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
            invokevirtual org.graalvm.compiler.lir.LIR.getControlFlowGraph:()Lorg/graalvm/compiler/core/common/cfg/AbstractControlFlowGraph;
            checkcast org.graalvm.compiler.nodes.cfg.ControlFlowGraph
            putfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
        28: .line 189
      StackMap locals:
      StackMap stack:
            aload 1 /* debug */
            ldc Ljdk/vm/ci/code/CodeCacheProvider;
            invokevirtual org.graalvm.compiler.debug.DebugContext.contextLookup:(Ljava/lang/Class;)Ljava/lang/Object;
            checkcast jdk.vm.ci.code.CodeCacheProvider
            astore 6 /* codeCache */
        start local 6 // jdk.vm.ci.code.CodeCacheProvider codeCache
        29: .line 190
            aload 6 /* codeCache */
            ifnull 31
        30: .line 191
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 6 /* codeCache */
            invokeinterface jdk.vm.ci.code.CodeCacheProvider.getTarget:()Ljdk/vm/ci/code/TargetDescription;
            putfield org.graalvm.compiler.printer.CFGPrinter.target:Ljdk/vm/ci/code/TargetDescription;
        31: .line 194
      StackMap locals: jdk.vm.ci.code.CodeCacheProvider
      StackMap stack:
            aload 2 /* object */
            instanceof org.graalvm.compiler.java.BciBlockMapping
            ifeq 37
        32: .line 195
            aload 2 /* object */
            checkcast org.graalvm.compiler.java.BciBlockMapping
            astore 7 /* blockMap */
        start local 7 // org.graalvm.compiler.java.BciBlockMapping blockMap
        33: .line 196
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 7 /* blockMap */
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printCFG:(Ljava/lang/String;Lorg/graalvm/compiler/java/BciBlockMapping;)V
        34: .line 197
            aload 7 /* blockMap */
            getfield org.graalvm.compiler.java.BciBlockMapping.code:Lorg/graalvm/compiler/bytecode/Bytecode;
            invokeinterface org.graalvm.compiler.bytecode.Bytecode.getCode:()[B
            ifnull 92
        35: .line 198
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            new org.graalvm.compiler.bytecode.BytecodeDisassembler
            dup
            iconst_0
            invokespecial org.graalvm.compiler.bytecode.BytecodeDisassembler.<init>:(Z)V
            aload 7 /* blockMap */
            getfield org.graalvm.compiler.java.BciBlockMapping.code:Lorg/graalvm/compiler/bytecode/Bytecode;
            invokevirtual org.graalvm.compiler.bytecode.BytecodeDisassembler.disassemble:(Lorg/graalvm/compiler/bytecode/Bytecode;)Ljava/lang/String;
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printBytecodes:(Ljava/lang/String;)V
        end local 7 // org.graalvm.compiler.java.BciBlockMapping blockMap
        36: .line 201
            goto 92
      StackMap locals:
      StackMap stack:
        37: aload 2 /* object */
            instanceof org.graalvm.compiler.lir.LIR
            ifeq 44
        38: .line 203
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
            invokevirtual org.graalvm.compiler.lir.LIR.codeEmittingOrder:()[Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase;
            iconst_0
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printCFG:(Ljava/lang/String;[Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase;Z)V
        39: .line 204
            aload 0 /* this */
            aload 2 /* object */
            checkcast org.graalvm.compiler.lir.LIR
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.lastLIR:Lorg/graalvm/compiler/lir/LIR;
        40: .line 205
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.delayedIntervals:Lorg/graalvm/compiler/lir/debug/IntervalDumper;
            ifnull 92
        41: .line 206
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.delayedIntervals:Lorg/graalvm/compiler/lir/debug/IntervalDumper;
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printIntervals:(Ljava/lang/String;Lorg/graalvm/compiler/lir/debug/IntervalDumper;)V
        42: .line 207
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.delayedIntervals:Lorg/graalvm/compiler/lir/debug/IntervalDumper;
        43: .line 209
            goto 92
      StackMap locals:
      StackMap stack:
        44: aload 2 /* object */
            instanceof org.graalvm.compiler.nodes.StructuredGraph$ScheduleResult
            ifeq 47
        45: .line 210
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 2 /* object */
            checkcast org.graalvm.compiler.nodes.StructuredGraph$ScheduleResult
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printSchedule:(Ljava/lang/String;Lorg/graalvm/compiler/nodes/StructuredGraph$ScheduleResult;)V
        46: .line 211
            goto 92
      StackMap locals:
      StackMap stack:
        47: aload 2 /* object */
            instanceof org.graalvm.compiler.nodes.StructuredGraph
            ifeq 58
        48: .line 212
            aload 2 /* object */
            checkcast org.graalvm.compiler.nodes.StructuredGraph
            astore 7 /* graph */
        start local 7 // org.graalvm.compiler.nodes.StructuredGraph graph
        49: .line 213
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
            ifnonnull 53
        50: .line 214
            aload 1 /* debug */
            aload 7 /* graph */
            invokestatic org.graalvm.compiler.printer.GraalDebugHandlersFactory.tryGetSchedule:(Lorg/graalvm/compiler/debug/DebugContext;Lorg/graalvm/compiler/nodes/StructuredGraph;)Lorg/graalvm/compiler/nodes/StructuredGraph$ScheduleResult;
            astore 8 /* scheduleResult */
        start local 8 // org.graalvm.compiler.nodes.StructuredGraph$ScheduleResult scheduleResult
        51: .line 215
            aload 8 /* scheduleResult */
            ifnull 53
        52: .line 216
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 8 /* scheduleResult */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph$ScheduleResult.getCFG:()Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
            putfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
        end local 8 // org.graalvm.compiler.nodes.StructuredGraph$ScheduleResult scheduleResult
        53: .line 219
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
            ifnull 92
        54: .line 220
            aload 7 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.nodeIdCount:()I
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
            invokevirtual org.graalvm.compiler.nodes.cfg.ControlFlowGraph.getNodeToBlock:()Lorg/graalvm/compiler/graph/NodeMap;
            invokevirtual org.graalvm.compiler.graph.NodeMap.capacity:()I
            if_icmple 56
        55: .line 221
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 7 /* graph */
            iconst_1
            iconst_1
            iconst_1
            iconst_0
            invokestatic org.graalvm.compiler.nodes.cfg.ControlFlowGraph.compute:(Lorg/graalvm/compiler/nodes/StructuredGraph;ZZZZ)Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
            putfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
        56: .line 223
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
            invokevirtual org.graalvm.compiler.nodes.cfg.ControlFlowGraph.getBlocks:()[Lorg/graalvm/compiler/nodes/cfg/Block;
            iconst_1
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printCFG:(Ljava/lang/String;[Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase;Z)V
        end local 7 // org.graalvm.compiler.nodes.StructuredGraph graph
        57: .line 225
            goto 92
      StackMap locals:
      StackMap stack:
        58: aload 2 /* object */
            instanceof org.graalvm.compiler.code.CompilationResult
            ifeq 62
        59: .line 226
            aload 2 /* object */
            checkcast org.graalvm.compiler.code.CompilationResult
            astore 7 /* compResult */
        start local 7 // org.graalvm.compiler.code.CompilationResult compResult
        60: .line 227
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 4 /* options */
            aload 6 /* codeCache */
            aload 7 /* compResult */
            aconst_null
            invokestatic org.graalvm.compiler.printer.CFGPrinterObserver.disassemble:(Lorg/graalvm/compiler/options/OptionValues;Ljdk/vm/ci/code/CodeCacheProvider;Lorg/graalvm/compiler/code/CompilationResult;Ljdk/vm/ci/code/InstalledCode;)Ljava/lang/String;
            aload 3 /* message */
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printMachineCode:(Ljava/lang/String;Ljava/lang/String;)V
        end local 7 // org.graalvm.compiler.code.CompilationResult compResult
        61: .line 228
            goto 92
      StackMap locals:
      StackMap stack:
        62: aload 2 /* object */
            instanceof jdk.vm.ci.code.InstalledCode
            ifeq 67
        63: .line 229
            aload 1 /* debug */
            ldc Lorg/graalvm/compiler/code/CompilationResult;
            invokevirtual org.graalvm.compiler.debug.DebugContext.contextLookup:(Ljava/lang/Class;)Ljava/lang/Object;
            checkcast org.graalvm.compiler.code.CompilationResult
            astore 7 /* compResult */
        start local 7 // org.graalvm.compiler.code.CompilationResult compResult
        64: .line 230
            aload 7 /* compResult */
            ifnull 92
        65: .line 231
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 4 /* options */
            aload 6 /* codeCache */
            aload 7 /* compResult */
            aload 2 /* object */
            checkcast jdk.vm.ci.code.InstalledCode
            invokestatic org.graalvm.compiler.printer.CFGPrinterObserver.disassemble:(Lorg/graalvm/compiler/options/OptionValues;Ljdk/vm/ci/code/CodeCacheProvider;Lorg/graalvm/compiler/code/CompilationResult;Ljdk/vm/ci/code/InstalledCode;)Ljava/lang/String;
            aload 3 /* message */
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printMachineCode:(Ljava/lang/String;Ljava/lang/String;)V
        end local 7 // org.graalvm.compiler.code.CompilationResult compResult
        66: .line 233
            goto 92
      StackMap locals:
      StackMap stack:
        67: aload 2 /* object */
            instanceof org.graalvm.compiler.lir.debug.IntervalDumper
            ifeq 75
        68: .line 234
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.lastLIR:Lorg/graalvm/compiler/lir/LIR;
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            getfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
            if_acmpne 71
        69: .line 235
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 2 /* object */
            checkcast org.graalvm.compiler.lir.debug.IntervalDumper
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printIntervals:(Ljava/lang/String;Lorg/graalvm/compiler/lir/debug/IntervalDumper;)V
        70: .line 236
            goto 92
        71: .line 237
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.delayedIntervals:Lorg/graalvm/compiler/lir/debug/IntervalDumper;
            ifnull 73
        72: .line 238
            aload 1 /* debug */
            ldc "Some delayed intervals were dropped (%s)"
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.delayedIntervals:Lorg/graalvm/compiler/lir/debug/IntervalDumper;
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(Ljava/lang/String;Ljava/lang/Object;)V
        73: .line 240
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* object */
            checkcast org.graalvm.compiler.lir.debug.IntervalDumper
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.delayedIntervals:Lorg/graalvm/compiler/lir/debug/IntervalDumper;
        74: .line 242
            goto 92
      StackMap locals:
      StackMap stack:
        75: aload 2 /* object */
            instanceof org.graalvm.compiler.core.common.cfg.AbstractBlockBase[]
            ifeq 78
        76: .line 243
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 2 /* object */
            checkcast org.graalvm.compiler.core.common.cfg.AbstractBlockBase[]
            iconst_0
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printCFG:(Ljava/lang/String;[Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase;Z)V
        77: .line 244
            goto 92
      StackMap locals:
      StackMap stack:
        78: aload 2 /* object */
            instanceof org.graalvm.compiler.core.common.alloc.Trace
            ifeq 81
        79: .line 245
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 2 /* object */
            checkcast org.graalvm.compiler.core.common.alloc.Trace
            invokevirtual org.graalvm.compiler.core.common.alloc.Trace.getBlocks:()[Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase;
            iconst_0
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printCFG:(Ljava/lang/String;[Lorg/graalvm/compiler/core/common/cfg/AbstractBlockBase;Z)V
        80: .line 246
            goto 92
      StackMap locals:
      StackMap stack:
        81: aload 2 /* object */
            instanceof org.graalvm.compiler.core.common.alloc.TraceBuilderResult
            ifeq 92
        82: .line 247
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aload 3 /* message */
            aload 2 /* object */
            checkcast org.graalvm.compiler.core.common.alloc.TraceBuilderResult
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.printTraces:(Ljava/lang/String;Lorg/graalvm/compiler/core/common/alloc/TraceBuilderResult;)V
        end local 6 // jdk.vm.ci.code.CodeCacheProvider codeCache
        83: .line 249
            goto 92
      StackMap locals: org.graalvm.compiler.printer.CFGPrinterObserver org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String org.graalvm.compiler.options.OptionValues int
      StackMap stack: java.lang.Throwable
        84: astore 9
        85: .line 250
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.target:Ljdk/vm/ci/code/TargetDescription;
        86: .line 251
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
        87: .line 252
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.res:Lorg/graalvm/compiler/lir/gen/LIRGenerationResult;
        88: .line 253
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.nodeLirGenerator:Lorg/graalvm/compiler/core/gen/NodeLIRBuilder;
        89: .line 254
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
        90: .line 255
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.flush:()V
        91: .line 256
            aload 9
            athrow
        92: .line 250
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.target:Ljdk/vm/ci/code/TargetDescription;
        93: .line 251
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.lir:Lorg/graalvm/compiler/lir/LIR;
        94: .line 252
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.res:Lorg/graalvm/compiler/lir/gen/LIRGenerationResult;
        95: .line 253
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.nodeLirGenerator:Lorg/graalvm/compiler/core/gen/NodeLIRBuilder;
        96: .line 254
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinter.cfg:Lorg/graalvm/compiler/nodes/cfg/ControlFlowGraph;
        97: .line 255
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.flush:()V
        98: .line 257
            return
        end local 5 // boolean dumpFrontend
        end local 4 // org.graalvm.compiler.options.OptionValues options
        end local 3 // java.lang.String message
        end local 2 // java.lang.Object object
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   99     0            this  Lorg/graalvm/compiler/printer/CFGPrinterObserver;
            0   99     1           debug  Lorg/graalvm/compiler/debug/DebugContext;
            0   99     2          object  Ljava/lang/Object;
            0   99     3         message  Ljava/lang/String;
            1   99     4         options  Lorg/graalvm/compiler/options/OptionValues;
            2   99     5    dumpFrontend  Z
            6    9     6        dumpFile  Ljava/nio/file/Path;
            8    9     7             out  Ljava/io/OutputStream;
           11   14     6               e  Ljava/io/IOException;
           29   83     6       codeCache  Ljdk/vm/ci/code/CodeCacheProvider;
           33   36     7        blockMap  Lorg/graalvm/compiler/java/BciBlockMapping;
           49   57     7           graph  Lorg/graalvm/compiler/nodes/StructuredGraph;
           51   53     8  scheduleResult  Lorg/graalvm/compiler/nodes/StructuredGraph$ScheduleResult;
           60   61     7      compResult  Lorg/graalvm/compiler/code/CompilationResult;
           64   66     7      compResult  Lorg/graalvm/compiler/code/CompilationResult;
      Exception table:
        from    to  target  type
           5     9      10  Class java.io.IOException
          16    84      84  any
    MethodParameters:
         Name  Flags
      debug    
      object   
      message  

  private static org.graalvm.compiler.code.DisassemblerProvider selectDisassemblerProvider(org.graalvm.compiler.options.OptionValues);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;)Lorg/graalvm/compiler/code/DisassemblerProvider;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=7, args_size=1
        start local 0 // org.graalvm.compiler.options.OptionValues options
         0: .line 260
            aconst_null
            astore 1 /* selected */
        start local 1 // org.graalvm.compiler.code.DisassemblerProvider selected
         1: .line 261
            invokestatic jdk.vm.ci.services.Services.getSavedProperties:()Ljava/util/Map;
            ldc "os.arch"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 2 /* arch */
        start local 2 // java.lang.String arch
         2: .line 262
            aload 2 /* arch */
            ldc "aarch64"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            istore 3 /* isAArch64 */
        start local 3 // boolean isAArch64
         3: .line 263
            ldc Lorg/graalvm/compiler/code/DisassemblerProvider;
            invokestatic org.graalvm.compiler.serviceprovider.GraalServices.load:(Ljava/lang/Class;)Ljava/lang/Iterable;
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 5
            goto 12
      StackMap locals: org.graalvm.compiler.options.OptionValues org.graalvm.compiler.code.DisassemblerProvider java.lang.String int top java.util.Iterator
      StackMap stack:
         4: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.code.DisassemblerProvider
            astore 4 /* d */
        start local 4 // org.graalvm.compiler.code.DisassemblerProvider d
         5: .line 264
            aload 4 /* d */
            invokeinterface org.graalvm.compiler.code.DisassemblerProvider.getName:()Ljava/lang/String;
            astore 6 /* name */
        start local 6 // java.lang.String name
         6: .line 265
            iload 3 /* isAArch64 */
            ifeq 8
            aload 6 /* name */
            ldc "objdump"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 8
            aload 4 /* d */
            aload 0 /* options */
            invokeinterface org.graalvm.compiler.code.DisassemblerProvider.isAvailable:(Lorg/graalvm/compiler/options/OptionValues;)Z
            ifeq 8
         7: .line 266
            aload 4 /* d */
            areturn
         8: .line 267
      StackMap locals: org.graalvm.compiler.options.OptionValues org.graalvm.compiler.code.DisassemblerProvider java.lang.String int org.graalvm.compiler.code.DisassemblerProvider java.util.Iterator java.lang.String
      StackMap stack:
            aload 6 /* name */
            ldc "hcf"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 12
         9: .line 268
            iload 3 /* isAArch64 */
            ifne 11
        10: .line 269
            aload 4 /* d */
            areturn
        11: .line 271
      StackMap locals:
      StackMap stack:
            aload 4 /* d */
            astore 1 /* selected */
        end local 6 // java.lang.String name
        end local 4 // org.graalvm.compiler.code.DisassemblerProvider d
        12: .line 263
      StackMap locals: org.graalvm.compiler.options.OptionValues org.graalvm.compiler.code.DisassemblerProvider java.lang.String int top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        13: .line 274
            aload 1 /* selected */
            ifnonnull 15
        14: .line 275
            new org.graalvm.compiler.printer.CFGPrinterObserver$1
            dup
            invokespecial org.graalvm.compiler.printer.CFGPrinterObserver$1.<init>:()V
            astore 1 /* selected */
        15: .line 282
      StackMap locals: org.graalvm.compiler.options.OptionValues org.graalvm.compiler.code.DisassemblerProvider java.lang.String int
      StackMap stack:
            aload 1 /* selected */
            areturn
        end local 3 // boolean isAArch64
        end local 2 // java.lang.String arch
        end local 1 // org.graalvm.compiler.code.DisassemblerProvider selected
        end local 0 // org.graalvm.compiler.options.OptionValues options
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   16     0    options  Lorg/graalvm/compiler/options/OptionValues;
            1   16     1   selected  Lorg/graalvm/compiler/code/DisassemblerProvider;
            2   16     2       arch  Ljava/lang/String;
            3   16     3  isAArch64  Z
            5   12     4          d  Lorg/graalvm/compiler/code/DisassemblerProvider;
            6   12     6       name  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      options  

  private static java.lang.String disassemble(org.graalvm.compiler.options.OptionValues, jdk.vm.ci.code.CodeCacheProvider, org.graalvm.compiler.code.CompilationResult, jdk.vm.ci.code.InstalledCode);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;Ljdk/vm/ci/code/CodeCacheProvider;Lorg/graalvm/compiler/code/CompilationResult;Ljdk/vm/ci/code/InstalledCode;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // org.graalvm.compiler.options.OptionValues options
        start local 1 // jdk.vm.ci.code.CodeCacheProvider codeCache
        start local 2 // org.graalvm.compiler.code.CompilationResult compResult
        start local 3 // jdk.vm.ci.code.InstalledCode installedCode
         0: .line 286
            aload 0 /* options */
            invokestatic org.graalvm.compiler.printer.CFGPrinterObserver.selectDisassemblerProvider:(Lorg/graalvm/compiler/options/OptionValues;)Lorg/graalvm/compiler/code/DisassemblerProvider;
            astore 4 /* dis */
        start local 4 // org.graalvm.compiler.code.DisassemblerProvider dis
         1: .line 287
            aload 3 /* installedCode */
            ifnull 3
         2: .line 288
            aload 4 /* dis */
            aload 1 /* codeCache */
            aload 2 /* compResult */
            aload 3 /* installedCode */
            invokeinterface org.graalvm.compiler.code.DisassemblerProvider.disassembleInstalledCode:(Ljdk/vm/ci/code/CodeCacheProvider;Lorg/graalvm/compiler/code/CompilationResult;Ljdk/vm/ci/code/InstalledCode;)Ljava/lang/String;
            areturn
         3: .line 290
      StackMap locals: org.graalvm.compiler.code.DisassemblerProvider
      StackMap stack:
            aload 4 /* dis */
            aload 0 /* options */
            aload 1 /* codeCache */
            aload 2 /* compResult */
            invokeinterface org.graalvm.compiler.code.DisassemblerProvider.disassembleCompiledCode:(Lorg/graalvm/compiler/options/OptionValues;Ljdk/vm/ci/code/CodeCacheProvider;Lorg/graalvm/compiler/code/CompilationResult;)Ljava/lang/String;
            areturn
        end local 4 // org.graalvm.compiler.code.DisassemblerProvider dis
        end local 3 // jdk.vm.ci.code.InstalledCode installedCode
        end local 2 // org.graalvm.compiler.code.CompilationResult compResult
        end local 1 // jdk.vm.ci.code.CodeCacheProvider codeCache
        end local 0 // org.graalvm.compiler.options.OptionValues options
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    4     0        options  Lorg/graalvm/compiler/options/OptionValues;
            0    4     1      codeCache  Ljdk/vm/ci/code/CodeCacheProvider;
            0    4     2     compResult  Lorg/graalvm/compiler/code/CompilationResult;
            0    4     3  installedCode  Ljdk/vm/ci/code/InstalledCode;
            1    4     4            dis  Lorg/graalvm/compiler/code/DisassemblerProvider;
    MethodParameters:
               Name  Flags
      options        
      codeCache      
      compResult     
      installedCode  

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
         0: .line 295
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            ifnull 6
         1: .line 296
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
            invokevirtual org.graalvm.compiler.printer.CFGPrinter.close:()V
         2: .line 297
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgPrinter:Lorg/graalvm/compiler/printer/CFGPrinter;
         3: .line 298
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.curDecorators:Ljava/util/List;
         4: .line 299
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.curMethod:Ljdk/vm/ci/meta/JavaMethod;
         5: .line 300
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.printer.CFGPrinterObserver.curCompilation:Lorg/graalvm/compiler/core/common/CompilationIdentifier;
         6: .line 302
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/graalvm/compiler/printer/CFGPrinterObserver;

  public java.lang.String getDumpPath();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
         0: .line 305
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgFile:Ljava/io/File;
            ifnull 2
         1: .line 306
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.CFGPrinterObserver.cfgFile:Ljava/io/File;
            invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
            areturn
         2: .line 308
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 0 // org.graalvm.compiler.printer.CFGPrinterObserver this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/graalvm/compiler/printer/CFGPrinterObserver;
}
SourceFile: "CFGPrinterObserver.java"
NestMembers:
  org.graalvm.compiler.printer.CFGPrinterObserver$1
InnerClasses:
  public ScheduleResult = org.graalvm.compiler.nodes.StructuredGraph$ScheduleResult of org.graalvm.compiler.nodes.StructuredGraph
  org.graalvm.compiler.printer.CFGPrinterObserver$1