public class org.graalvm.compiler.printer.GraphPrinterDumpHandler 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.GraphPrinterDumpHandler
  super_class: java.lang.Object
{
  private static final int FAILURE_LIMIT;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 8

  private final org.graalvm.compiler.printer.GraphPrinterDumpHandler$GraphPrinterSupplier printerSupplier;
    descriptor: Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler$GraphPrinterSupplier;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  protected org.graalvm.compiler.printer.GraphPrinter printer;
    descriptor: Lorg/graalvm/compiler/printer/GraphPrinter;
    flags: (0x0004) ACC_PROTECTED

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

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

  private int[] dumpIds;
    descriptor: [I
    flags: (0x0002) ACC_PRIVATE

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

  private java.util.Map<org.graalvm.compiler.graph.Graph, java.util.List<java.lang.String>> inlineContextMap;
    descriptor: Ljava/util/Map;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Map<Lorg/graalvm/compiler/graph/Graph;Ljava/util/List<Ljava/lang/String;>;>;

  private final java.lang.String jvmArguments;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String sunJavaCommand;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>(org.graalvm.compiler.printer.GraphPrinterDumpHandler$GraphPrinterSupplier);
    descriptor: (Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler$GraphPrinterSupplier;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
        start local 1 // org.graalvm.compiler.printer.GraphPrinterDumpHandler$GraphPrinterSupplier printerSupplier
         0: .line 88
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 70
            aload 0 /* this */
            getstatic org.graalvm.compiler.core.common.CompilationIdentifier.INVALID_COMPILATION_ID:Lorg/graalvm/compiler/core/common/CompilationRequestIdentifier;
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousCompilationID:Lorg/graalvm/compiler/core/common/CompilationIdentifier;
         2: .line 71
            aload 0 /* this */
            iconst_0
            newarray 10
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.dumpIds:[I
         3: .line 89
            aload 0 /* this */
            aload 1 /* printerSupplier */
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printerSupplier:Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler$GraphPrinterSupplier;
         4: .line 91
            aload 0 /* this */
            invokestatic org.graalvm.compiler.printer.GraphPrinterDumpHandler.jvmArguments:()Ljava/lang/String;
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.jvmArguments:Ljava/lang/String;
         5: .line 92
            aload 0 /* this */
            invokestatic jdk.vm.ci.services.Services.getSavedProperties:()Ljava/util/Map;
            ldc "sun.java.command"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.sunJavaCommand:Ljava/lang/String;
         6: .line 93
            return
        end local 1 // org.graalvm.compiler.printer.GraphPrinterDumpHandler$GraphPrinterSupplier printerSupplier
        end local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    7     0             this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            0    7     1  printerSupplier  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler$GraphPrinterSupplier;
    MethodParameters:
                 Name  Flags
      printerSupplier  

  private static java.lang.String jvmArguments();
    descriptor: ()Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 96
            invokestatic org.graalvm.compiler.serviceprovider.GraalServices.getInputArguments:()Ljava/util/List;
            astore 0 /* inputArguments */
        start local 0 // java.util.List inputArguments
         1: .line 97
            aload 0 /* inputArguments */
            ifnull 3
         2: .line 98
            ldc " "
            aload 0 /* inputArguments */
            invokestatic java.lang.String.join:(Ljava/lang/CharSequence;Ljava/lang/Iterable;)Ljava/lang/String;
            areturn
         3: .line 100
      StackMap locals: java.util.List
      StackMap stack:
            ldc "unknown"
            areturn
        end local 0 // java.util.List inputArguments
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            1    4     0  inputArguments  Ljava/util/List<Ljava/lang/String;>;

  private void ensureInitialized(org.graalvm.compiler.debug.DebugContext, org.graalvm.compiler.graph.Graph);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;Lorg/graalvm/compiler/graph/Graph;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=3
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
        start local 1 // org.graalvm.compiler.debug.DebugContext ctx
        start local 2 // org.graalvm.compiler.graph.Graph graph
         0: .line 104
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
            ifnonnull 10
         1: .line 105
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.failuresCount:I
            bipush 8
            if_icmplt 3
         2: .line 106
            return
         3: .line 108
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
         4: .line 109
            aload 0 /* this */
            new java.util.WeakHashMap
            dup
            invokespecial java.util.WeakHashMap.<init>:()V
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.inlineContextMap:Ljava/util/Map;
         5: .line 110
            aload 2 /* graph */
            invokevirtual org.graalvm.compiler.graph.Graph.getDebug:()Lorg/graalvm/compiler/debug/DebugContext;
            astore 3 /* debug */
        start local 3 // org.graalvm.compiler.debug.DebugContext debug
         6: .line 112
            aload 0 /* this */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printerSupplier:Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler$GraphPrinterSupplier;
            aload 1 /* ctx */
            aload 2 /* graph */
            invokeinterface org.graalvm.compiler.printer.GraphPrinterDumpHandler$GraphPrinterSupplier.get:(Lorg/graalvm/compiler/debug/DebugContext;Lorg/graalvm/compiler/graph/Graph;)Lorg/graalvm/compiler/printer/GraphPrinter;
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
         7: .line 113
            goto 10
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.Graph org.graalvm.compiler.debug.DebugContext
      StackMap stack: java.io.IOException
         8: astore 4 /* e */
        start local 4 // java.io.IOException e
         9: .line 114
            aload 0 /* this */
            aload 3 /* debug */
            aload 4 /* e */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.handleException:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/io/IOException;)V
        end local 4 // java.io.IOException e
        end local 3 // org.graalvm.compiler.debug.DebugContext debug
        10: .line 117
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.graalvm.compiler.graph.Graph graph
        end local 1 // org.graalvm.compiler.debug.DebugContext ctx
        end local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   11     0   this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            0   11     1    ctx  Lorg/graalvm/compiler/debug/DebugContext;
            0   11     2  graph  Lorg/graalvm/compiler/graph/Graph;
            6   10     3  debug  Lorg/graalvm/compiler/debug/DebugContext;
            9   10     4      e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           6     7       8  Class java.io.IOException
    MethodParameters:
       Name  Flags
      ctx    
      graph  

  private int nextDumpId();
    descriptor: ()I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
         0: .line 120
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            istore 1 /* depth */
        start local 1 // int depth
         1: .line 121
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.dumpIds:[I
            arraylength
            iload 1 /* depth */
            if_icmpge 3
         2: .line 122
            aload 0 /* this */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.dumpIds:[I
            iload 1 /* depth */
            invokestatic java.util.Arrays.copyOf:([II)[I
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.dumpIds:[I
         3: .line 124
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.dumpIds:[I
            iload 1 /* depth */
            iconst_1
            isub
            dup2
            iaload
            dup_x2
            iconst_1
            iadd
            iastore
            ireturn
        end local 1 // int depth
        end local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            1    4     1  depth  I

  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=7, locals=14, args_size=5
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler 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 130
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.getOptions:()Lorg/graalvm/compiler/options/OptionValues;
            astore 5 /* options */
        start local 5 // org.graalvm.compiler.options.OptionValues options
         1: .line 131
            aload 2 /* object */
            instanceof org.graalvm.compiler.graph.Graph
            ifeq 72
            getstatic org.graalvm.compiler.debug.DebugOptions.PrintGraph:Lorg/graalvm/compiler/options/EnumOptionKey;
            aload 5 /* options */
            invokevirtual org.graalvm.compiler.options.EnumOptionKey.getValue:(Lorg/graalvm/compiler/options/OptionValues;)Ljava/lang/Object;
            getstatic org.graalvm.compiler.debug.DebugOptions$PrintGraphTarget.Disable:Lorg/graalvm/compiler/debug/DebugOptions$PrintGraphTarget;
            if_acmpeq 72
         2: .line 132
            aload 2 /* object */
            checkcast org.graalvm.compiler.graph.Graph
            astore 6 /* graph */
        start local 6 // org.graalvm.compiler.graph.Graph graph
         3: .line 133
            aload 0 /* this */
            aload 1 /* debug */
            aload 6 /* graph */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.ensureInitialized:(Lorg/graalvm/compiler/debug/DebugContext;Lorg/graalvm/compiler/graph/Graph;)V
         4: .line 134
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
            ifnonnull 6
         5: .line 135
            return
         6: .line 139
      StackMap locals: org.graalvm.compiler.options.OptionValues org.graalvm.compiler.graph.Graph
      StackMap stack:
            aload 0 /* this */
            aload 6 /* graph */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.getInlineContext:(Lorg/graalvm/compiler/graph/Graph;)Ljava/util/List;
            astore 7 /* inlineContext */
        start local 7 // java.util.List inlineContext
         7: .line 141
            aload 6 /* graph */
            instanceof org.graalvm.compiler.nodes.StructuredGraph
            ifeq 18
         8: .line 142
            aload 6 /* graph */
            checkcast org.graalvm.compiler.nodes.StructuredGraph
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.compilationId:()Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            astore 8 /* compilationID */
        start local 8 // org.graalvm.compiler.core.common.CompilationIdentifier compilationID
         9: .line 145
            aload 8 /* compilationID */
            getstatic org.graalvm.compiler.core.common.CompilationIdentifier.INVALID_COMPILATION_ID:Lorg/graalvm/compiler/core/common/CompilationRequestIdentifier;
            if_acmpeq 18
        10: .line 146
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousCompilationID:Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            getstatic org.graalvm.compiler.core.common.CompilationIdentifier.INVALID_COMPILATION_ID:Lorg/graalvm/compiler/core/common/CompilationRequestIdentifier;
            if_acmpeq 17
            aload 8 /* compilationID */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousCompilationID:Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifne 17
        11: .line 148
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            istore 9 /* inlineDepth */
        start local 9 // int inlineDepth
        12: goto 15
        13: .line 149
      StackMap locals: java.util.List org.graalvm.compiler.core.common.CompilationIdentifier int
      StackMap stack:
            aload 0 /* this */
            aload 1 /* debug */
            iload 9 /* inlineDepth */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.closeScope:(Lorg/graalvm/compiler/debug/DebugContext;I)V
        14: .line 148
            iinc 9 /* inlineDepth */ -1
      StackMap locals:
      StackMap stack:
        15: iload 9 /* inlineDepth */
            ifge 13
        end local 9 // int inlineDepth
        16: .line 151
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
        17: .line 153
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 8 /* compilationID */
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousCompilationID:Lorg/graalvm/compiler/core/common/CompilationIdentifier;
        end local 8 // org.graalvm.compiler.core.common.CompilationIdentifier compilationID
        18: .line 157
      StackMap locals:
      StackMap stack:
            aload 7 /* inlineContext */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            invokeinterface java.util.List.equals:(Ljava/lang/Object;)Z
            ifne 46
        19: .line 158
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 8 /* properties */
        start local 8 // java.util.Map properties
        20: .line 159
            aload 8 /* properties */
            ldc "graph"
            aload 6 /* graph */
            invokevirtual org.graalvm.compiler.graph.Graph.toString:()Ljava/lang/String;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        21: .line 160
            aload 8 /* properties */
            aload 6 /* graph */
            invokestatic org.graalvm.compiler.printer.GraphPrinterDumpHandler.addCompilationId:(Ljava/util/Map;Lorg/graalvm/compiler/graph/Graph;)V
        22: .line 162
            iconst_0
            istore 9 /* i */
        start local 9 // int i
        23: goto 32
        24: .line 163
      StackMap locals: java.util.Map int
      StackMap stack:
            iload 9 /* i */
            aload 7 /* inlineContext */
            invokeinterface java.util.List.size:()I
            if_icmpge 25
            aload 7 /* inlineContext */
            iload 9 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.lang.String
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            iload 9 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 31
        25: .line 164
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            istore 10 /* inlineDepth */
        start local 10 // int inlineDepth
        26: goto 29
        27: .line 165
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            aload 1 /* debug */
            iload 10 /* inlineDepth */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.closeScope:(Lorg/graalvm/compiler/debug/DebugContext;I)V
        28: .line 164
            iinc 10 /* inlineDepth */ -1
      StackMap locals:
      StackMap stack:
        29: iload 10 /* inlineDepth */
            iload 9 /* i */
            if_icmpge 27
        end local 10 // int inlineDepth
        30: .line 167
            goto 33
        31: .line 162
      StackMap locals:
      StackMap stack:
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        32: iload 9 /* i */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            if_icmplt 24
        end local 9 // int i
        33: .line 171
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 9 /* i */
        start local 9 // int i
        34: goto 45
        35: .line 172
      StackMap locals: int
      StackMap stack:
            iload 9 /* i */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            if_icmpge 36
            aload 7 /* inlineContext */
            iload 9 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.lang.String
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            iload 9 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 44
        36: .line 173
      StackMap locals:
      StackMap stack:
            iload 9 /* i */
            istore 10 /* inlineDepth */
        start local 10 // int inlineDepth
        37: goto 42
        38: .line 174
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            aload 1 /* debug */
            aload 7 /* inlineContext */
            iload 10 /* inlineDepth */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.lang.String
            iload 10 /* inlineDepth */
            iload 10 /* inlineDepth */
            aload 7 /* inlineContext */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            if_icmpne 39
            aload 8 /* properties */
            goto 40
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String java.lang.Object[] org.graalvm.compiler.options.OptionValues org.graalvm.compiler.graph.Graph java.util.List java.util.Map int int
      StackMap stack: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext java.lang.String int
        39: aconst_null
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String java.lang.Object[] org.graalvm.compiler.options.OptionValues org.graalvm.compiler.graph.Graph java.util.List java.util.Map int int
      StackMap stack: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext java.lang.String int java.util.Map
        40: invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.openScope:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;ILjava/util/Map;)V
        41: .line 173
            iinc 10 /* inlineDepth */ 1
      StackMap locals:
      StackMap stack:
        42: iload 10 /* inlineDepth */
            aload 7 /* inlineContext */
            invokeinterface java.util.List.size:()I
            if_icmplt 38
        end local 10 // int inlineDepth
        43: .line 176
            goto 46
        44: .line 171
      StackMap locals:
      StackMap stack:
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        45: iload 9 /* i */
            aload 7 /* inlineContext */
            invokeinterface java.util.List.size:()I
            if_icmplt 35
        end local 9 // int i
        end local 8 // java.util.Map properties
        46: .line 182
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 7 /* inlineContext */
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
        47: .line 185
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.getCurrentScopeName:()Ljava/lang/String;
            astore 8 /* currentScopeName */
        start local 8 // java.lang.String currentScopeName
        48: .line 186
            aconst_null
            astore 9
            aconst_null
            astore 10
        49: aload 1 /* debug */
            ldc "PrintingGraph"
            aconst_null
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.debug.DebugContext.sandbox:(Ljava/lang/CharSequence;Lorg/graalvm/compiler/debug/DebugConfig;[Ljava/lang/Object;)Lorg/graalvm/compiler/debug/DebugContext$Scope;
            astore 11 /* s */
        start local 11 // org.graalvm.compiler.debug.DebugContext$Scope s
        50: .line 188
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 12 /* properties */
        start local 12 // java.util.Map properties
        51: .line 189
            aload 12 /* properties */
            ldc "graph"
            aload 6 /* graph */
            invokevirtual org.graalvm.compiler.graph.Graph.toString:()Ljava/lang/String;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        52: .line 190
            aload 12 /* properties */
            ldc "scope"
            aload 8 /* currentScopeName */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        53: .line 191
            aload 6 /* graph */
            instanceof org.graalvm.compiler.nodes.StructuredGraph
            ifeq 60
        54: .line 192
            aload 12 /* properties */
            ldc "compilationIdentifier"
            aload 6 /* graph */
            checkcast org.graalvm.compiler.nodes.StructuredGraph
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.compilationId:()Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        55: .line 194
            aload 6 /* graph */
            checkcast org.graalvm.compiler.nodes.StructuredGraph
            invokestatic org.graalvm.compiler.phases.contract.NodeCostUtil.computeGraphSize:(Lorg/graalvm/compiler/nodes/StructuredGraph;)I
            istore 13 /* size */
        start local 13 // int size
        56: .line 195
            aload 12 /* properties */
            ldc "node-cost graph size"
            iload 13 /* size */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 13 // int size
        57: .line 196
            goto 60
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String java.lang.Object[] org.graalvm.compiler.options.OptionValues org.graalvm.compiler.graph.Graph java.util.List java.lang.String java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugContext$Scope java.util.Map
      StackMap stack: java.lang.Throwable
        58: astore 13 /* t */
        start local 13 // java.lang.Throwable t
        59: .line 197
            aload 12 /* properties */
            ldc "node-cost-exception"
            aload 13 /* t */
            invokevirtual java.lang.Throwable.getMessage:()Ljava/lang/String;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 13 // java.lang.Throwable t
        60: .line 200
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
            aload 1 /* debug */
            aload 6 /* graph */
            aload 12 /* properties */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.nextDumpId:()I
            aload 3 /* format */
            aload 4 /* arguments */
            invokeinterface org.graalvm.compiler.printer.GraphPrinter.print:(Lorg/graalvm/compiler/debug/DebugContext;Lorg/graalvm/compiler/graph/Graph;Ljava/util/Map;ILjava/lang/String;[Ljava/lang/Object;)V
        end local 12 // java.util.Map properties
        61: .line 201
            aload 11 /* s */
            ifnull 72
            aload 11 /* s */
            invokeinterface org.graalvm.compiler.debug.DebugContext$Scope.close:()V
            goto 72
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String java.lang.Object[] org.graalvm.compiler.options.OptionValues org.graalvm.compiler.graph.Graph java.util.List java.lang.String java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugContext$Scope
      StackMap stack: java.lang.Throwable
        62: astore 9
            aload 11 /* s */
            ifnull 63
            aload 11 /* s */
            invokeinterface org.graalvm.compiler.debug.DebugContext$Scope.close:()V
        end local 11 // org.graalvm.compiler.debug.DebugContext$Scope s
      StackMap locals:
      StackMap stack:
        63: aload 9
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        64: astore 10
            aload 9
            ifnonnull 65
            aload 10
            astore 9
            goto 66
      StackMap locals:
      StackMap stack:
        65: aload 9
            aload 10
            if_acmpeq 66
            aload 9
            aload 10
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        66: aload 9
            athrow
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext java.lang.Object java.lang.String java.lang.Object[] org.graalvm.compiler.options.OptionValues org.graalvm.compiler.graph.Graph java.util.List java.lang.String
      StackMap stack: java.io.IOException
        67: astore 9 /* e */
        start local 9 // java.io.IOException e
        68: .line 202
            aload 0 /* this */
            aload 1 /* debug */
            aload 9 /* e */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.handleException:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/io/IOException;)V
        end local 9 // java.io.IOException e
        69: goto 72
        70: .line 203
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 9 /* e */
        start local 9 // java.lang.Throwable e
        71: .line 204
            aload 1 /* debug */
            aload 9 /* e */
            invokevirtual org.graalvm.compiler.debug.DebugContext.handle:(Ljava/lang/Throwable;)Ljava/lang/RuntimeException;
            athrow
        end local 9 // java.lang.Throwable e
        end local 8 // java.lang.String currentScopeName
        end local 7 // java.util.List inlineContext
        end local 6 // org.graalvm.compiler.graph.Graph graph
        72: .line 207
      StackMap locals:
      StackMap stack:
            return
        end local 5 // org.graalvm.compiler.options.OptionValues options
        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.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   73     0              this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            0   73     1             debug  Lorg/graalvm/compiler/debug/DebugContext;
            0   73     2            object  Ljava/lang/Object;
            0   73     3            format  Ljava/lang/String;
            0   73     4         arguments  [Ljava/lang/Object;
            1   73     5           options  Lorg/graalvm/compiler/options/OptionValues;
            3   72     6             graph  Lorg/graalvm/compiler/graph/Graph;
            7   72     7     inlineContext  Ljava/util/List<Ljava/lang/String;>;
            9   18     8     compilationID  Lorg/graalvm/compiler/core/common/CompilationIdentifier;
           12   16     9       inlineDepth  I
           20   46     8        properties  Ljava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;
           23   33     9                 i  I
           26   30    10       inlineDepth  I
           34   46     9                 i  I
           37   43    10       inlineDepth  I
           48   72     8  currentScopeName  Ljava/lang/String;
           50   63    11                 s  Lorg/graalvm/compiler/debug/DebugContext$Scope;
           51   61    12        properties  Ljava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;
           56   57    13              size  I
           59   60    13                 t  Ljava/lang/Throwable;
           68   69     9                 e  Ljava/io/IOException;
           71   72     9                 e  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
          55    57      58  Class java.lang.Throwable
          50    61      62  any
          49    64      64  any
          48    67      67  Class java.io.IOException
          48    67      70  Class java.lang.Throwable
    MethodParameters:
           Name  Flags
      debug      
      object     
      format     final
      arguments  

  void handleException(org.graalvm.compiler.debug.DebugContext, java.io.IOException);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;Ljava/io/IOException;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.io.IOException e
         0: .line 210
            aload 1 /* debug */
            ifnull 2
            getstatic org.graalvm.compiler.debug.DebugOptions.DumpingErrorsAreFatal:Lorg/graalvm/compiler/options/OptionKey;
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.getOptions:()Lorg/graalvm/compiler/options/OptionValues;
            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
            ifeq 2
         1: .line 211
            new org.graalvm.compiler.debug.GraalError
            dup
            aload 2 /* e */
            invokespecial org.graalvm.compiler.debug.GraalError.<init>:(Ljava/lang/Throwable;)V
            athrow
         2: .line 213
      StackMap locals:
      StackMap stack:
            aload 2 /* e */
            instanceof java.nio.channels.ClosedByInterruptException
            ifeq 5
         3: .line 217
            aload 0 /* this */
            iconst_0
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.failuresCount:I
         4: .line 218
            goto 6
         5: .line 219
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.failuresCount:I
            iconst_1
            iadd
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.failuresCount:I
         6: .line 221
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
         7: .line 222
            aload 2 /* e */
            getstatic org.graalvm.compiler.debug.TTY.out:Ljava/io/PrintStream;
            invokevirtual java.io.IOException.printStackTrace:(Ljava/io/PrintStream;)V
         8: .line 223
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.failuresCount:I
            bipush 8
            if_icmple 10
         9: .line 224
            new java.lang.StringBuilder
            dup
            ldc "Too many failures with dumping. Disabling dump in thread "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            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
        10: .line 226
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.io.IOException e
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   11     0   this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            0   11     1  debug  Lorg/graalvm/compiler/debug/DebugContext;
            0   11     2      e  Ljava/io/IOException;
    MethodParameters:
       Name  Flags
      debug  
      e      

  private static void addCompilationId(java.util.Map<java.lang.Object, java.lang.Object>, org.graalvm.compiler.graph.Graph);
    descriptor: (Ljava/util/Map;Lorg/graalvm/compiler/graph/Graph;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.util.Map properties
        start local 1 // org.graalvm.compiler.graph.Graph graph
         0: .line 229
            aload 1 /* graph */
            instanceof org.graalvm.compiler.nodes.StructuredGraph
            ifeq 2
         1: .line 230
            aload 0 /* properties */
            ldc "compilationId"
            aload 1 /* graph */
            checkcast org.graalvm.compiler.nodes.StructuredGraph
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.compilationId:()Lorg/graalvm/compiler/core/common/CompilationIdentifier;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 232
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.graalvm.compiler.graph.Graph graph
        end local 0 // java.util.Map properties
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0  properties  Ljava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;
            0    3     1       graph  Lorg/graalvm/compiler/graph/Graph;
    Signature: (Ljava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;Lorg/graalvm/compiler/graph/Graph;)V
    MethodParameters:
            Name  Flags
      properties  
      graph       final

  private java.util.List<java.lang.String> getInlineContext(org.graalvm.compiler.graph.Graph);
    descriptor: (Lorg/graalvm/compiler/graph/Graph;)Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=9, args_size=2
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
        start local 1 // org.graalvm.compiler.graph.Graph graph
         0: .line 235
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.inlineContextMap:Ljava/util/Map;
            aload 1 /* graph */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.List
            astore 2 /* result */
        start local 2 // java.util.List result
         1: .line 236
            aload 2 /* result */
            ifnonnull 34
         2: .line 237
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 2 /* result */
         3: .line 238
            aconst_null
            astore 3 /* lastMethodOrGraph */
        start local 3 // java.lang.Object lastMethodOrGraph
         4: .line 239
            iconst_0
            istore 4 /* graphSeen */
        start local 4 // boolean graphSeen
         5: .line 240
            aload 1 /* graph */
            invokevirtual org.graalvm.compiler.graph.Graph.getDebug:()Lorg/graalvm/compiler/debug/DebugContext;
            astore 5 /* debug */
        start local 5 // org.graalvm.compiler.debug.DebugContext debug
         6: .line 241
            aload 5 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.context:()Ljava/lang/Iterable;
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 7
            goto 20
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.graph.Graph java.util.List java.lang.Object int org.graalvm.compiler.debug.DebugContext top java.util.Iterator
      StackMap stack:
         7: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 6 /* o */
        start local 6 // java.lang.Object o
         8: .line 242
            aload 6 /* o */
            aload 1 /* graph */
            if_acmpne 10
         9: .line 243
            iconst_1
            istore 4 /* graphSeen */
        10: .line 246
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.graph.Graph java.util.List java.lang.Object int org.graalvm.compiler.debug.DebugContext java.lang.Object java.util.Iterator
      StackMap stack:
            aload 6 /* o */
            instanceof org.graalvm.compiler.debug.DebugDumpScope
            ifeq 17
        11: .line 247
            aload 6 /* o */
            checkcast org.graalvm.compiler.debug.DebugDumpScope
            astore 8 /* debugDumpScope */
        start local 8 // org.graalvm.compiler.debug.DebugDumpScope debugDumpScope
        12: .line 248
            aload 8 /* debugDumpScope */
            getfield org.graalvm.compiler.debug.DebugDumpScope.decorator:Z
            ifeq 15
            aload 2 /* result */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 15
        13: .line 249
            aload 2 /* result */
            aload 2 /* result */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            new java.lang.StringBuilder
            dup
            aload 8 /* debugDumpScope */
            getfield org.graalvm.compiler.debug.DebugDumpScope.name:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ":"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* result */
            aload 2 /* result */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface java.util.List.set:(ILjava/lang/Object;)Ljava/lang/Object;
            pop
        14: .line 250
            goto 18
        15: .line 251
      StackMap locals: org.graalvm.compiler.debug.DebugDumpScope
      StackMap stack:
            aload 2 /* result */
            aload 8 /* debugDumpScope */
            getfield org.graalvm.compiler.debug.DebugDumpScope.name:Ljava/lang/String;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 8 // org.graalvm.compiler.debug.DebugDumpScope debugDumpScope
        16: .line 253
            goto 18
        17: .line 254
      StackMap locals:
      StackMap stack:
            aload 2 /* result */
            aload 6 /* o */
            aload 3 /* lastMethodOrGraph */
            invokestatic org.graalvm.compiler.printer.GraphPrinterDumpHandler.addMethodContext:(Ljava/util/List;Ljava/lang/Object;Ljava/lang/Object;)V
        18: .line 256
      StackMap locals:
      StackMap stack:
            aload 6 /* o */
            instanceof jdk.vm.ci.meta.JavaMethod
            ifne 19
            aload 6 /* o */
            instanceof org.graalvm.compiler.graph.Graph
            ifeq 20
        19: .line 257
      StackMap locals:
      StackMap stack:
            aload 6 /* o */
            astore 3 /* lastMethodOrGraph */
        end local 6 // java.lang.Object o
        20: .line 241
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.graph.Graph java.util.List java.lang.Object int org.graalvm.compiler.debug.DebugContext top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        21: .line 260
            aload 2 /* result */
            invokeinterface java.util.List.size:()I
            iconst_2
            if_icmpne 24
            aload 2 /* result */
            iconst_1
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.lang.String
            ldc "TruffleGraal"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 24
        22: .line 261
            aload 2 /* result */
            invokeinterface java.util.List.clear:()V
        23: .line 262
            aload 2 /* result */
            ldc "Graal Graphs"
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        24: .line 264
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.graph.Graph java.util.List java.lang.Object int org.graalvm.compiler.debug.DebugContext
      StackMap stack:
            aload 2 /* result */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 27
        25: .line 265
            aload 2 /* result */
            aload 1 /* graph */
            invokevirtual org.graalvm.compiler.graph.Graph.toString:()Ljava/lang/String;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        26: .line 266
            iconst_1
            istore 4 /* graphSeen */
        27: .line 269
      StackMap locals:
      StackMap stack:
            aload 2 /* result */
            invokestatic java.util.Collections.reverse:(Ljava/util/List;)V
        28: .line 270
            iload 4 /* graphSeen */
            ifne 33
        29: .line 275
            aload 1 /* graph */
            invokestatic org.graalvm.compiler.debug.DebugConfig.asJavaMethod:(Ljava/lang/Object;)Ljdk/vm/ci/meta/JavaMethod;
            ifnull 32
        30: .line 276
            aload 2 /* result */
            aload 1 /* graph */
            aload 3 /* lastMethodOrGraph */
            invokestatic org.graalvm.compiler.printer.GraphPrinterDumpHandler.addMethodContext:(Ljava/util/List;Ljava/lang/Object;Ljava/lang/Object;)V
        31: .line 277
            goto 33
        32: .line 278
      StackMap locals:
      StackMap stack:
            aload 2 /* result */
            aload 1 /* graph */
            invokevirtual org.graalvm.compiler.graph.Graph.toString:()Ljava/lang/String;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        33: .line 281
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.inlineContextMap:Ljava/util/Map;
            aload 1 /* graph */
            aload 2 /* result */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 5 // org.graalvm.compiler.debug.DebugContext debug
        end local 4 // boolean graphSeen
        end local 3 // java.lang.Object lastMethodOrGraph
        34: .line 283
      StackMap locals:
      StackMap stack:
            aload 2 /* result */
            areturn
        end local 2 // java.util.List result
        end local 1 // org.graalvm.compiler.graph.Graph graph
        end local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   35     0               this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            0   35     1              graph  Lorg/graalvm/compiler/graph/Graph;
            1   35     2             result  Ljava/util/List<Ljava/lang/String;>;
            4   34     3  lastMethodOrGraph  Ljava/lang/Object;
            5   34     4          graphSeen  Z
            6   34     5              debug  Lorg/graalvm/compiler/debug/DebugContext;
            8   20     6                  o  Ljava/lang/Object;
           12   16     8     debugDumpScope  Lorg/graalvm/compiler/debug/DebugDumpScope;
    Signature: (Lorg/graalvm/compiler/graph/Graph;)Ljava/util/List<Ljava/lang/String;>;
    MethodParameters:
       Name  Flags
      graph  

  private static void addMethodContext(java.util.List<java.lang.String>, , );
    descriptor: (Ljava/util/List;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // java.util.List result
        start local 1 // java.lang.Object o
        start local 2 // java.lang.Object lastMethodOrGraph
         0: .line 287
            aload 1 /* o */
            invokestatic org.graalvm.compiler.debug.DebugConfig.asJavaMethod:(Ljava/lang/Object;)Ljdk/vm/ci/meta/JavaMethod;
            astore 3 /* method */
        start local 3 // jdk.vm.ci.meta.JavaMethod method
         1: .line 288
            aload 3 /* method */
            ifnull 5
         2: .line 295
            aload 2 /* lastMethodOrGraph */
            ifnull 4
            aload 2 /* lastMethodOrGraph */
            invokestatic org.graalvm.compiler.debug.DebugConfig.asJavaMethod:(Ljava/lang/Object;)Ljdk/vm/ci/meta/JavaMethod;
            ifnull 4
            aload 2 /* lastMethodOrGraph */
            invokestatic org.graalvm.compiler.debug.DebugConfig.asJavaMethod:(Ljava/lang/Object;)Ljdk/vm/ci/meta/JavaMethod;
            aload 3 /* method */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 4
         3: .line 296
            aload 2 /* lastMethodOrGraph */
            aload 1 /* o */
            if_acmpeq 5
            aload 2 /* lastMethodOrGraph */
            instanceof org.graalvm.compiler.graph.Graph
            ifeq 5
            aload 1 /* o */
            instanceof org.graalvm.compiler.graph.Graph
            ifeq 5
         4: .line 297
      StackMap locals: jdk.vm.ci.meta.JavaMethod
      StackMap stack:
            aload 0 /* result */
            aload 3 /* method */
            ldc "%H.%n(%p)"
            invokeinterface jdk.vm.ci.meta.JavaMethod.format:(Ljava/lang/String;)Ljava/lang/String;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         5: .line 307
      StackMap locals:
      StackMap stack:
            return
        end local 3 // jdk.vm.ci.meta.JavaMethod method
        end local 2 // java.lang.Object lastMethodOrGraph
        end local 1 // java.lang.Object o
        end local 0 // java.util.List result
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    6     0             result  Ljava/util/List<Ljava/lang/String;>;
            0    6     1                  o  Ljava/lang/Object;
            0    6     2  lastMethodOrGraph  Ljava/lang/Object;
            1    6     3             method  Ljdk/vm/ci/meta/JavaMethod;
    Signature: (Ljava/util/List<Ljava/lang/String;>;Ljava/lang/Object;Ljava/lang/Object;)V
    MethodParameters:
                   Name  Flags
      result             
      o                  
      lastMethodOrGraph  

  private void openScope(org.graalvm.compiler.debug.DebugContext, java.lang.String, int, java.util.Map<java.lang.Object, java.lang.Object>);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;ILjava/util/Map;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=6, args_size=5
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.lang.String name
        start local 3 // int inlineDepth
        start local 4 // java.util.Map properties
         0: .line 311
            aload 4 /* properties */
            astore 5 /* props */
        start local 5 // java.util.Map props
         1: .line 312
            iload 3 /* inlineDepth */
            ifne 8
         2: .line 314
            aload 5 /* props */
            ifnonnull 4
         3: .line 315
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 5 /* props */
         4: .line 317
      StackMap locals: java.util.Map
      StackMap stack:
            aload 5 /* props */
            ldc "jvmArguments"
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.jvmArguments:Ljava/lang/String;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 318
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.sunJavaCommand:Ljava/lang/String;
            ifnull 7
         6: .line 319
            aload 5 /* props */
            ldc "sun.java.command"
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.sunJavaCommand:Ljava/lang/String;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 321
      StackMap locals:
      StackMap stack:
            aload 5 /* props */
            ldc "date"
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            invokevirtual java.util.Date.toString:()Ljava/lang/String;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 323
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
            aload 1 /* debug */
            aload 2 /* name */
            aload 2 /* name */
            aload 1 /* debug */
            ldc Ljdk/vm/ci/meta/ResolvedJavaMethod;
            invokevirtual org.graalvm.compiler.debug.DebugContext.contextLookup:(Ljava/lang/Class;)Ljava/lang/Object;
            checkcast jdk.vm.ci.meta.ResolvedJavaMethod
            iconst_m1
            aload 5 /* props */
            invokeinterface org.graalvm.compiler.printer.GraphPrinter.beginGroup:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;Ljava/lang/String;Ljdk/vm/ci/meta/ResolvedJavaMethod;ILjava/util/Map;)V
        end local 5 // java.util.Map props
         9: .line 324
            goto 12
      StackMap locals: org.graalvm.compiler.printer.GraphPrinterDumpHandler org.graalvm.compiler.debug.DebugContext java.lang.String int java.util.Map
      StackMap stack: java.io.IOException
        10: astore 5 /* e */
        start local 5 // java.io.IOException e
        11: .line 325
            aload 0 /* this */
            aload 1 /* debug */
            aload 5 /* e */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.handleException:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/io/IOException;)V
        end local 5 // java.io.IOException e
        12: .line 327
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.util.Map properties
        end local 3 // int inlineDepth
        end local 2 // java.lang.String name
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   13     0         this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            0   13     1        debug  Lorg/graalvm/compiler/debug/DebugContext;
            0   13     2         name  Ljava/lang/String;
            0   13     3  inlineDepth  I
            0   13     4   properties  Ljava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;
            1    9     5        props  Ljava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;
           11   12     5            e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           0     9      10  Class java.io.IOException
    Signature: (Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;ILjava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;)V
    MethodParameters:
             Name  Flags
      debug        
      name         
      inlineDepth  
      properties   

  private void closeScope(org.graalvm.compiler.debug.DebugContext, int);
    descriptor: (Lorg/graalvm/compiler/debug/DebugContext;I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // int inlineDepth
         0: .line 330
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.dumpIds:[I
            iload 2 /* inlineDepth */
            iconst_0
            iastore
         1: .line 332
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
            ifnull 6
         2: .line 333
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
            invokeinterface org.graalvm.compiler.printer.GraphPrinter.endGroup:()V
         3: .line 335
            goto 6
      StackMap locals:
      StackMap stack: java.io.IOException
         4: astore 3 /* e */
        start local 3 // java.io.IOException e
         5: .line 336
            aload 0 /* this */
            aload 1 /* debug */
            aload 3 /* e */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.handleException:(Lorg/graalvm/compiler/debug/DebugContext;Ljava/io/IOException;)V
        end local 3 // java.io.IOException e
         6: .line 338
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int inlineDepth
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            0    7     1        debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    7     2  inlineDepth  I
            5    6     3            e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     3       4  Class java.io.IOException
    MethodParameters:
             Name  Flags
      debug        
      inlineDepth  

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
         0: .line 342
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            ifnull 6
         1: .line 343
            iconst_0
            istore 1 /* inlineDepth */
        start local 1 // int inlineDepth
         2: goto 5
         3: .line 344
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            aconst_null
            iload 1 /* inlineDepth */
            invokevirtual org.graalvm.compiler.printer.GraphPrinterDumpHandler.closeScope:(Lorg/graalvm/compiler/debug/DebugContext;I)V
         4: .line 343
            iinc 1 /* inlineDepth */ 1
      StackMap locals:
      StackMap stack:
         5: iload 1 /* inlineDepth */
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.previousInlineContext:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            if_icmplt 3
        end local 1 // int inlineDepth
         6: .line 347
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
            ifnull 9
         7: .line 348
            aload 0 /* this */
            getfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
            invokeinterface org.graalvm.compiler.printer.GraphPrinter.close:()V
         8: .line 349
            aload 0 /* this */
            aconst_null
            putfield org.graalvm.compiler.printer.GraphPrinterDumpHandler.printer:Lorg/graalvm/compiler/printer/GraphPrinter;
         9: .line 351
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.graalvm.compiler.printer.GraphPrinterDumpHandler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   10     0         this  Lorg/graalvm/compiler/printer/GraphPrinterDumpHandler;
            2    6     1  inlineDepth  I
}
SourceFile: "GraphPrinterDumpHandler.java"
NestMembers:
  org.graalvm.compiler.printer.GraphPrinterDumpHandler$GraphPrinterSupplier
InnerClasses:
  public abstract Scope = org.graalvm.compiler.debug.DebugContext$Scope of org.graalvm.compiler.debug.DebugContext
  public final PrintGraphTarget = org.graalvm.compiler.debug.DebugOptions$PrintGraphTarget of org.graalvm.compiler.debug.DebugOptions
  public abstract GraphPrinterSupplier = org.graalvm.compiler.printer.GraphPrinterDumpHandler$GraphPrinterSupplier of org.graalvm.compiler.printer.GraphPrinterDumpHandler