public class org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase<C extends org.graalvm.compiler.phases.tiers.PhaseContext> extends org.graalvm.compiler.phases.PhaseSuite<C>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase
  super_class: org.graalvm.compiler.phases.PhaseSuite
{
  private final java.lang.String message;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>(java.lang.String, org.graalvm.compiler.phases.BasePhase<C>);
    descriptor: (Ljava/lang/String;Lorg/graalvm/compiler/phases/BasePhase;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase this
        start local 1 // java.lang.String message
        start local 2 // org.graalvm.compiler.phases.BasePhase phase
         0: .line 52
            aload 0 /* this */
            invokespecial org.graalvm.compiler.phases.PhaseSuite.<init>:()V
         1: .line 53
            aload 0 /* this */
            aload 1 /* message */
            putfield org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase.message:Ljava/lang/String;
         2: .line 54
            aload 0 /* this */
            aload 2 /* phase */
            invokevirtual org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase.appendPhase:(Lorg/graalvm/compiler/phases/BasePhase;)V
         3: .line 55
            return
        end local 2 // org.graalvm.compiler.phases.BasePhase phase
        end local 1 // java.lang.String message
        end local 0 // org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0     this  Lorg/graalvm/compiler/core/phases/GraphChangeMonitoringPhase<TC;>;
            0    4     1  message  Ljava/lang/String;
            0    4     2    phase  Lorg/graalvm/compiler/phases/BasePhase<TC;>;
    Signature: (Ljava/lang/String;Lorg/graalvm/compiler/phases/BasePhase<TC;>;)V
    MethodParameters:
         Name  Flags
      message  
      phase    

  public void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase this
        start local 1 // java.lang.String message
         0: .line 58
            aload 0 /* this */
            invokespecial org.graalvm.compiler.phases.PhaseSuite.<init>:()V
         1: .line 59
            aload 0 /* this */
            aload 1 /* message */
            putfield org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase.message:Ljava/lang/String;
         2: .line 60
            return
        end local 1 // java.lang.String message
        end local 0 // org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lorg/graalvm/compiler/core/phases/GraphChangeMonitoringPhase<TC;>;
            0    3     1  message  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      message  

  protected void run(org.graalvm.compiler.nodes.StructuredGraph, );
    descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;Lorg/graalvm/compiler/phases/tiers/PhaseContext;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=13, args_size=3
        start local 0 // org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase this
        start local 1 // org.graalvm.compiler.nodes.StructuredGraph graph
        start local 2 // org.graalvm.compiler.phases.tiers.PhaseContext context
         0: .line 69
            new org.graalvm.compiler.phases.common.util.HashSetNodeEventListener
            dup
            invokespecial org.graalvm.compiler.phases.common.util.HashSetNodeEventListener.<init>:()V
            getstatic org.graalvm.compiler.graph.Graph$NodeEvent.NODE_ADDED:Lorg/graalvm/compiler/graph/Graph$NodeEvent;
            invokevirtual org.graalvm.compiler.phases.common.util.HashSetNodeEventListener.exclude:(Lorg/graalvm/compiler/graph/Graph$NodeEvent;)Lorg/graalvm/compiler/phases/common/util/HashSetNodeEventListener;
            astore 3 /* listener */
        start local 3 // org.graalvm.compiler.phases.common.util.HashSetNodeEventListener listener
         1: .line 70
            aload 1 /* graph */
            aload 1 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getDebug:()Lorg/graalvm/compiler/debug/DebugContext;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.copy:(Lorg/graalvm/compiler/debug/DebugContext;)Lorg/graalvm/compiler/graph/Graph;
            checkcast org.graalvm.compiler.nodes.StructuredGraph
            astore 4 /* graphCopy */
        start local 4 // org.graalvm.compiler.nodes.StructuredGraph graphCopy
         2: .line 71
            aload 1 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getDebug:()Lorg/graalvm/compiler/debug/DebugContext;
            astore 5 /* debug */
        start local 5 // org.graalvm.compiler.debug.DebugContext debug
         3: .line 72
            aconst_null
            astore 6
            aconst_null
            astore 7
         4: aload 4 /* graphCopy */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.trackNodeEvents:(Lorg/graalvm/compiler/graph/Graph$NodeEventListener;)Lorg/graalvm/compiler/graph/Graph$NodeEventScope;
            astore 8 /* s */
        start local 8 // org.graalvm.compiler.graph.Graph$NodeEventScope s
         5: .line 73
            aconst_null
            astore 9
            aconst_null
            astore 10
         6: aload 5 /* debug */
            ldc "WithoutMonitoring"
            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 /* s2 */
        start local 11 // org.graalvm.compiler.debug.DebugContext$Scope s2
         7: .line 74
            aload 0 /* this */
            aload 4 /* graphCopy */
            aload 2 /* context */
            invokespecial org.graalvm.compiler.phases.PhaseSuite.run:(Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;)V
         8: .line 75
            aload 11 /* s2 */
            ifnull 16
            aload 11 /* s2 */
            invokeinterface org.graalvm.compiler.debug.DebugContext$Scope.close:()V
            goto 16
      StackMap locals: org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.phases.tiers.PhaseContext org.graalvm.compiler.phases.common.util.HashSetNodeEventListener org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.debug.DebugContext java.lang.Throwable java.lang.Throwable org.graalvm.compiler.graph.Graph$NodeEventScope java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugContext$Scope
      StackMap stack: java.lang.Throwable
         9: astore 9
            aload 11 /* s2 */
            ifnull 10
            aload 11 /* s2 */
            invokeinterface org.graalvm.compiler.debug.DebugContext$Scope.close:()V
        end local 11 // org.graalvm.compiler.debug.DebugContext$Scope s2
      StackMap locals:
      StackMap stack:
        10: aload 9
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        11: astore 10
            aload 9
            ifnonnull 12
            aload 10
            astore 9
            goto 13
      StackMap locals:
      StackMap stack:
        12: aload 9
            aload 10
            if_acmpeq 13
            aload 9
            aload 10
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        13: aload 9
            athrow
      StackMap locals: org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.phases.tiers.PhaseContext org.graalvm.compiler.phases.common.util.HashSetNodeEventListener org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.debug.DebugContext java.lang.Throwable java.lang.Throwable org.graalvm.compiler.graph.Graph$NodeEventScope
      StackMap stack: java.lang.Throwable
        14: astore 9 /* t */
        start local 9 // java.lang.Throwable t
        15: .line 76
            aload 5 /* debug */
            aload 9 /* t */
            invokevirtual org.graalvm.compiler.debug.DebugContext.handle:(Ljava/lang/Throwable;)Ljava/lang/RuntimeException;
            pop
        end local 9 // java.lang.Throwable t
        16: .line 78
      StackMap locals:
      StackMap stack:
            aload 8 /* s */
            ifnull 22
            aload 8 /* s */
            invokevirtual org.graalvm.compiler.graph.Graph$NodeEventScope.close:()V
            goto 22
      StackMap locals:
      StackMap stack: java.lang.Throwable
        17: astore 6
            aload 8 /* s */
            ifnull 18
            aload 8 /* s */
            invokevirtual org.graalvm.compiler.graph.Graph$NodeEventScope.close:()V
        end local 8 // org.graalvm.compiler.graph.Graph$NodeEventScope s
      StackMap locals:
      StackMap stack:
        18: aload 6
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        19: astore 7
            aload 6
            ifnonnull 20
            aload 7
            astore 6
            goto 21
      StackMap locals:
      StackMap stack:
        20: aload 6
            aload 7
            if_acmpeq 21
            aload 6
            aload 7
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        21: aload 6
            athrow
        22: .line 80
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.util.Equivalence.IDENTITY:Lorg/graalvm/util/Equivalence;
            invokestatic org.graalvm.util.EconomicSet.create:(Lorg/graalvm/util/Equivalence;)Lorg/graalvm/util/EconomicSet;
            astore 6 /* filteredNodes */
        start local 6 // org.graalvm.util.EconomicSet filteredNodes
        23: .line 81
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.phases.common.util.HashSetNodeEventListener.getNodes:()Lorg/graalvm/util/EconomicSet;
            invokeinterface org.graalvm.util.EconomicSet.iterator:()Ljava/util/Iterator;
            astore 8
            goto 27
      StackMap locals: org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.phases.tiers.PhaseContext org.graalvm.compiler.phases.common.util.HashSetNodeEventListener org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.debug.DebugContext org.graalvm.util.EconomicSet top java.util.Iterator
      StackMap stack:
        24: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 7 /* n */
        start local 7 // org.graalvm.compiler.graph.Node n
        25: .line 82
            aload 7 /* n */
            instanceof org.graalvm.compiler.nodes.LogicConstantNode
            ifne 27
        26: .line 86
            aload 6 /* filteredNodes */
            aload 7 /* n */
            invokeinterface org.graalvm.util.EconomicSet.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // org.graalvm.compiler.graph.Node n
        27: .line 81
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 24
        28: .line 89
            aload 6 /* filteredNodes */
            invokeinterface org.graalvm.util.EconomicSet.isEmpty:()Z
            ifne 52
        29: .line 91
            new org.graalvm.compiler.phases.common.util.HashSetNodeEventListener
            dup
            invokespecial org.graalvm.compiler.phases.common.util.HashSetNodeEventListener.<init>:()V
            astore 3 /* listener */
        30: .line 92
            aconst_null
            astore 7
            aconst_null
            astore 8
        31: aload 1 /* graph */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.trackNodeEvents:(Lorg/graalvm/compiler/graph/Graph$NodeEventListener;)Lorg/graalvm/compiler/graph/Graph$NodeEventScope;
            astore 9 /* s */
        start local 9 // org.graalvm.compiler.graph.Graph$NodeEventScope s
        32: .line 93
            aconst_null
            astore 10
            aconst_null
            astore 11
        33: aload 5 /* debug */
            ldc "WithGraphChangeMonitoring"
            invokevirtual org.graalvm.compiler.debug.DebugContext.scope:(Ljava/lang/Object;)Lorg/graalvm/compiler/debug/DebugContext$Scope;
            astore 12 /* s2 */
        start local 12 // org.graalvm.compiler.debug.DebugContext$Scope s2
        34: .line 94
            aload 5 /* debug */
            iconst_4
            invokevirtual org.graalvm.compiler.debug.DebugContext.isDumpEnabled:(I)Z
            ifeq 36
        35: .line 95
            aload 5 /* debug */
            iconst_4
            aload 1 /* graph */
            ldc "*** Before phase %s"
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase.getName:()Ljava/lang/CharSequence;
            invokevirtual org.graalvm.compiler.debug.DebugContext.dump:(ILjava/lang/Object;Ljava/lang/String;Ljava/lang/Object;)V
        36: .line 97
      StackMap locals: org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.phases.tiers.PhaseContext org.graalvm.compiler.phases.common.util.HashSetNodeEventListener org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.debug.DebugContext org.graalvm.util.EconomicSet java.lang.Throwable java.lang.Throwable org.graalvm.compiler.graph.Graph$NodeEventScope java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugContext$Scope
      StackMap stack:
            aload 0 /* this */
            aload 1 /* graph */
            aload 2 /* context */
            invokespecial org.graalvm.compiler.phases.PhaseSuite.run:(Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;)V
        37: .line 98
            aload 5 /* debug */
            iconst_4
            invokevirtual org.graalvm.compiler.debug.DebugContext.isDumpEnabled:(I)Z
            ifeq 39
        38: .line 99
            aload 5 /* debug */
            iconst_4
            aload 1 /* graph */
            ldc "*** After phase %s %s"
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase.getName:()Ljava/lang/CharSequence;
            aload 6 /* filteredNodes */
            invokevirtual org.graalvm.compiler.debug.DebugContext.dump:(ILjava/lang/Object;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        39: .line 101
      StackMap locals:
      StackMap stack:
            aload 5 /* debug */
            ldc "*** %s %s %s\n"
            aload 0 /* this */
            getfield org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase.message:Ljava/lang/String;
            aload 1 /* graph */
            aload 6 /* filteredNodes */
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        40: .line 102
            aload 12 /* s2 */
            ifnull 46
            aload 12 /* s2 */
            invokeinterface org.graalvm.compiler.debug.DebugContext$Scope.close:()V
            goto 46
      StackMap locals:
      StackMap stack: java.lang.Throwable
        41: astore 10
            aload 12 /* s2 */
            ifnull 42
            aload 12 /* s2 */
            invokeinterface org.graalvm.compiler.debug.DebugContext$Scope.close:()V
        end local 12 // org.graalvm.compiler.debug.DebugContext$Scope s2
      StackMap locals:
      StackMap stack:
        42: aload 10
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        43: astore 11
            aload 10
            ifnonnull 44
            aload 11
            astore 10
            goto 45
      StackMap locals:
      StackMap stack:
        44: aload 10
            aload 11
            if_acmpeq 45
            aload 10
            aload 11
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        45: aload 10
            athrow
        46: .line 103
      StackMap locals:
      StackMap stack:
            aload 9 /* s */
            ifnull 53
            aload 9 /* s */
            invokevirtual org.graalvm.compiler.graph.Graph$NodeEventScope.close:()V
            goto 53
      StackMap locals:
      StackMap stack: java.lang.Throwable
        47: astore 7
            aload 9 /* s */
            ifnull 48
            aload 9 /* s */
            invokevirtual org.graalvm.compiler.graph.Graph$NodeEventScope.close:()V
        end local 9 // org.graalvm.compiler.graph.Graph$NodeEventScope s
      StackMap locals:
      StackMap stack:
        48: aload 7
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        49: astore 8
            aload 7
            ifnonnull 50
            aload 8
            astore 7
            goto 51
      StackMap locals:
      StackMap stack:
        50: aload 7
            aload 8
            if_acmpeq 51
            aload 7
            aload 8
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        51: aload 7
            athrow
        52: .line 106
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* graph */
            aload 2 /* context */
            invokespecial org.graalvm.compiler.phases.PhaseSuite.run:(Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;)V
        53: .line 108
      StackMap locals:
      StackMap stack:
            return
        end local 6 // org.graalvm.util.EconomicSet filteredNodes
        end local 5 // org.graalvm.compiler.debug.DebugContext debug
        end local 4 // org.graalvm.compiler.nodes.StructuredGraph graphCopy
        end local 3 // org.graalvm.compiler.phases.common.util.HashSetNodeEventListener listener
        end local 2 // org.graalvm.compiler.phases.tiers.PhaseContext context
        end local 1 // org.graalvm.compiler.nodes.StructuredGraph graph
        end local 0 // org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   54     0           this  Lorg/graalvm/compiler/core/phases/GraphChangeMonitoringPhase<TC;>;
            0   54     1          graph  Lorg/graalvm/compiler/nodes/StructuredGraph;
            0   54     2        context  TC;
            1   54     3       listener  Lorg/graalvm/compiler/phases/common/util/HashSetNodeEventListener;
            2   54     4      graphCopy  Lorg/graalvm/compiler/nodes/StructuredGraph;
            3   54     5          debug  Lorg/graalvm/compiler/debug/DebugContext;
            5   18     8              s  Lorg/graalvm/compiler/graph/Graph$NodeEventScope;
            7   10    11             s2  Lorg/graalvm/compiler/debug/DebugContext$Scope;
           15   16     9              t  Ljava/lang/Throwable;
           23   54     6  filteredNodes  Lorg/graalvm/util/EconomicSet<Lorg/graalvm/compiler/graph/Node;>;
           25   27     7              n  Lorg/graalvm/compiler/graph/Node;
           32   48     9              s  Lorg/graalvm/compiler/graph/Graph$NodeEventScope;
           34   42    12             s2  Lorg/graalvm/compiler/debug/DebugContext$Scope;
      Exception table:
        from    to  target  type
           7     8       9  any
           6    11      11  any
           5    14      14  Class java.lang.Throwable
           5    16      17  any
           4    19      19  any
          34    40      41  any
          33    43      43  any
          32    46      47  any
          31    49      49  any
    Signature: (Lorg/graalvm/compiler/nodes/StructuredGraph;TC;)V
    MethodParameters:
         Name  Flags
      graph    
      context  

  protected void run(org.graalvm.compiler.nodes.StructuredGraph, java.lang.Object);
    descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;)V
    flags: (0x1044) ACC_PROTECTED, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            aload 2
            checkcast org.graalvm.compiler.phases.tiers.PhaseContext
            invokevirtual org.graalvm.compiler.core.phases.GraphChangeMonitoringPhase.run:(Lorg/graalvm/compiler/nodes/StructuredGraph;Lorg/graalvm/compiler/phases/tiers/PhaseContext;)V
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
Signature: <C:Lorg/graalvm/compiler/phases/tiers/PhaseContext;>Lorg/graalvm/compiler/phases/PhaseSuite<TC;>;
SourceFile: "GraphChangeMonitoringPhase.java"
InnerClasses:
  public abstract Scope = org.graalvm.compiler.debug.DebugContext$Scope of org.graalvm.compiler.debug.DebugContext
  public final NodeEvent = org.graalvm.compiler.graph.Graph$NodeEvent of org.graalvm.compiler.graph.Graph
  public abstract NodeEventListener = org.graalvm.compiler.graph.Graph$NodeEventListener of org.graalvm.compiler.graph.Graph
  public final NodeEventScope = org.graalvm.compiler.graph.Graph$NodeEventScope of org.graalvm.compiler.graph.Graph