public final class org.graalvm.compiler.virtual.phases.ea.VirtualUtil
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.graalvm.compiler.virtual.phases.ea.VirtualUtil
  super_class: java.lang.Object
{
  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 45
            ldc Lorg/graalvm/compiler/virtual/phases/ea/VirtualUtil;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.graalvm.compiler.virtual.phases.ea.VirtualUtil.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.virtual.phases.ea.VirtualUtil this
         0: .line 47
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 48
            invokestatic org.graalvm.compiler.debug.GraalError.shouldNotReachHere:()Ljava/lang/RuntimeException;
            pop
         2: .line 49
            return
        end local 0 // org.graalvm.compiler.virtual.phases.ea.VirtualUtil this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/graalvm/compiler/virtual/phases/ea/VirtualUtil;

  public static boolean assertNonReachable(org.graalvm.compiler.nodes.StructuredGraph, java.util.List<org.graalvm.compiler.graph.Node>);
    descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/util/List;)Z
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=9, args_size=2
        start local 0 // org.graalvm.compiler.nodes.StructuredGraph graph
        start local 1 // java.util.List obsoleteNodes
         0: .line 56
            aload 0 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getDebug:()Lorg/graalvm/compiler/debug/DebugContext;
            astore 2 /* debug */
        start local 2 // org.graalvm.compiler.debug.DebugContext debug
         1: .line 57
            aload 0 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.createNodeFlood:()Lorg/graalvm/compiler/graph/NodeFlood;
            astore 3 /* flood */
        start local 3 // org.graalvm.compiler.graph.NodeFlood flood
         2: .line 58
            getstatic jdk.internal.vm.compiler.collections.Equivalence.IDENTITY:Ljdk/internal/vm/compiler/collections/Equivalence;
            invokestatic jdk.internal.vm.compiler.collections.EconomicMap.create:(Ljdk/internal/vm/compiler/collections/Equivalence;)Ljdk/internal/vm/compiler/collections/EconomicMap;
            astore 4 /* path */
        start local 4 // jdk.internal.vm.compiler.collections.EconomicMap path
         3: .line 59
            aload 3 /* flood */
            aload 0 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.start:()Lorg/graalvm/compiler/nodes/StartNode;
            invokevirtual org.graalvm.compiler.graph.NodeFlood.add:(Lorg/graalvm/compiler/graph/Node;)V
         4: .line 60
            aload 3 /* flood */
            invokevirtual org.graalvm.compiler.graph.NodeFlood.iterator:()Ljava/util/Iterator;
            astore 6
            goto 18
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap top java.util.Iterator
      StackMap stack:
         5: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 5 /* current */
        start local 5 // org.graalvm.compiler.graph.Node current
         6: .line 61
            aload 5 /* current */
            instanceof org.graalvm.compiler.nodes.AbstractEndNode
            ifeq 12
         7: .line 62
            aload 5 /* current */
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 7 /* end */
        start local 7 // org.graalvm.compiler.nodes.AbstractEndNode end
         8: .line 63
            aload 3 /* flood */
            aload 7 /* end */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            invokevirtual org.graalvm.compiler.graph.NodeFlood.add:(Lorg/graalvm/compiler/graph/Node;)V
         9: .line 64
            aload 4 /* path */
            aload 7 /* end */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.containsKey:(Ljava/lang/Object;)Z
            ifne 18
        10: .line 65
            aload 4 /* path */
            aload 7 /* end */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            aload 7 /* end */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 7 // org.graalvm.compiler.nodes.AbstractEndNode end
        11: .line 67
            goto 18
        12: .line 68
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap org.graalvm.compiler.graph.Node java.util.Iterator
      StackMap stack:
            aload 5 /* current */
            invokevirtual org.graalvm.compiler.graph.Node.successors:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 8
            goto 17
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap org.graalvm.compiler.graph.Node java.util.Iterator top java.util.Iterator
      StackMap stack:
        13: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 7 /* successor */
        start local 7 // org.graalvm.compiler.graph.Node successor
        14: .line 69
            aload 3 /* flood */
            aload 7 /* successor */
            invokevirtual org.graalvm.compiler.graph.NodeFlood.add:(Lorg/graalvm/compiler/graph/Node;)V
        15: .line 70
            aload 4 /* path */
            aload 7 /* successor */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.containsKey:(Ljava/lang/Object;)Z
            ifne 17
        16: .line 71
            aload 4 /* path */
            aload 7 /* successor */
            aload 5 /* current */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 7 // org.graalvm.compiler.graph.Node successor
        17: .line 68
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        end local 5 // org.graalvm.compiler.graph.Node current
        18: .line 60
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        19: .line 77
            aload 1 /* obsoleteNodes */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 23
      StackMap locals:
      StackMap stack:
        20: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 5 /* node */
        start local 5 // org.graalvm.compiler.graph.Node node
        21: .line 78
            aload 5 /* node */
            instanceof org.graalvm.compiler.nodes.FixedNode
            ifeq 23
            aload 5 /* node */
            invokevirtual org.graalvm.compiler.graph.Node.isDeleted:()Z
            ifne 23
        22: .line 79
            getstatic org.graalvm.compiler.virtual.phases.ea.VirtualUtil.$assertionsDisabled:Z
            ifne 23
            aload 3 /* flood */
            aload 5 /* node */
            invokevirtual org.graalvm.compiler.graph.NodeFlood.isMarked:(Lorg/graalvm/compiler/graph/Node;)Z
            ifeq 23
            new java.lang.AssertionError
            dup
            aload 5 /* node */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        end local 5 // org.graalvm.compiler.graph.Node node
        23: .line 77
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 20
        24: .line 83
            aload 0 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getNodes:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 6
            goto 33
      StackMap locals:
      StackMap stack:
        25: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 5 /* node */
        start local 5 // org.graalvm.compiler.graph.Node node
        26: .line 84
            aload 3 /* flood */
            aload 5 /* node */
            invokevirtual org.graalvm.compiler.graph.NodeFlood.isMarked:(Lorg/graalvm/compiler/graph/Node;)Z
            ifeq 33
        27: .line 85
            aload 5 /* node */
            invokevirtual org.graalvm.compiler.graph.Node.inputs:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 8
            goto 32
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap org.graalvm.compiler.graph.Node java.util.Iterator top java.util.Iterator
      StackMap stack:
        28: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 7 /* input */
        start local 7 // org.graalvm.compiler.graph.Node input
        29: .line 86
            aload 3 /* flood */
            aload 7 /* input */
            invokevirtual org.graalvm.compiler.graph.NodeFlood.add:(Lorg/graalvm/compiler/graph/Node;)V
        30: .line 87
            aload 4 /* path */
            aload 7 /* input */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.containsKey:(Ljava/lang/Object;)Z
            ifne 32
        31: .line 88
            aload 4 /* path */
            aload 7 /* input */
            aload 5 /* node */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 7 // org.graalvm.compiler.graph.Node input
        32: .line 85
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 28
        end local 5 // org.graalvm.compiler.graph.Node node
        33: .line 83
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 25
        34: .line 93
            aload 3 /* flood */
            invokevirtual org.graalvm.compiler.graph.NodeFlood.iterator:()Ljava/util/Iterator;
            astore 6
            goto 42
      StackMap locals:
      StackMap stack:
        35: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 5 /* current */
        start local 5 // org.graalvm.compiler.graph.Node current
        36: .line 94
            aload 5 /* current */
            invokevirtual org.graalvm.compiler.graph.Node.inputs:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 8
            goto 41
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap org.graalvm.compiler.graph.Node java.util.Iterator top java.util.Iterator
      StackMap stack:
        37: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 7 /* input */
        start local 7 // org.graalvm.compiler.graph.Node input
        38: .line 95
            aload 3 /* flood */
            aload 7 /* input */
            invokevirtual org.graalvm.compiler.graph.NodeFlood.add:(Lorg/graalvm/compiler/graph/Node;)V
        39: .line 96
            aload 4 /* path */
            aload 7 /* input */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.containsKey:(Ljava/lang/Object;)Z
            ifne 41
        40: .line 97
            aload 4 /* path */
            aload 7 /* input */
            aload 5 /* current */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 7 // org.graalvm.compiler.graph.Node input
        41: .line 94
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 37
        end local 5 // org.graalvm.compiler.graph.Node current
        42: .line 93
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 35
        43: .line 101
            iconst_1
            istore 5 /* success */
        start local 5 // boolean success
        44: .line 102
            aload 1 /* obsoleteNodes */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 55
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap int top java.util.Iterator
      StackMap stack:
        45: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 6 /* node */
        start local 6 // org.graalvm.compiler.graph.Node node
        46: .line 103
            aload 6 /* node */
            invokevirtual org.graalvm.compiler.graph.Node.isDeleted:()Z
            ifne 55
            aload 3 /* flood */
            aload 6 /* node */
            invokevirtual org.graalvm.compiler.graph.NodeFlood.isMarked:(Lorg/graalvm/compiler/graph/Node;)Z
            ifeq 55
            aload 6 /* node */
            invokevirtual org.graalvm.compiler.graph.Node.getNodeClass:()Lorg/graalvm/compiler/graph/NodeClass;
            invokevirtual org.graalvm.compiler.graph.NodeClass.valueNumberable:()Z
            ifne 55
        47: .line 104
            ldc "offending node path:"
            invokestatic org.graalvm.compiler.debug.TTY.println:(Ljava/lang/String;)V
        48: .line 105
            aload 6 /* node */
            astore 8 /* current */
        start local 8 // org.graalvm.compiler.graph.Node current
        49: .line 106
            aload 8 /* current */
            invokevirtual org.graalvm.compiler.graph.Node.toString:()Ljava/lang/String;
            invokestatic org.graalvm.compiler.debug.TTY.print:(Ljava/lang/String;)V
        50: .line 108
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap int org.graalvm.compiler.graph.Node java.util.Iterator org.graalvm.compiler.graph.Node
      StackMap stack:
            aload 4 /* path */
            aload 8 /* current */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 8 /* current */
        51: .line 109
            aload 8 /* current */
            ifnull 50
        52: .line 110
            new java.lang.StringBuilder
            dup
            ldc " -> "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* current */
            invokevirtual org.graalvm.compiler.graph.Node.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.graalvm.compiler.debug.TTY.print:(Ljava/lang/String;)V
        53: .line 111
            aload 8 /* current */
            instanceof org.graalvm.compiler.nodes.FixedNode
            ifeq 50
            aload 1 /* obsoleteNodes */
            aload 8 /* current */
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifne 50
        54: .line 116
            iconst_0
            istore 5 /* success */
        end local 8 // org.graalvm.compiler.graph.Node current
        end local 6 // org.graalvm.compiler.graph.Node node
        55: .line 102
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap int top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 45
        56: .line 119
            iload 5 /* success */
            ifne 59
        57: .line 120
            invokestatic org.graalvm.compiler.debug.TTY.println:()V
        58: .line 121
            aload 2 /* debug */
            aload 0 /* graph */
            ldc "assertNonReachable"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.debug.DebugContext.forceDump:(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
        59: .line 123
      StackMap locals: org.graalvm.compiler.nodes.StructuredGraph java.util.List org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.graph.NodeFlood jdk.internal.vm.compiler.collections.EconomicMap int
      StackMap stack:
            iload 5 /* success */
            ireturn
        end local 5 // boolean success
        end local 4 // jdk.internal.vm.compiler.collections.EconomicMap path
        end local 3 // org.graalvm.compiler.graph.NodeFlood flood
        end local 2 // org.graalvm.compiler.debug.DebugContext debug
        end local 1 // java.util.List obsoleteNodes
        end local 0 // org.graalvm.compiler.nodes.StructuredGraph graph
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   60     0          graph  Lorg/graalvm/compiler/nodes/StructuredGraph;
            0   60     1  obsoleteNodes  Ljava/util/List<Lorg/graalvm/compiler/graph/Node;>;
            1   60     2          debug  Lorg/graalvm/compiler/debug/DebugContext;
            2   60     3          flood  Lorg/graalvm/compiler/graph/NodeFlood;
            3   60     4           path  Ljdk/internal/vm/compiler/collections/EconomicMap<Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;>;
            6   18     5        current  Lorg/graalvm/compiler/graph/Node;
            8   11     7            end  Lorg/graalvm/compiler/nodes/AbstractEndNode;
           14   17     7      successor  Lorg/graalvm/compiler/graph/Node;
           21   23     5           node  Lorg/graalvm/compiler/graph/Node;
           26   33     5           node  Lorg/graalvm/compiler/graph/Node;
           29   32     7          input  Lorg/graalvm/compiler/graph/Node;
           36   42     5        current  Lorg/graalvm/compiler/graph/Node;
           38   41     7          input  Lorg/graalvm/compiler/graph/Node;
           44   60     5        success  Z
           46   55     6           node  Lorg/graalvm/compiler/graph/Node;
           49   55     8        current  Lorg/graalvm/compiler/graph/Node;
    Signature: (Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/util/List<Lorg/graalvm/compiler/graph/Node;>;)Z
    MethodParameters:
               Name  Flags
      graph          
      obsoleteNodes  

  public static void trace(org.graalvm.compiler.options.OptionValues, org.graalvm.compiler.debug.DebugContext, java.lang.String);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.options.OptionValues options
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.lang.String msg
         0: .line 127
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.areScopesEnabled:()Z
            ifeq 2
            getstatic org.graalvm.compiler.core.common.GraalOptions.TraceEscapeAnalysis:Lorg/graalvm/compiler/options/OptionKey;
            aload 0 /* 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
            ifeq 2
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.isLogEnabled:()Z
            ifeq 2
         1: .line 128
            aload 1 /* debug */
            aload 2 /* msg */
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(Ljava/lang/String;)V
         2: .line 130
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String msg
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.options.OptionValues options
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0  options  Lorg/graalvm/compiler/options/OptionValues;
            0    3     1    debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    3     2      msg  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      options  
      debug    
      msg      

  public static void trace(org.graalvm.compiler.options.OptionValues, org.graalvm.compiler.debug.DebugContext, java.lang.String, java.lang.Object);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // org.graalvm.compiler.options.OptionValues options
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.lang.String format
        start local 3 // java.lang.Object obj
         0: .line 133
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.areScopesEnabled:()Z
            ifeq 2
            getstatic org.graalvm.compiler.core.common.GraalOptions.TraceEscapeAnalysis:Lorg/graalvm/compiler/options/OptionKey;
            aload 0 /* 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
            ifeq 2
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.isLogEnabled:()Z
            ifeq 2
         1: .line 134
            aload 1 /* debug */
            aload 2 /* format */
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* obj */
            aastore
            invokevirtual org.graalvm.compiler.debug.DebugContext.logv:(Ljava/lang/String;[Ljava/lang/Object;)V
         2: .line 136
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.Object obj
        end local 2 // java.lang.String format
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.options.OptionValues options
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0  options  Lorg/graalvm/compiler/options/OptionValues;
            0    3     1    debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    3     2   format  Ljava/lang/String;
            0    3     3      obj  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      options  
      debug    
      format   
      obj      

  public static void trace(org.graalvm.compiler.options.OptionValues, org.graalvm.compiler.debug.DebugContext, java.lang.String, java.lang.Object, java.lang.Object);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=5, args_size=5
        start local 0 // org.graalvm.compiler.options.OptionValues options
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.lang.String format
        start local 3 // java.lang.Object obj
        start local 4 // java.lang.Object obj2
         0: .line 139
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.areScopesEnabled:()Z
            ifeq 2
            getstatic org.graalvm.compiler.core.common.GraalOptions.TraceEscapeAnalysis:Lorg/graalvm/compiler/options/OptionKey;
            aload 0 /* 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
            ifeq 2
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.isLogEnabled:()Z
            ifeq 2
         1: .line 140
            aload 1 /* debug */
            aload 2 /* format */
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* obj */
            aastore
            dup
            iconst_1
            aload 4 /* obj2 */
            aastore
            invokevirtual org.graalvm.compiler.debug.DebugContext.logv:(Ljava/lang/String;[Ljava/lang/Object;)V
         2: .line 142
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.lang.Object obj2
        end local 3 // java.lang.Object obj
        end local 2 // java.lang.String format
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.options.OptionValues options
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0  options  Lorg/graalvm/compiler/options/OptionValues;
            0    3     1    debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    3     2   format  Ljava/lang/String;
            0    3     3      obj  Ljava/lang/Object;
            0    3     4     obj2  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      options  
      debug    
      format   
      obj      
      obj2     

  public static void trace(org.graalvm.compiler.options.OptionValues, org.graalvm.compiler.debug.DebugContext, java.lang.String, java.lang.Object, java.lang.Object, java.lang.Object);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=6, args_size=6
        start local 0 // org.graalvm.compiler.options.OptionValues options
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.lang.String format
        start local 3 // java.lang.Object obj
        start local 4 // java.lang.Object obj2
        start local 5 // java.lang.Object obj3
         0: .line 145
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.areScopesEnabled:()Z
            ifeq 2
            getstatic org.graalvm.compiler.core.common.GraalOptions.TraceEscapeAnalysis:Lorg/graalvm/compiler/options/OptionKey;
            aload 0 /* 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
            ifeq 2
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.isLogEnabled:()Z
            ifeq 2
         1: .line 146
            aload 1 /* debug */
            aload 2 /* format */
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* obj */
            aastore
            dup
            iconst_1
            aload 4 /* obj2 */
            aastore
            dup
            iconst_2
            aload 5 /* obj3 */
            aastore
            invokevirtual org.graalvm.compiler.debug.DebugContext.logv:(Ljava/lang/String;[Ljava/lang/Object;)V
         2: .line 148
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.lang.Object obj3
        end local 4 // java.lang.Object obj2
        end local 3 // java.lang.Object obj
        end local 2 // java.lang.String format
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.options.OptionValues options
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0  options  Lorg/graalvm/compiler/options/OptionValues;
            0    3     1    debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    3     2   format  Ljava/lang/String;
            0    3     3      obj  Ljava/lang/Object;
            0    3     4     obj2  Ljava/lang/Object;
            0    3     5     obj3  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      options  
      debug    
      format   
      obj      
      obj2     
      obj3     

  public static void trace(org.graalvm.compiler.options.OptionValues, org.graalvm.compiler.debug.DebugContext, java.lang.String, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object);
    descriptor: (Lorg/graalvm/compiler/options/OptionValues;Lorg/graalvm/compiler/debug/DebugContext;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=7, args_size=7
        start local 0 // org.graalvm.compiler.options.OptionValues options
        start local 1 // org.graalvm.compiler.debug.DebugContext debug
        start local 2 // java.lang.String format
        start local 3 // java.lang.Object obj
        start local 4 // java.lang.Object obj2
        start local 5 // java.lang.Object obj3
        start local 6 // java.lang.Object obj4
         0: .line 151
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.areScopesEnabled:()Z
            ifeq 2
            getstatic org.graalvm.compiler.core.common.GraalOptions.TraceEscapeAnalysis:Lorg/graalvm/compiler/options/OptionKey;
            aload 0 /* 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
            ifeq 2
            aload 1 /* debug */
            invokevirtual org.graalvm.compiler.debug.DebugContext.isLogEnabled:()Z
            ifeq 2
         1: .line 152
            aload 1 /* debug */
            aload 2 /* format */
            iconst_4
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* obj */
            aastore
            dup
            iconst_1
            aload 4 /* obj2 */
            aastore
            dup
            iconst_2
            aload 5 /* obj3 */
            aastore
            dup
            iconst_3
            aload 6 /* obj4 */
            aastore
            invokevirtual org.graalvm.compiler.debug.DebugContext.logv:(Ljava/lang/String;[Ljava/lang/Object;)V
         2: .line 154
      StackMap locals:
      StackMap stack:
            return
        end local 6 // java.lang.Object obj4
        end local 5 // java.lang.Object obj3
        end local 4 // java.lang.Object obj2
        end local 3 // java.lang.Object obj
        end local 2 // java.lang.String format
        end local 1 // org.graalvm.compiler.debug.DebugContext debug
        end local 0 // org.graalvm.compiler.options.OptionValues options
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0  options  Lorg/graalvm/compiler/options/OptionValues;
            0    3     1    debug  Lorg/graalvm/compiler/debug/DebugContext;
            0    3     2   format  Ljava/lang/String;
            0    3     3      obj  Ljava/lang/Object;
            0    3     4     obj2  Ljava/lang/Object;
            0    3     5     obj3  Ljava/lang/Object;
            0    3     6     obj4  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      options  
      debug    
      format   
      obj      
      obj2     
      obj3     
      obj4     

  public static boolean matches(org.graalvm.compiler.nodes.StructuredGraph, java.lang.String);
    descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/String;)Z
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.StructuredGraph graph
        start local 1 // java.lang.String filter
         0: .line 157
            aload 1 /* filter */
            ifnull 2
         1: .line 158
            aload 0 /* graph */
            aload 1 /* filter */
            invokestatic org.graalvm.compiler.virtual.phases.ea.VirtualUtil.matchesHelper:(Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/String;)Z
            ireturn
         2: .line 160
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 1 // java.lang.String filter
        end local 0 // org.graalvm.compiler.nodes.StructuredGraph graph
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0   graph  Lorg/graalvm/compiler/nodes/StructuredGraph;
            0    3     1  filter  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      graph   
      filter  

  private static boolean matchesHelper(org.graalvm.compiler.nodes.StructuredGraph, java.lang.String);
    descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/String;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.graalvm.compiler.nodes.StructuredGraph graph
        start local 1 // java.lang.String filter
         0: .line 164
            aload 1 /* filter */
            ldc "~"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 4
         1: .line 165
            aload 0 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.method:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            astore 2 /* method */
        start local 2 // jdk.vm.ci.meta.ResolvedJavaMethod method
         2: .line 166
            aload 2 /* method */
            ifnull 3
            aload 2 /* method */
            ldc "%H.%n"
            invokeinterface jdk.vm.ci.meta.ResolvedJavaMethod.format:(Ljava/lang/String;)Ljava/lang/String;
            aload 1 /* filter */
            iconst_1
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 3
            iconst_0
            ireturn
      StackMap locals: jdk.vm.ci.meta.ResolvedJavaMethod
      StackMap stack:
         3: iconst_1
            ireturn
        end local 2 // jdk.vm.ci.meta.ResolvedJavaMethod method
         4: .line 168
      StackMap locals:
      StackMap stack:
            aload 0 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.method:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            astore 2 /* method */
        start local 2 // jdk.vm.ci.meta.ResolvedJavaMethod method
         5: .line 169
            aload 2 /* method */
            ifnull 6
            aload 2 /* method */
            ldc "%H.%n"
            invokeinterface jdk.vm.ci.meta.ResolvedJavaMethod.format:(Ljava/lang/String;)Ljava/lang/String;
            aload 1 /* filter */
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 6
            iconst_1
            ireturn
      StackMap locals: jdk.vm.ci.meta.ResolvedJavaMethod
      StackMap stack:
         6: iconst_0
            ireturn
        end local 2 // jdk.vm.ci.meta.ResolvedJavaMethod method
        end local 1 // java.lang.String filter
        end local 0 // org.graalvm.compiler.nodes.StructuredGraph graph
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0   graph  Lorg/graalvm/compiler/nodes/StructuredGraph;
            0    7     1  filter  Ljava/lang/String;
            2    4     2  method  Ljdk/vm/ci/meta/ResolvedJavaMethod;
            5    7     2  method  Ljdk/vm/ci/meta/ResolvedJavaMethod;
    MethodParameters:
        Name  Flags
      graph   
      filter  
}
SourceFile: "VirtualUtil.java"