diff --git a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/BytecodeNode.java b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/BytecodeNode.java index 86449e58817..e4eb95bb295 100644 --- a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/BytecodeNode.java +++ b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/BytecodeNode.java @@ -59,9 +59,7 @@ public class BytecodeNode extends AbstractNode { List nodeList = selector.selectMultiple(matcher); if (nodeList.size() > 0) { nodes = new LinkedHashSet<>(); - for (InputNode n : nodeList) { - nodes.add(n); - } + nodes.addAll(nodeList); displayName += " (" + nodes.size() + " nodes)"; } @@ -88,12 +86,12 @@ public class BytecodeNode extends AbstractNode { @Override public Action[] getActions(boolean b) { - return new Action[]{(Action) SelectBytecodesAction.findObject(SelectBytecodesAction.class, true)}; + return new Action[]{SelectBytecodesAction.findObject(SelectBytecodesAction.class, true)}; } @Override public Action getPreferredAction() { - return (Action) SelectBytecodesAction.findObject(SelectBytecodesAction.class, true); + return SelectBytecodesAction.findObject(SelectBytecodesAction.class, true); } @Override diff --git a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/BytecodeViewTopComponent.java b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/BytecodeViewTopComponent.java index 9564e53d1ab..96b8544753f 100644 --- a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/BytecodeViewTopComponent.java +++ b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/BytecodeViewTopComponent.java @@ -29,12 +29,11 @@ import com.sun.hotspot.igv.data.InputGraph; import com.sun.hotspot.igv.data.services.InputGraphProvider; import com.sun.hotspot.igv.util.LookupHistory; import java.awt.BorderLayout; -import java.io.Serializable; import org.openide.ErrorManager; import org.openide.explorer.ExplorerManager; import org.openide.explorer.ExplorerUtils; import org.openide.explorer.view.BeanTreeView; -import org.openide.util.*; +import org.openide.util.NbBundle; import org.openide.windows.TopComponent; import org.openide.windows.WindowManager; @@ -62,7 +61,7 @@ final class BytecodeViewTopComponent extends TopComponent implements ExplorerMan treeView = new BeanTreeView(); treeView.setRootVisible(false); - this.add(BorderLayout.CENTER, treeView); + add(BorderLayout.CENTER, treeView); associateLookup(ExplorerUtils.createLookup(manager, getActionMap())); } @@ -109,11 +108,6 @@ final class BytecodeViewTopComponent extends TopComponent implements ExplorerMan LookupHistory.removeListener(InputGraphProvider.class, this); } - @Override - public Object writeReplace() { - return new ResolvableHelper(); - } - @Override protected String preferredID() { return PREFERRED_ID; @@ -156,15 +150,6 @@ final class BytecodeViewTopComponent extends TopComponent implements ExplorerMan manager.setRootContext(rootNode); } - static final class ResolvableHelper implements Serializable { - - private static final long serialVersionUID = 1L; - - public Object readResolve() { - return BytecodeViewTopComponent.getDefault(); - } - } - /** This method is called from within the constructor to * initialize the form. * WARNING: Do NOT modify this code. The content of this method is diff --git a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/MethodNode.java b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/MethodNode.java index 383950b422f..fcb032cb8cd 100644 --- a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/MethodNode.java +++ b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/MethodNode.java @@ -42,7 +42,7 @@ public class MethodNode extends AbstractNode { private InputMethod method; private InputGraph graph; - private String bciString; + private final String bciString; public MethodNodeChildren(InputMethod method, InputGraph graph, String bciString) { this.method = method; diff --git a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/SelectBytecodesCookie.java b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/SelectBytecodesCookie.java index 72311470d91..eb82d9424d5 100644 --- a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/SelectBytecodesCookie.java +++ b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/java/com/sun/hotspot/igv/bytecodes/SelectBytecodesCookie.java @@ -34,7 +34,7 @@ import org.openide.nodes.Node; */ public class SelectBytecodesCookie implements Node.Cookie { - private Set nodes; + private final Set nodes; /** Creates a new instance of SelectBytecodesCookie */ public SelectBytecodesCookie(Set nodes) { diff --git a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/resources/com/sun/hotspot/igv/bytecodes/layer.xml b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/resources/com/sun/hotspot/igv/bytecodes/layer.xml index de53ae1da33..c864c8d9269 100644 --- a/src/utils/IdealGraphVisualizer/Bytecodes/src/main/resources/com/sun/hotspot/igv/bytecodes/layer.xml +++ b/src/utils/IdealGraphVisualizer/Bytecodes/src/main/resources/com/sun/hotspot/igv/bytecodes/layer.xml @@ -13,6 +13,7 @@ + diff --git a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/BlockConnectionWidget.java b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/BlockConnectionWidget.java index 77ea2808eb4..1077d03744e 100644 --- a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/BlockConnectionWidget.java +++ b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/BlockConnectionWidget.java @@ -8,7 +8,7 @@ * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * @@ -24,9 +24,9 @@ package com.sun.hotspot.igv.controlflow; import com.sun.hotspot.igv.data.InputBlockEdge; +import com.sun.hotspot.igv.layout.Cluster; import com.sun.hotspot.igv.layout.Link; import com.sun.hotspot.igv.layout.Port; -import com.sun.hotspot.igv.layout.Cluster; import java.awt.BasicStroke; import java.awt.Point; import java.awt.Stroke; @@ -45,28 +45,22 @@ public class BlockConnectionWidget extends ConnectionWidget implements Link { private static final Stroke DASHED_STROKE = new BasicStroke(1.0f, BasicStroke.CAP_SQUARE, BasicStroke.JOIN_MITER, 10.0f, new float[]{5, 5}, 0); private static final Stroke BOLD_DASHED_STROKE = new BasicStroke(2.5f, BasicStroke.CAP_SQUARE, BasicStroke.JOIN_MITER, 10.0f, new float[]{5, 5}, 0); - private BlockWidget from; - private BlockWidget to; - private Port inputSlot; - private Port outputSlot; + private final BlockWidget from; + private final BlockWidget to; + private final Port inputSlot; + private final Port outputSlot; private List points; - private InputBlockEdge edge; private boolean isDashed = false; private boolean isBold = false; public BlockConnectionWidget(ControlFlowScene scene, InputBlockEdge edge) { super(scene); - this.edge = edge; this.from = (BlockWidget) scene.findWidget(edge.getFrom()); this.to = (BlockWidget) scene.findWidget(edge.getTo()); inputSlot = to.getInputSlot(); outputSlot = from.getOutputSlot(); - points = new ArrayList(); - } - - public InputBlockEdge getEdge() { - return edge; + points = new ArrayList<>(); } public Port getTo() { diff --git a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/BlockWidget.java b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/BlockWidget.java index 6f4aa4d3f9f..78fbd4fce1a 100644 --- a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/BlockWidget.java +++ b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/BlockWidget.java @@ -8,7 +8,7 @@ * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * @@ -27,11 +27,7 @@ import com.sun.hotspot.igv.data.InputBlock; import com.sun.hotspot.igv.layout.Cluster; import com.sun.hotspot.igv.layout.Port; import com.sun.hotspot.igv.layout.Vertex; -import java.awt.Color; -import java.awt.Dimension; -import java.awt.Font; -import java.awt.Point; -import java.awt.Rectangle; +import java.awt.*; import org.netbeans.api.visual.border.BorderFactory; import org.netbeans.api.visual.model.ObjectState; import org.netbeans.api.visual.widget.LabelWidget; @@ -43,11 +39,10 @@ import org.netbeans.api.visual.widget.LabelWidget; public class BlockWidget extends LabelWidget implements Vertex { public static final Dimension MIN_SIZE = new Dimension(20, 20); - private InputBlock block; - private Port inputSlot; - private Port outputSlot; + private final InputBlock block; + private final Port inputSlot; + private final Port outputSlot; private Cluster cluster; - private boolean root; private static final Font font = new Font(Font.SANS_SERIF, Font.PLAIN, 12); private static final Font boldFont = font.deriveFont(Font.BOLD); public static final Color NORMAL_FOREGROUND_COLOR = Color.BLACK; @@ -123,15 +118,7 @@ public class BlockWidget extends LabelWidget implements Vertex { } public boolean isRoot() { - return root; - } - - public void setCluster(Cluster c) { - cluster = c; - } - - public void setRoot(boolean b) { - root = b; + return false; } public int compareTo(Vertex o) { diff --git a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowAction.java b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowAction.java index 43b8fae8f58..ff08fe14754 100644 --- a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowAction.java +++ b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowAction.java @@ -8,7 +8,7 @@ * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * diff --git a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowScene.java b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowScene.java index c6cb8c4290a..477e181d8d2 100644 --- a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowScene.java +++ b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowScene.java @@ -8,7 +8,7 @@ * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * @@ -23,11 +23,11 @@ */ package com.sun.hotspot.igv.controlflow; -import com.sun.hotspot.igv.data.InputBlockEdge; import com.sun.hotspot.igv.data.InputBlock; +import com.sun.hotspot.igv.data.InputBlockEdge; import com.sun.hotspot.igv.data.InputGraph; -import com.sun.hotspot.igv.data.services.InputGraphProvider; import com.sun.hotspot.igv.data.InputNode; +import com.sun.hotspot.igv.data.services.InputGraphProvider; import com.sun.hotspot.igv.util.LookupHistory; import java.awt.Color; import java.awt.Point; @@ -36,22 +36,17 @@ import java.util.ArrayList; import java.util.HashSet; import java.util.Set; import javax.swing.BorderFactory; -import org.netbeans.api.visual.action.ActionFactory; -import org.netbeans.api.visual.action.MoveProvider; -import org.netbeans.api.visual.action.RectangularSelectDecorator; -import org.netbeans.api.visual.action.RectangularSelectProvider; -import org.netbeans.api.visual.action.SelectProvider; -import org.netbeans.api.visual.action.WidgetAction; +import org.netbeans.api.visual.action.*; import org.netbeans.api.visual.anchor.AnchorFactory; import org.netbeans.api.visual.anchor.AnchorShape; -import org.netbeans.api.visual.router.RouterFactory; -import org.netbeans.api.visual.widget.LayerWidget; -import org.netbeans.api.visual.widget.Widget; import org.netbeans.api.visual.graph.GraphScene; import org.netbeans.api.visual.graph.layout.GraphLayout; import org.netbeans.api.visual.layout.LayoutFactory; import org.netbeans.api.visual.layout.SceneLayout; +import org.netbeans.api.visual.router.RouterFactory; import org.netbeans.api.visual.widget.ConnectionWidget; +import org.netbeans.api.visual.widget.LayerWidget; +import org.netbeans.api.visual.widget.Widget; /** * @@ -59,34 +54,33 @@ import org.netbeans.api.visual.widget.ConnectionWidget; */ public class ControlFlowScene extends GraphScene implements SelectProvider, MoveProvider, RectangularSelectDecorator, RectangularSelectProvider { - private HashSet selection; + private final HashSet selection; private InputGraph oldGraph; - private LayerWidget edgeLayer; - private LayerWidget mainLayer; - private LayerWidget selectLayer; - private WidgetAction hoverAction = this.createWidgetHoverAction(); - private WidgetAction selectAction = new DoubleClickSelectAction(this); - private WidgetAction moveAction = ActionFactory.createMoveAction(null, this); + private final LayerWidget edgeLayer; + private final LayerWidget mainLayer; + private final WidgetAction hoverAction = createWidgetHoverAction(); + private final WidgetAction selectAction = new DoubleClickSelectAction(this); + private final WidgetAction moveAction = ActionFactory.createMoveAction(null, this); public ControlFlowScene() { - selection = new HashSet(); + selection = new HashSet<>(); - this.getInputBindings().setZoomActionModifiers(0); - this.setLayout(LayoutFactory.createAbsoluteLayout()); + getInputBindings().setZoomActionModifiers(0); + setLayout(LayoutFactory.createAbsoluteLayout()); mainLayer = new LayerWidget(this); - this.addChild(mainLayer); + addChild(mainLayer); edgeLayer = new LayerWidget(this); - this.addChild(edgeLayer); + addChild(edgeLayer); - selectLayer = new LayerWidget(this); - this.addChild(selectLayer); + LayerWidget selectLayer = new LayerWidget(this); + addChild(selectLayer); - this.getActions().addAction(hoverAction); - this.getActions().addAction(selectAction); - this.getActions().addAction(ActionFactory.createRectangularSelectAction(this, selectLayer, this)); - this.getActions().addAction(ActionFactory.createMouseCenteredZoomAction(1.1)); + getActions().addAction(hoverAction); + getActions().addAction(selectAction); + getActions().addAction(ActionFactory.createRectangularSelectAction(this, selectLayer, this)); + getActions().addAction(ActionFactory.createMouseCenteredZoomAction(1.1)); } public void setGraph(InputGraph g) { @@ -95,12 +89,12 @@ public class ControlFlowScene extends GraphScene imp } oldGraph = g; - ArrayList blocks = new ArrayList(this.getNodes()); + ArrayList blocks = new ArrayList<>(getNodes()); for (InputBlock b : blocks) { removeNode(b); } - ArrayList edges = new ArrayList(this.getEdges()); + ArrayList edges = new ArrayList<>(getEdges()); for (InputBlockEdge e : edges) { removeEdge(e); } @@ -113,15 +107,15 @@ public class ControlFlowScene extends GraphScene imp addEdge(e); assert g.getBlocks().contains(e.getFrom()); assert g.getBlocks().contains(e.getTo()); - this.setEdgeSource(e, e.getFrom()); - this.setEdgeTarget(e, e.getTo()); + setEdgeSource(e, e.getFrom()); + setEdgeTarget(e, e.getTo()); } - GraphLayout layout = new HierarchicalGraphLayout();//GridGraphLayout(); + GraphLayout layout = new HierarchicalGraphLayout<>(); SceneLayout sceneLayout = LayoutFactory.createSceneGraphLayout(this, layout); sceneLayout.invokeLayout(); - this.validate(); + validate(); } public void clearSelection() { @@ -135,7 +129,7 @@ public class ControlFlowScene extends GraphScene imp public void selectionChanged() { InputGraphProvider p = LookupHistory.getLast(InputGraphProvider.class); if (p != null) { - Set inputNodes = new HashSet(); + Set inputNodes = new HashSet<>(); for (BlockWidget w : selection) { inputNodes.addAll(w.getBlock().getNodes()); } @@ -155,14 +149,17 @@ public class ControlFlowScene extends GraphScene imp selectionChanged(); } + @Override public boolean isAimingAllowed(Widget widget, Point point, boolean b) { return false; } + @Override public boolean isSelectionAllowed(Widget widget, Point point, boolean b) { return true; } + @Override public void select(Widget widget, Point point, boolean change) { if (widget == this) { clearSelection(); @@ -185,18 +182,22 @@ public class ControlFlowScene extends GraphScene imp } } - public void movementStarted(Widget widget) { - } + @Override + public void movementStarted(Widget widget) {} - public void movementFinished(Widget widget) { - } + @Override + public void movementFinished(Widget widget) {} + + @Override public Point getOriginalLocation(Widget widget) { return widget.getPreferredLocation(); } + @Override public void setNewLocation(Widget widget, Point location) { - if (selection.contains(widget)) { + assert widget instanceof BlockWidget; + if (selection.contains((BlockWidget) widget)) { // move entire selection Point originalLocation = getOriginalLocation(widget); int xOffset = location.x - originalLocation.x; @@ -211,6 +212,7 @@ public class ControlFlowScene extends GraphScene imp } } + @Override public Widget createSelectionWidget() { Widget widget = new Widget(this); widget.setOpaque(false); @@ -219,6 +221,7 @@ public class ControlFlowScene extends GraphScene imp return widget; } + @Override public void performSelection(Rectangle rectangle) { if (rectangle.width < 0) { @@ -232,7 +235,7 @@ public class ControlFlowScene extends GraphScene imp } boolean changed = false; - for (InputBlock b : this.getNodes()) { + for (InputBlock b : getNodes()) { BlockWidget w = (BlockWidget) findWidget(b); Rectangle r = new Rectangle(w.getBounds()); r.setLocation(w.getLocation()); @@ -257,6 +260,7 @@ public class ControlFlowScene extends GraphScene imp } + @Override protected Widget attachNodeWidget(InputBlock node) { BlockWidget w = new BlockWidget(this, node); mainLayer.addChild(w); @@ -266,6 +270,7 @@ public class ControlFlowScene extends GraphScene imp return w; } + @Override protected Widget attachEdgeWidget(InputBlockEdge edge) { BlockConnectionWidget w = new BlockConnectionWidget(this, edge); switch (edge.getState()) { @@ -282,16 +287,18 @@ public class ControlFlowScene extends GraphScene imp return w; } + @Override protected void attachEdgeSourceAnchor(InputBlockEdge edge, InputBlock oldSourceNode, InputBlock sourceNode) { - Widget w = this.findWidget(edge); + Widget w = findWidget(edge); assert w instanceof ConnectionWidget; ConnectionWidget cw = (ConnectionWidget) w; cw.setSourceAnchor(AnchorFactory.createRectangularAnchor(findWidget(sourceNode))); } + @Override protected void attachEdgeTargetAnchor(InputBlockEdge edge, InputBlock oldTargetNode, InputBlock targetNode) { - Widget w = this.findWidget(edge); + Widget w = findWidget(edge); assert w instanceof ConnectionWidget; ConnectionWidget cw = (ConnectionWidget) w; cw.setTargetAnchor(AnchorFactory.createRectangularAnchor(findWidget(targetNode))); diff --git a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowTopComponent.java b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowTopComponent.java index 80597a9eee2..683a5fdb381 100644 --- a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowTopComponent.java +++ b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/ControlFlowTopComponent.java @@ -8,7 +8,7 @@ * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * @@ -28,7 +28,6 @@ import com.sun.hotspot.igv.data.InputGraph; import com.sun.hotspot.igv.data.services.InputGraphProvider; import com.sun.hotspot.igv.util.LookupHistory; import java.awt.BorderLayout; -import java.io.Serializable; import javax.swing.JScrollPane; import org.openide.ErrorManager; import org.openide.util.NbBundle; @@ -51,12 +50,11 @@ final class ControlFlowTopComponent extends TopComponent implements ChangedListe setToolTipText(NbBundle.getMessage(ControlFlowTopComponent.class, "HINT_ControlFlowTopComponent")); scene = new ControlFlowScene(); - this.setLayout(new BorderLayout()); - this.associateLookup(scene.getLookup()); - + setLayout(new BorderLayout()); + associateLookup(scene.getLookup()); JScrollPane panel = new JScrollPane(scene.createView()); - this.add(panel, BorderLayout.CENTER); + add(panel, BorderLayout.CENTER); } /** @@ -114,11 +112,6 @@ final class ControlFlowTopComponent extends TopComponent implements ChangedListe scene.setGraph(new InputGraph("")); } - @Override - public Object writeReplace() { - return new ResolvableHelper(); - } - @Override protected String preferredID() { return PREFERRED_ID; @@ -130,15 +123,6 @@ final class ControlFlowTopComponent extends TopComponent implements ChangedListe scene.getView().requestFocus(); } - static final class ResolvableHelper implements Serializable { - - private static final long serialVersionUID = 1L; - - public Object readResolve() { - return ControlFlowTopComponent.getDefault(); - } - } - /** This method is called from within the constructor to * initialize the form. * WARNING: Do NOT modify this code. The content of this method is diff --git a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/DoubleClickSelectAction.java b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/DoubleClickSelectAction.java index f70ba33df7d..47482e58e83 100644 --- a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/DoubleClickSelectAction.java +++ b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/DoubleClickSelectAction.java @@ -8,7 +8,7 @@ * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * diff --git a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/HierarchicalGraphLayout.java b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/HierarchicalGraphLayout.java index bf16e7f427e..5cbc7c5653f 100644 --- a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/HierarchicalGraphLayout.java +++ b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/java/com/sun/hotspot/igv/controlflow/HierarchicalGraphLayout.java @@ -8,7 +8,7 @@ * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * @@ -24,20 +24,10 @@ package com.sun.hotspot.igv.controlflow; import com.sun.hotspot.igv.hierarchicallayout.HierarchicalLayoutManager; -import com.sun.hotspot.igv.layout.Cluster; -import com.sun.hotspot.igv.layout.LayoutGraph; -import com.sun.hotspot.igv.layout.Link; -import com.sun.hotspot.igv.layout.Port; -import com.sun.hotspot.igv.layout.Vertex; +import com.sun.hotspot.igv.layout.*; import java.awt.Dimension; import java.awt.Point; -import java.util.ArrayList; -import java.util.Collection; -import java.util.HashMap; -import java.util.LinkedHashSet; -import java.util.List; -import java.util.Map; -import java.util.Set; +import java.util.*; import org.netbeans.api.visual.graph.layout.GraphLayout; import org.netbeans.api.visual.graph.layout.UniversalGraph; import org.netbeans.api.visual.widget.Widget; @@ -48,13 +38,12 @@ import org.netbeans.api.visual.widget.Widget; */ public class HierarchicalGraphLayout extends GraphLayout { - public HierarchicalGraphLayout() { - } + public HierarchicalGraphLayout() {} private class LinkWrapper implements Link { - private VertexWrapper from; - private VertexWrapper to; + private final VertexWrapper from; + private final VertexWrapper to; public LinkWrapper(VertexWrapper from, VertexWrapper to) { this.from = from; @@ -78,7 +67,7 @@ public class HierarchicalGraphLayout extends GraphLayout { } public List getControlPoints() { - return new ArrayList(); + return new ArrayList<>(); } public void setControlPoints(List list) { @@ -92,9 +81,9 @@ public class HierarchicalGraphLayout extends GraphLayout { private class VertexWrapper implements Vertex { - private N node; - private UniversalGraph graph; - private Port slot; + private final N node; + private final UniversalGraph graph; + private final Port slot; private Point position; public VertexWrapper(N node, UniversalGraph graph) { @@ -122,6 +111,7 @@ public class HierarchicalGraphLayout extends GraphLayout { public Dimension getSize() { Widget w = graph.getScene().findWidget(node); + assert w.getBounds() != null; return w.getBounds().getSize(); } @@ -151,9 +141,9 @@ public class HierarchicalGraphLayout extends GraphLayout { protected void performGraphLayout(UniversalGraph graph) { - Set links = new LinkedHashSet(); - Set vertices = new LinkedHashSet(); - Map vertexMap = new HashMap(); + Set links = new LinkedHashSet<>(); + Set vertices = new LinkedHashSet<>(); + Map vertexMap = new HashMap<>(); for (N node : graph.getNodes()) { VertexWrapper v = new VertexWrapper(node, graph); diff --git a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/resources/com/sun/hotspot/igv/controlflow/layer.xml b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/resources/com/sun/hotspot/igv/controlflow/layer.xml index 36b0e8ce903..176712f1595 100644 --- a/src/utils/IdealGraphVisualizer/ControlFlow/src/main/resources/com/sun/hotspot/igv/controlflow/layer.xml +++ b/src/utils/IdealGraphVisualizer/ControlFlow/src/main/resources/com/sun/hotspot/igv/controlflow/layer.xml @@ -10,6 +10,7 @@ + diff --git a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/FolderNode.java b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/FolderNode.java index e0a4af80e7a..0521123890a 100644 --- a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/FolderNode.java +++ b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/FolderNode.java @@ -28,8 +28,8 @@ import com.sun.hotspot.igv.data.*; import com.sun.hotspot.igv.util.PropertiesSheet; import com.sun.hotspot.igv.util.StringUtils; import java.awt.Image; -import java.util.List; import java.util.HashMap; +import java.util.List; import java.util.Map; import org.openide.nodes.AbstractNode; import org.openide.nodes.Children; @@ -45,11 +45,11 @@ import org.openide.util.lookup.InstanceContent; */ public class FolderNode extends AbstractNode { - private InstanceContent content; - private FolderChildren children; + private final InstanceContent content; + private final FolderChildren children; // NetBeans node corresponding to each opened graph. Used to highlight the // focused graph in the Outline window. - private static Map graphNode = new HashMap<>(); + private static final Map graphNode = new HashMap<>(); private boolean selected = false; private static class FolderChildren extends Children.Keys implements ChangedListener { @@ -128,12 +128,9 @@ public class FolderNode extends AbstractNode { if (folder instanceof FolderElement) { final FolderElement folderElement = (FolderElement) folder; this.setDisplayName(folderElement.getName()); - content.add(new RemoveCookie() { - @Override - public void remove() { - children.destroyNodes(children.getNodes()); - folderElement.getParent().removeElement(folderElement); - } + content.add((RemoveCookie) () -> { + children.destroyNodes(children.getNodes()); + folderElement.getParent().removeElement(folderElement); }); } } @@ -163,7 +160,7 @@ public class FolderNode extends AbstractNode { public boolean isRootNode() { Folder folder = getFolder(); - return (folder != null && folder instanceof GraphDocument); + return (folder instanceof GraphDocument); } @Override diff --git a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/GraphNode.java b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/GraphNode.java index b52a914ffb8..d3a0ed5232c 100644 --- a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/GraphNode.java +++ b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/GraphNode.java @@ -23,12 +23,7 @@ */ package com.sun.hotspot.igv.coordinator; -import com.sun.hotspot.igv.coordinator.actions.CloneGraphAction; -import com.sun.hotspot.igv.coordinator.actions.DiffGraphAction; -import com.sun.hotspot.igv.coordinator.actions.DiffGraphCookie; -import com.sun.hotspot.igv.coordinator.actions.GraphCloneCookie; -import com.sun.hotspot.igv.coordinator.actions.GraphOpenCookie; -import com.sun.hotspot.igv.coordinator.actions.GraphRemoveCookie; +import com.sun.hotspot.igv.coordinator.actions.*; import com.sun.hotspot.igv.data.InputGraph; import com.sun.hotspot.igv.data.Properties; import com.sun.hotspot.igv.data.services.GraphViewer; @@ -37,12 +32,7 @@ import com.sun.hotspot.igv.util.StringUtils; import java.awt.Image; import javax.swing.Action; import org.openide.actions.OpenAction; -import org.openide.nodes.AbstractNode; -import org.openide.nodes.Children; -import org.openide.nodes.NodeAdapter; -import org.openide.nodes.NodeEvent; -import org.openide.nodes.NodeMemberEvent; -import org.openide.nodes.Sheet; +import org.openide.nodes.*; import org.openide.util.ImageUtilities; import org.openide.util.Lookup; import org.openide.util.lookup.AbstractLookup; @@ -132,12 +122,12 @@ public class GraphNode extends AbstractNode { @Override public Action[] getActions(boolean b) { - return new Action[]{(Action) DiffGraphAction.findObject(DiffGraphAction.class, true), (Action) CloneGraphAction.findObject(CloneGraphAction.class, true), (Action) OpenAction.findObject(OpenAction.class, true)}; + return new Action[]{DiffGraphAction.findObject(DiffGraphAction.class, true), CloneGraphAction.findObject(CloneGraphAction.class, true), OpenAction.findObject(OpenAction.class, true)}; } @Override public Action getPreferredAction() { - return (Action) OpenAction.findObject(OpenAction.class, true); + return OpenAction.findObject(OpenAction.class, true); } @Override diff --git a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/OutlineTopComponent.java b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/OutlineTopComponent.java index 64bb633a173..d4764648adf 100644 --- a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/OutlineTopComponent.java +++ b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/OutlineTopComponent.java @@ -37,7 +37,6 @@ import java.awt.Dimension; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectOutput; -import java.io.Serializable; import java.util.HashSet; import java.util.Set; import javax.swing.UIManager; @@ -66,8 +65,6 @@ public final class OutlineTopComponent extends TopComponent implements ExplorerM private ExplorerManager manager; private final GraphDocument document; private FolderNode root; - private Server server; - private Server binaryServer; private SaveAllAction saveAllAction; private RemoveAllAction removeAllAction; private GraphNode[] selectedGraphs = new GraphNode[0]; @@ -138,8 +135,7 @@ public final class OutlineTopComponent extends TopComponent implements ExplorerM } }; - server = new Server(getDocument(), callback, false); - binaryServer = new Server(getDocument(), callback, true); + new Server(callback); } public void clear() { @@ -286,15 +282,6 @@ public final class OutlineTopComponent extends TopComponent implements ExplorerM super.writeExternal(objectOutput); } - static final class ResolvableHelper implements Serializable { - - private static final long serialVersionUID = 1L; - - public Object readResolve() { - return OutlineTopComponent.getDefault(); - } - } - /** This method is called from within the constructor to * initialize the form. * WARNING: Do NOT modify this code. The content of this method is diff --git a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/ImportAction.java b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/ImportAction.java index 7b76bc955b3..03d062d8041 100644 --- a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/ImportAction.java +++ b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/ImportAction.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,31 +26,24 @@ package com.sun.hotspot.igv.coordinator.actions; import com.sun.hotspot.igv.coordinator.OutlineTopComponent; import com.sun.hotspot.igv.data.GraphDocument; -import com.sun.hotspot.igv.data.serialization.BinaryParser; import com.sun.hotspot.igv.data.serialization.GraphParser; import com.sun.hotspot.igv.data.serialization.ParseMonitor; import com.sun.hotspot.igv.data.serialization.Parser; import com.sun.hotspot.igv.settings.Settings; -import java.awt.event.ActionEvent; import java.io.File; -import java.io.FileNotFoundException; import java.io.IOException; import java.nio.channels.FileChannel; import java.nio.file.StandardOpenOption; import java.util.logging.Level; import java.util.logging.Logger; +import javax.swing.Action; import javax.swing.JFileChooser; import javax.swing.SwingUtilities; import javax.swing.filechooser.FileFilter; -import javax.swing.Action; import org.netbeans.api.progress.ProgressHandle; import org.netbeans.api.progress.ProgressHandleFactory; -import org.openide.util.Exceptions; -import org.openide.util.RequestProcessor; -import org.openide.util.HelpCtx; -import org.openide.util.NbBundle; +import org.openide.util.*; import org.openide.util.actions.CallableSystemAction; -import org.openide.util.Utilities; /** * @@ -65,12 +58,12 @@ public final class ImportAction extends CallableSystemAction { @Override public boolean accept(File f) { - return f.getName().toLowerCase().endsWith(".xml") || f.getName().toLowerCase().endsWith(".bgv") || f.isDirectory(); + return f.getName().toLowerCase().endsWith(".xml") || f.isDirectory(); } @Override public String getDescription() { - return "Graph files (*.xml, *.bgv)"; + return "Graph files (*.xml)"; } }; } @@ -102,8 +95,7 @@ public final class ImportAction extends CallableSystemAction { try { int prog = (int) (WORKUNITS * (double) channel.position() / (double) start); handle.progress(prog); - } catch (IOException ex) { - } + } catch (IOException ignored) {} } @Override public void setState(String state) { @@ -115,8 +107,6 @@ public final class ImportAction extends CallableSystemAction { final OutlineTopComponent component = OutlineTopComponent.findInstance(); if (file.getName().endsWith(".xml")) { parser = new Parser(channel, monitor, null); - } else if (file.getName().endsWith(".bgv")) { - parser = new BinaryParser(channel, monitor, component.getDocument(), null); } else { parser = null; } @@ -126,13 +116,10 @@ public final class ImportAction extends CallableSystemAction { try { final GraphDocument document = parser.parse(); if (document != null) { - SwingUtilities.invokeLater(new Runnable(){ - @Override - public void run() { - component.requestActive(); - component.getDocument().addGraphDocument(document); - } - }); + SwingUtilities.invokeLater(() -> { + component.requestActive(); + component.getDocument().addGraphDocument(document); + }); } } catch (IOException ex) { Exceptions.printStackTrace(ex); @@ -142,8 +129,6 @@ public final class ImportAction extends CallableSystemAction { Logger.getLogger(getClass().getName()).log(Level.INFO, "Loaded in " + file + " in " + ((stop - startTime) / 1000.0) + " seconds"); } }); - } catch (FileNotFoundException ex) { - Exceptions.printStackTrace(ex); } catch (IOException ex) { Exceptions.printStackTrace(ex); } diff --git a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/RemoveAllAction.java b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/RemoveAllAction.java index effc7d59fbb..e95099d0f97 100644 --- a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/RemoveAllAction.java +++ b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/RemoveAllAction.java @@ -25,10 +25,7 @@ package com.sun.hotspot.igv.coordinator.actions; import com.sun.hotspot.igv.coordinator.OutlineTopComponent; -import java.awt.event.InputEvent; -import java.awt.event.KeyEvent; import javax.swing.Action; -import javax.swing.KeyStroke; import org.openide.util.HelpCtx; import org.openide.util.NbBundle; import org.openide.util.actions.CallableSystemAction; diff --git a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/SaveAllAction.java b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/SaveAllAction.java index 230cff294b7..dde018f60e9 100644 --- a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/SaveAllAction.java +++ b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/SaveAllAction.java @@ -25,15 +25,11 @@ package com.sun.hotspot.igv.coordinator.actions; import com.sun.hotspot.igv.coordinator.OutlineTopComponent; -import java.awt.event.InputEvent; -import java.awt.event.KeyEvent; import javax.swing.Action; -import javax.swing.KeyStroke; import org.openide.util.HelpCtx; import org.openide.util.NbBundle; -import org.openide.util.NbBundle.Messages; -import org.openide.util.actions.CallableSystemAction; import org.openide.util.Utilities; +import org.openide.util.actions.CallableSystemAction; /** * diff --git a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/SaveAsAction.java b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/SaveAsAction.java index a1abf62d3a5..4be57a51dba 100644 --- a/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/SaveAsAction.java +++ b/src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/actions/SaveAsAction.java @@ -25,19 +25,21 @@ package com.sun.hotspot.igv.coordinator.actions; import com.sun.hotspot.igv.coordinator.FolderNode; -import com.sun.hotspot.igv.coordinator.OutlineTopComponent; import com.sun.hotspot.igv.data.Folder; import com.sun.hotspot.igv.data.GraphDocument; import com.sun.hotspot.igv.data.Group; import com.sun.hotspot.igv.data.serialization.Printer; import com.sun.hotspot.igv.settings.Settings; -import java.io.*; +import java.io.File; +import java.io.IOException; +import java.io.OutputStreamWriter; +import java.io.Writer; +import java.nio.file.Files; import javax.swing.Action; import javax.swing.JFileChooser; import org.openide.nodes.Node; import org.openide.util.HelpCtx; import org.openide.util.NbBundle; -import org.openide.util.actions.CookieAction; import org.openide.util.actions.NodeAction; /** @@ -52,7 +54,6 @@ public final class SaveAsAction extends NodeAction { @Override protected void performAction(Node[] activatedNodes) { - final OutlineTopComponent component = OutlineTopComponent.findInstance(); GraphDocument doc = new GraphDocument(); for (Node node : activatedNodes) { if (node instanceof FolderNode) { @@ -84,23 +85,16 @@ public final class SaveAsAction extends NodeAction { } Settings.get().put(Settings.DIRECTORY, dir.getAbsolutePath()); try { - try (Writer writer = new OutputStreamWriter(new FileOutputStream(file))) { + try (Writer writer = new OutputStreamWriter(Files.newOutputStream(file.toPath()))) { Printer p = new Printer(); p.export(writer, doc); } - } catch (FileNotFoundException e) { - e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); - } } } - protected int mode() { - return CookieAction.MODE_SOME; - } - @Override public String getName() { return NbBundle.getMessage(SaveAsAction.class, "CTL_SaveAsAction"); diff --git a/src/utils/IdealGraphVisualizer/Coordinator/src/main/resources/com/sun/hotspot/igv/coordinator/layer.xml b/src/utils/IdealGraphVisualizer/Coordinator/src/main/resources/com/sun/hotspot/igv/coordinator/layer.xml index 78ebc84b534..8e43e4a0028 100644 --- a/src/utils/IdealGraphVisualizer/Coordinator/src/main/resources/com/sun/hotspot/igv/coordinator/layer.xml +++ b/src/utils/IdealGraphVisualizer/Coordinator/src/main/resources/com/sun/hotspot/igv/coordinator/layer.xml @@ -43,9 +43,10 @@ - + + @@ -96,8 +97,9 @@ - + + @@ -130,8 +132,9 @@ - + + @@ -148,7 +151,7 @@ - + @@ -159,14 +162,18 @@ + + + + @@ -188,6 +195,7 @@ + @@ -214,12 +222,12 @@ - + - + diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/ChangedEvent.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/ChangedEvent.java index 90c87e47dba..5005e67f829 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/ChangedEvent.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/ChangedEvent.java @@ -30,7 +30,7 @@ package com.sun.hotspot.igv.data; */ public class ChangedEvent extends Event> { - private T object; + private final T object; /** * Creates a new event with the specific object as the one for which the event gets fired. diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Event.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Event.java index 25effee7672..ddbab9f363a 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Event.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Event.java @@ -32,7 +32,7 @@ import java.util.List; */ public abstract class Event { - private List listener; + private final List listener; private boolean fireEvents; private boolean eventWasFired; @@ -45,10 +45,6 @@ public abstract class Event { listener.add(l); } - /** - * Remove listener - * @param l - */ public void removeListener(final L l) { listener.remove(l); } diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/GraphDocument.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/GraphDocument.java index 85a0494658c..744a3aa491e 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/GraphDocument.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/GraphDocument.java @@ -32,8 +32,8 @@ import java.util.List; */ public class GraphDocument extends Properties.Entity implements ChangedEventProvider, Folder { - private List elements; - private ChangedEvent changedEvent; + private final List elements; + private final ChangedEvent changedEvent; public GraphDocument() { elements = new ArrayList<>(); diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Group.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Group.java index 645ef3c2cfa..8926b67eb19 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Group.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Group.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -31,26 +31,18 @@ import java.util.*; */ public class Group extends Properties.Entity implements ChangedEventProvider, Folder, FolderElement { - private final List elements; private final List graphs; - private InputMethod method; - private transient ChangedEvent changedEvent; + private final transient ChangedEvent changedEvent; private Folder parent; public Group(Folder parent) { - elements = new ArrayList<>(); graphs = new ArrayList<>(); changedEvent = new ChangedEvent<>(this); this.parent = parent; - // Ensure that name and type are never null + // Ensure that name is never null getProperties().setProperty("name", ""); - getProperties().setProperty("type", ""); - } - - public void fireChangedEvent() { - changedEvent.fire(); } public void setMethod(InputMethod method) { @@ -67,33 +59,34 @@ public class Group extends Properties.Entity implements ChangedEventProvider getElements() { - return Collections.unmodifiableList(elements); - } - - public int getGraphsCount() { - return elements.size(); + public void addElement(FolderElement element) { + assert element instanceof InputGraph; + graphs.add((InputGraph) element); + element.setParent(this); + getChangedEvent().fire(); } @Override - public void addElement(FolderElement element) { - elements.add(element); - if (element instanceof InputGraph) { - graphs.add((InputGraph) element); - } else { - + public void removeElement(FolderElement element) { + assert element instanceof InputGraph; + if (graphs.remove((InputGraph) element)) { + getChangedEvent().fire(); } - element.setParent(this); - changedEvent.fire(); + } + + @Override + public List getElements() { + return Collections.unmodifiableList(graphs); + } + + public List getGraphs() { + return Collections.unmodifiableList(graphs); } public Set getAllNodes() { Set result = new HashSet<>(); - for (FolderElement e : elements) { - if (e instanceof InputGraph) { - InputGraph g = (InputGraph) e; - result.addAll(g.getNodesAsSet()); - } + for (InputGraph g : graphs) { + result.addAll(g.getNodesAsSet()); } return result; } @@ -102,7 +95,7 @@ public class Group extends Properties.Entity implements ChangedEventProvider getGraphs() { - return graphs; - } - @Override public void setParent(Folder parent) { this.parent = parent; diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBlock.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBlock.java index 28cfc11d7cd..7f3d1a514ef 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBlock.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBlock.java @@ -32,9 +32,9 @@ import java.util.*; public class InputBlock { private List nodes; - private String name; - private InputGraph graph; - private Set successors; + private final String name; + private final InputGraph graph; + private final Set successors; private boolean artificial; @Override @@ -49,7 +49,7 @@ public class InputBlock { return true; } - if (o == null || (!(o instanceof InputBlock))) { + if ((!(o instanceof InputBlock))) { return false; } @@ -113,13 +113,11 @@ public class InputBlock { } void addSuccessor(InputBlock b) { - if (!successors.contains(b)) { - successors.add(b); - } + successors.add(b); } - void setArtificial(boolean artificial) { - this.artificial = artificial; + void setArtificial() { + this.artificial = true; } public boolean isArtificial() { diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBlockEdge.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBlockEdge.java index 2a1586dc9da..92f0e5247ff 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBlockEdge.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBlockEdge.java @@ -35,10 +35,10 @@ public class InputBlockEdge { DELETED } - private InputBlock from; - private InputBlock to; + private final InputBlock from; + private final InputBlock to; private State state = State.SAME; - private String label; + private final String label; public InputBlockEdge(InputBlock from, InputBlock to, String label) { assert from != null; @@ -70,7 +70,7 @@ public class InputBlockEdge { @Override public boolean equals(Object obj) { - if (obj != null && obj instanceof InputBlockEdge) { + if (obj instanceof InputBlockEdge) { InputBlockEdge e = (InputBlockEdge) obj; return e.from.equals(from) && e.to.equals(to); } diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBytecode.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBytecode.java index eb4b8438f29..8378466ce60 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBytecode.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputBytecode.java @@ -29,10 +29,10 @@ package com.sun.hotspot.igv.data; */ public class InputBytecode { - private int bci; - private String name; - private String operands; - private String comment; + private final int bci; + private final String name; + private final String operands; + private final String comment; private InputMethod inlined; public InputBytecode(int bci, String name, String operands, String comment) { diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputEdge.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputEdge.java index 846f74f3d1e..579fd41688c 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputEdge.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputEdge.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,8 +24,7 @@ package com.sun.hotspot.igv.data; import java.util.Comparator; -import java.util.WeakHashMap; -import java.lang.ref.WeakReference; +import java.util.Objects; /** * @@ -40,27 +39,19 @@ public class InputEdge { DELETED } - public static final Comparator OUTGOING_COMPARATOR = new Comparator(){ - - @Override - public int compare(InputEdge o1, InputEdge o2) { - if(o1.getFromIndex() == o2.getFromIndex()) { - return o1.getTo() - o2.getTo(); - } - return o1.getFromIndex() - o2.getFromIndex(); + public static final Comparator OUTGOING_COMPARATOR = (o1, o2) -> { + if (o1.getFromIndex() == o2.getFromIndex()) { + return o1.getTo() - o2.getTo(); } - }; + return o1.getFromIndex() - o2.getFromIndex(); + }; - public static final Comparator INGOING_COMPARATOR = new Comparator(){ - - @Override - public int compare(InputEdge o1, InputEdge o2) { - if(o1.getToIndex() == o2.getToIndex()) { - return o1.getFrom() - o2.getFrom(); - } - return o1.getToIndex() - o2.getToIndex(); + public static final Comparator INGOING_COMPARATOR = (o1, o2) -> { + if (o1.getToIndex() == o2.getToIndex()) { + return o1.getFrom() - o2.getFrom(); } - }; + return o1.getToIndex() - o2.getToIndex(); + }; private final char toIndex; private final char fromIndex; @@ -70,14 +61,6 @@ public class InputEdge { private final String type; private State state; - public InputEdge(char toIndex, int from, int to) { - this((char) 0, toIndex, from, to, null, null); - } - - public InputEdge(char fromIndex, char toIndex, int from, int to) { - this(fromIndex, toIndex, from, to, null, null); - } - public InputEdge(char fromIndex, char toIndex, int from, int to, String label, String type) { this.toIndex = toIndex; this.fromIndex = fromIndex; @@ -88,31 +71,6 @@ public class InputEdge { this.type = type.intern(); } - static WeakHashMap> immutableCache = new WeakHashMap<>(); - - public static synchronized InputEdge createImmutable(char fromIndex, char toIndex, int from, int to, String label, String type) { - InputEdge edge = new InputEdge(fromIndex, toIndex, from, to, label, type, State.IMMUTABLE); - WeakReference result = immutableCache.get(edge); - if (result != null) { - InputEdge edge2 = result.get(); - if (edge2 != null) { - return edge2; - } - } - immutableCache.put(edge, new WeakReference<>(edge)); - return edge; - } - - public InputEdge(char fromIndex, char toIndex, int from, int to, String label, String type, State state) { - this.toIndex = toIndex; - this.fromIndex = fromIndex; - this.from = from; - this.to = to; - this.state = state; - this.label = label; - this.type = type; - } - public State getState() { return state; } @@ -154,14 +112,14 @@ public class InputEdge { @Override public boolean equals(Object o) { - if (o == null || !(o instanceof InputEdge)) { + if (!(o instanceof InputEdge)) { return false; } InputEdge conn2 = (InputEdge) o; boolean result = conn2.fromIndex == fromIndex && conn2.toIndex == toIndex && conn2.from == from && conn2.to == to; if (result && (state == State.IMMUTABLE || conn2.state == State.IMMUTABLE)) { // Immutable instances must be exactly the same - return conn2.label == label && conn2.state == state; + return Objects.equals(conn2.label, label) && conn2.state == state; } return result; } diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputGraph.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputGraph.java index a3f9a6c0e46..6cfa0c74484 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputGraph.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputGraph.java @@ -31,13 +31,13 @@ import java.util.*; */ public class InputGraph extends Properties.Entity implements FolderElement { - private Map nodes; - private List edges; + private final Map nodes; + private final List edges; private Folder parent; private Group parentGroup; - private Map blocks; - private List blockEdges; - private Map nodeToBlock; + private final Map blocks; + private final List blockEdges; + private final Map nodeToBlock; private boolean isDiffGraph; private InputGraph firstGraph; private InputGraph secondGraph; @@ -64,7 +64,7 @@ public class InputGraph extends Properties.Entity implements FolderElement { } public boolean isDiffGraph() { - return this.isDiffGraph; + return isDiffGraph; } public InputGraph getFirstGraph() { @@ -114,7 +114,7 @@ public class InputGraph extends Properties.Entity implements FolderElement { public Map> findAllOutgoingEdges() { Map> result = new HashMap<>(getNodes().size()); for(InputNode n : this.getNodes()) { - result.put(n, new ArrayList()); + result.put(n, new ArrayList<>()); } for(InputEdge e : this.edges) { @@ -175,16 +175,6 @@ public class InputGraph extends Properties.Entity implements FolderElement { nodeToBlock.clear(); } - public void setEdge(int fromIndex, int toIndex, int from, int to) { - assert fromIndex == ((char)fromIndex) : "Downcast must be safe"; - assert toIndex == ((char)toIndex) : "Downcast must be safe"; - - InputEdge edge = new InputEdge((char)fromIndex, (char)toIndex, from, to); - if(!this.getEdges().contains(edge)) { - this.addEdge(edge); - } - } - public void ensureNodesInBlocks() { InputBlock noBlock = null; Set scheduledNodes = new HashSet<>(); @@ -304,7 +294,7 @@ public class InputGraph extends Properties.Entity implements FolderElement { public InputBlock addArtificialBlock() { InputBlock b = addBlock("(no block)"); - b.setArtificial(true); + b.setArtificial(); return b; } diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputMethod.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputMethod.java index 9f2cce8aadd..ccc455ba8f1 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputMethod.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputMethod.java @@ -35,13 +35,13 @@ import java.util.regex.Pattern; */ public class InputMethod extends Properties.Entity { - private String name; - private int bci; - private String shortName; - private List inlined; + private final String name; + private final int bci; + private final String shortName; + private final List inlined; private InputMethod parentMethod; - private Group group; - private List bytecodes; + private final Group group; + private final List bytecodes; @Override public int hashCode() { @@ -55,11 +55,10 @@ public class InputMethod extends Properties.Entity { @Override public boolean equals(Object o) { - if (o == null || (!(o instanceof InputMethod))) { + if ((!(o instanceof InputMethod))) { return false; } - - final InputMethod im = (InputMethod)o; + final InputMethod im = (InputMethod) o; return name.equals(im.name) && bci == im.bci && shortName.equals(im.shortName) && inlined.equals(im.inlined) && bytecodes.equals(im.bytecodes); } diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputNode.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputNode.java index fc6b363fe18..75b8b17ed5a 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputNode.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/InputNode.java @@ -23,10 +23,6 @@ */ package com.sun.hotspot.igv.data; -import java.util.ArrayList; -import java.util.Comparator; -import java.util.List; - /** * * @author Thomas Wuerthinger @@ -34,37 +30,6 @@ import java.util.List; public class InputNode extends Properties.Entity { private int id; - private List subgraphs; - - public static final Comparator COMPARATOR = new Comparator() { - @Override - public int compare(InputNode o1, InputNode o2) { - return o1.getId() - o2.getId(); - } - }; - - public static Comparator getPropertyComparator(final String propertyName) { - return new Comparator() { - - @Override - public int compare(InputNode o1, InputNode o2) { - - int i1 = 0; - try { - i1 = Integer.parseInt(o1.getProperties().get(propertyName)); - } catch(NumberFormatException e) { - } - - int i2 = 0; - try { - i2 = Integer.parseInt(o2.getProperties().get(propertyName)); - } catch(NumberFormatException e) { - } - - return i1 - i2; - } - }; - } public InputNode(InputNode n) { super(n); @@ -83,17 +48,6 @@ public class InputNode extends Properties.Entity { return id; } - public void addSubgraph(InputGraph graph) { - if (subgraphs == null) { - subgraphs = new ArrayList<>(); - } - subgraphs.add(graph); - } - - public List getSubgraphs() { - return subgraphs; - } - @Override public boolean equals(Object o) { if (!(o instanceof InputNode)) { diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Pair.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Pair.java index 8c15c6cf667..434fb83e5c1 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Pair.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Pair.java @@ -58,10 +58,10 @@ public class Pair { @Override public boolean equals(Object o) { - if (o == null || !(o instanceof Pair)) { + if (!(o instanceof Pair)) { return false; } - Pair obj = (Pair) o; + Pair obj = (Pair) o; boolean b1 = (l == obj.l); if (l != null) { b1 = l.equals(obj.l); diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Properties.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Properties.java index 36df1e2576a..ec230c2214a 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Properties.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Properties.java @@ -26,7 +26,6 @@ package com.sun.hotspot.igv.data; import java.io.Serializable; import java.lang.ref.WeakReference; import java.util.*; -import java.util.Map.Entry; import java.util.regex.Matcher; import java.util.regex.Pattern; import java.util.regex.PatternSyntaxException; @@ -188,7 +187,7 @@ public class Properties implements Serializable, Iterable { public static class InvertPropertyMatcher implements PropertyMatcher { - private PropertyMatcher matcher; + private final PropertyMatcher matcher; public InvertPropertyMatcher(PropertyMatcher matcher) { this.matcher = matcher; @@ -210,8 +209,8 @@ public class Properties implements Serializable, Iterable { public static class StringPropertyMatcher implements PropertyMatcher { - private String name; - private String value; + private final String name; + private final String value; public StringPropertyMatcher(String name, String value) { if (name == null) { @@ -240,8 +239,8 @@ public class Properties implements Serializable, Iterable { public static class RegexpPropertyMatcher implements PropertyMatcher { - private String name; - private Pattern valuePattern; + private final String name; + private final Pattern valuePattern; public RegexpPropertyMatcher(String name, String value) { this(name, value, 0); @@ -312,13 +311,10 @@ public class Properties implements Serializable, Iterable { } } - pairs.sort(new Comparator() { - @Override - public int compare(String[] o1, String[] o2) { - assert o1.length == 2; - assert o2.length == 2; - return o1[0].compareTo(o2[0]); - } + pairs.sort((o1, o2) -> { + assert o1.length == 2; + assert o2.length == 2; + return o1[0].compareTo(o2[0]); }); StringBuilder sb = new StringBuilder(); @@ -337,7 +333,7 @@ public class Properties implements Serializable, Iterable { public static class PropertySelector { - private Collection objects; + private final Collection objects; public PropertySelector(Collection objects) { this.objects = objects; diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Property.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Property.java index 95ec2fe45c3..3c4f57dbcae 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Property.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Property.java @@ -32,8 +32,8 @@ import java.io.Serializable; public class Property implements Serializable { public static final long serialVersionUID = 1L; - private String name; - private String value; + private final String name; + private final String value; Property(String name, String value) { this.name = name; diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Source.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Source.java index 5a8e83eb973..43243ad6fd8 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Source.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/Source.java @@ -31,8 +31,8 @@ import java.util.*; */ public class Source { - private List sourceNodes; - private Set set; + private final List sourceNodes; + private final Set set; public Source() { sourceNodes = new ArrayList<>(1); @@ -56,12 +56,7 @@ public class Source { public interface Provider { - public Source getSource(); + Source getSource(); } - public void addSourceNodes(Source s) { - for (InputNode n : s.getSourceNodes()) { - addSourceNode(n); - } - } } diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/BinaryParser.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/BinaryParser.java deleted file mode 100644 index bfb6a86d1e0..00000000000 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/BinaryParser.java +++ /dev/null @@ -1,937 +0,0 @@ -/* - * Copyright (c) 2012, 2021, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package com.sun.hotspot.igv.data.serialization; - -import com.sun.hotspot.igv.data.*; -import com.sun.hotspot.igv.data.Properties; -import com.sun.hotspot.igv.data.services.GroupCallback; -import java.io.EOFException; -import java.io.IOException; -import java.nio.ByteBuffer; -import java.nio.channels.ReadableByteChannel; -import java.util.*; -import java.util.regex.Matcher; -import java.util.regex.Pattern; -import javax.swing.SwingUtilities; -import java.security.MessageDigest; -import java.security.NoSuchAlgorithmException; - -import static java.nio.charset.StandardCharsets.UTF_8; - -public class BinaryParser implements GraphParser { - private static final int BEGIN_GROUP = 0x00; - private static final int BEGIN_GRAPH = 0x01; - private static final int CLOSE_GROUP = 0x02; - - private static final int POOL_NEW = 0x00; - private static final int POOL_STRING = 0x01; - private static final int POOL_ENUM = 0x02; - private static final int POOL_CLASS = 0x03; - private static final int POOL_METHOD = 0x04; - private static final int POOL_NULL = 0x05; - private static final int POOL_NODE_CLASS = 0x06; - private static final int POOL_FIELD = 0x07; - private static final int POOL_SIGNATURE = 0x08; - - private static final int KLASS = 0x00; - private static final int ENUM_KLASS = 0x01; - - private static final int PROPERTY_POOL = 0x00; - private static final int PROPERTY_INT = 0x01; - private static final int PROPERTY_LONG = 0x02; - private static final int PROPERTY_DOUBLE = 0x03; - private static final int PROPERTY_FLOAT = 0x04; - private static final int PROPERTY_TRUE = 0x05; - private static final int PROPERTY_FALSE = 0x06; - private static final int PROPERTY_ARRAY = 0x07; - private static final int PROPERTY_SUBGRAPH = 0x08; - - private static final String NO_BLOCK = "noBlock"; - - private final GroupCallback callback; - private final List constantPool; - private final ByteBuffer buffer; - private final ReadableByteChannel channel; - private final GraphDocument rootDocument; - private final Deque folderStack; - private final Deque hashStack; - private final ParseMonitor monitor; - - private MessageDigest digest; - - private enum Length { - S, - M, - L - } - - private interface LengthToString { - String toString(Length l); - } - - private abstract static class Member implements LengthToString { - public final Klass holder; - public final int accessFlags; - public final String name; - public Member(Klass holder, String name, int accessFlags) { - this.holder = holder; - this.accessFlags = accessFlags; - this.name = name; - } - } - - private static class Method extends Member { - public final Signature signature; - public final byte[] code; - public Method(String name, Signature signature, byte[] code, Klass holder, int accessFlags) { - super(holder, name, accessFlags); - this.signature = signature; - this.code = code; - } - @Override - public String toString() { - StringBuilder sb = new StringBuilder(); - sb.append(holder).append('.').append(name).append('('); - for (int i = 0; i < signature.argTypes.length; i++) { - if (i > 0) { - sb.append(", "); - } - sb.append(signature.argTypes[i]); - } - sb.append(')'); - return sb.toString(); - } - @Override - public String toString(Length l) { - switch(l) { - case M: - return holder.toString(Length.L) + "." + name; - case S: - return holder.toString(Length.S) + "." + name; - default: - case L: - return toString(); - } - } - } - - private static class Signature { - public final String returnType; - public final String[] argTypes; - public Signature(String returnType, String[] argTypes) { - this.returnType = returnType; - this.argTypes = argTypes; - } - } - - private static class Field extends Member { - public final String type; - public Field(String type, Klass holder, String name, int accessFlags) { - super(holder, name, accessFlags); - this.type = type; - } - @Override - public String toString() { - return holder + "." + name; - } - @Override - public String toString(Length l) { - switch(l) { - case M: - return holder.toString(Length.L) + "." + name; - case S: - return holder.toString(Length.S) + "." + name; - default: - case L: - return toString(); - } - } - } - - private static class Klass implements LengthToString { - public final String name; - public final String simpleName; - public Klass(String name) { - this.name = name; - String simple; - try { - simple = name.substring(name.lastIndexOf('.') + 1); - } catch (IndexOutOfBoundsException ioobe) { - simple = name; - } - this.simpleName = simple; - } - @Override - public String toString() { - return name; - } - @Override - public String toString(Length l) { - switch(l) { - case S: - return simpleName; - default: - case L: - case M: - return toString(); - } - } - } - - private static class EnumKlass extends Klass { - public final String[] values; - public EnumKlass(String name, String[] values) { - super(name); - this.values = values; - } - } - - private static class Port { - public final boolean isList; - public final String name; - private Port(boolean isList, String name) { - this.isList = isList; - this.name = name; - } - } - - private static class TypedPort extends Port { - public final EnumValue type; - private TypedPort(boolean isList, String name, EnumValue type) { - super(isList, name); - this.type = type; - } - } - - private static class NodeClass { - public final String className; - public final String nameTemplate; - public final List inputs; - public final List sux; - private NodeClass(String className, String nameTemplate, List inputs, List sux) { - this.className = className; - this.nameTemplate = nameTemplate; - this.inputs = inputs; - this.sux = sux; - } - @Override - public String toString() { - return className; - } - } - - private static class EnumValue implements LengthToString { - public EnumKlass enumKlass; - public int ordinal; - public EnumValue(EnumKlass enumKlass, int ordinal) { - this.enumKlass = enumKlass; - this.ordinal = ordinal; - } - @Override - public String toString() { - return enumKlass.simpleName + "." + enumKlass.values[ordinal]; - } - @Override - public String toString(Length l) { - switch(l) { - case S: - return enumKlass.values[ordinal]; - default: - case M: - case L: - return toString(); - } - } - } - - public BinaryParser(ReadableByteChannel channel, ParseMonitor monitor, GraphDocument rootDocument, GroupCallback callback) { - this.callback = callback; - constantPool = new ArrayList<>(); - buffer = ByteBuffer.allocateDirect(256 * 1024); - buffer.flip(); - this.channel = channel; - this.rootDocument = rootDocument; - folderStack = new LinkedList<>(); - hashStack = new LinkedList<>(); - this.monitor = monitor; - try { - this.digest = MessageDigest.getInstance("SHA-1"); - } catch (NoSuchAlgorithmException e) { - } - } - - private void fill() throws IOException { - // All the data between lastPosition and position has been - // used so add it to the digest. - int position = buffer.position(); - buffer.position(lastPosition); - byte[] remaining = new byte[position - buffer.position()]; - buffer.get(remaining); - digest.update(remaining); - assert position == buffer.position(); - - buffer.compact(); - if (channel.read(buffer) < 0) { - throw new EOFException(); - } - buffer.flip(); - lastPosition = buffer.position(); - } - - private void ensureAvailable(int i) throws IOException { - if (i > buffer.capacity()) { - throw new IllegalArgumentException(String.format("Can not request %d bytes: buffer capacity is %d", i, buffer.capacity())); - } - while (buffer.remaining() < i) { - fill(); - } - } - - private int readByte() throws IOException { - ensureAvailable(1); - return ((int)buffer.get()) & 0xff; - } - - private int readInt() throws IOException { - ensureAvailable(4); - return buffer.getInt(); - } - - private char readShort() throws IOException { - ensureAvailable(2); - return buffer.getChar(); - } - - private long readLong() throws IOException { - ensureAvailable(8); - return buffer.getLong(); - } - - private double readDouble() throws IOException { - ensureAvailable(8); - return buffer.getDouble(); - } - - private float readFloat() throws IOException { - ensureAvailable(4); - return buffer.getFloat(); - } - - private String readString() throws IOException { - return new String(readBytes(), UTF_8).intern(); - } - - private byte[] readBytes() throws IOException { - int len = readInt(); - if (len < 0) { - return null; - } - byte[] b = new byte[len]; - int bytesRead = 0; - while (bytesRead < b.length) { - int toRead = Math.min(b.length - bytesRead, buffer.capacity()); - ensureAvailable(toRead); - buffer.get(b, bytesRead, toRead); - bytesRead += toRead; - } - return b; - } - - private String readIntsToString() throws IOException { - int len = readInt(); - if (len < 0) { - return "null"; - } - ensureAvailable(len * 4); - StringBuilder sb = new StringBuilder().append('['); - for (int i = 0; i < len; i++) { - sb.append(buffer.getInt()); - if (i < len - 1) { - sb.append(", "); - } - } - sb.append(']'); - return sb.toString().intern(); - } - - private String readDoublesToString() throws IOException { - int len = readInt(); - if (len < 0) { - return "null"; - } - ensureAvailable(len * 8); - StringBuilder sb = new StringBuilder().append('['); - for (int i = 0; i < len; i++) { - sb.append(buffer.getDouble()); - if (i < len - 1) { - sb.append(", "); - } - } - sb.append(']'); - return sb.toString().intern(); - } - - private String readPoolObjectsToString() throws IOException { - int len = readInt(); - if (len < 0) { - return "null"; - } - StringBuilder sb = new StringBuilder().append('['); - for (int i = 0; i < len; i++) { - sb.append(readPoolObject(Object.class)); - if (i < len - 1) { - sb.append(", "); - } - } - sb.append(']'); - return sb.toString().intern(); - } - - private T readPoolObject(Class klass) throws IOException { - int type = readByte(); - if (type == POOL_NULL) { - return null; - } - if (type == POOL_NEW) { - return (T) addPoolEntry(klass); - } - assert assertObjectType(klass, type); - char index = readShort(); - if (index < 0 || index >= constantPool.size()) { - throw new IOException("Invalid constant pool index : " + index); - } - Object obj = constantPool.get(index); - return (T) obj; - } - - private boolean assertObjectType(Class klass, int type) { - switch(type) { - case POOL_CLASS: - return klass.isAssignableFrom(EnumKlass.class); - case POOL_ENUM: - return klass.isAssignableFrom(EnumValue.class); - case POOL_METHOD: - return klass.isAssignableFrom(Method.class); - case POOL_STRING: - return klass.isAssignableFrom(String.class); - case POOL_NODE_CLASS: - return klass.isAssignableFrom(NodeClass.class); - case POOL_FIELD: - return klass.isAssignableFrom(Field.class); - case POOL_SIGNATURE: - return klass.isAssignableFrom(Signature.class); - case POOL_NULL: - return true; - default: - return false; - } - } - - private Object addPoolEntry(Class klass) throws IOException { - char index = readShort(); - int type = readByte(); - assert assertObjectType(klass, type) : "Wrong object type : " + klass + " != " + type; - Object obj; - switch(type) { - case POOL_CLASS: { - String name = readString(); - int klasstype = readByte(); - if (klasstype == ENUM_KLASS) { - int len = readInt(); - String[] values = new String[len]; - for (int i = 0; i < len; i++) { - values[i] = readPoolObject(String.class); - } - obj = new EnumKlass(name, values); - } else if (klasstype == KLASS) { - obj = new Klass(name); - } else { - throw new IOException("unknown klass type : " + klasstype); - } - break; - } - case POOL_ENUM: { - EnumKlass enumClass = readPoolObject(EnumKlass.class); - int ordinal = readInt(); - obj = new EnumValue(enumClass, ordinal); - break; - } - case POOL_NODE_CLASS: { - String className = readString(); - String nameTemplate = readString(); - int inputCount = readShort(); - List inputs = new ArrayList<>(inputCount); - for (int i = 0; i < inputCount; i++) { - boolean isList = readByte() != 0; - String name = readPoolObject(String.class); - EnumValue inputType = readPoolObject(EnumValue.class); - inputs.add(new TypedPort(isList, name, inputType)); - } - int suxCount = readShort(); - List sux = new ArrayList<>(suxCount); - for (int i = 0; i < suxCount; i++) { - boolean isList = readByte() != 0; - String name = readPoolObject(String.class); - sux.add(new Port(isList, name)); - } - obj = new NodeClass(className, nameTemplate, inputs, sux); - break; - } - case POOL_METHOD: { - Klass holder = readPoolObject(Klass.class); - String name = readPoolObject(String.class); - Signature sign = readPoolObject(Signature.class); - int flags = readInt(); - byte[] code = readBytes(); - obj = new Method(name, sign, code, holder, flags); - break; - } - case POOL_FIELD: { - Klass holder = readPoolObject(Klass.class); - String name = readPoolObject(String.class); - String fType = readPoolObject(String.class); - int flags = readInt(); - obj = new Field(fType, holder, name, flags); - break; - } - case POOL_SIGNATURE: { - int argc = readShort(); - String[] args = new String[argc]; - for (int i = 0; i < argc; i++) { - args[i] = readPoolObject(String.class); - } - String returnType = readPoolObject(String.class); - obj = new Signature(returnType, args); - break; - } - case POOL_STRING: { - obj = readString(); - break; - } - default: - throw new IOException("unknown pool type"); - } - while (constantPool.size() <= index) { - constantPool.add(null); - } - constantPool.set(index, obj); - return obj; - } - - private Object readPropertyObject() throws IOException { - int type = readByte(); - switch (type) { - case PROPERTY_INT: - return readInt(); - case PROPERTY_LONG: - return readLong(); - case PROPERTY_FLOAT: - return readFloat(); - case PROPERTY_DOUBLE: - return readDouble(); - case PROPERTY_TRUE: - return Boolean.TRUE; - case PROPERTY_FALSE: - return Boolean.FALSE; - case PROPERTY_POOL: - return readPoolObject(Object.class); - case PROPERTY_ARRAY: - int subType = readByte(); - switch(subType) { - case PROPERTY_INT: - return readIntsToString(); - case PROPERTY_DOUBLE: - return readDoublesToString(); - case PROPERTY_POOL: - return readPoolObjectsToString(); - default: - throw new IOException("Unknown type"); - } - case PROPERTY_SUBGRAPH: - InputGraph graph = parseGraph(""); - new Group(null).addElement(graph); - return graph; - default: - throw new IOException("Unknown type"); - } - } - - @Override - public GraphDocument parse() throws IOException { - folderStack.push(rootDocument); - hashStack.push(null); - if (monitor != null) { - monitor.setState("Starting parsing"); - } - try { - while(true) { - parseRoot(); - } - } catch (EOFException e) { - - } - if (monitor != null) { - monitor.setState("Finished parsing"); - } - return rootDocument; - } - - private void parseRoot() throws IOException { - int type = readByte(); - switch(type) { - case BEGIN_GRAPH: { - final Folder parent = folderStack.peek(); - final InputGraph graph = parseGraph(); - SwingUtilities.invokeLater(new Runnable(){ - @Override - public void run() { - parent.addElement(graph); - } - }); - break; - } - case BEGIN_GROUP: { - final Folder parent = folderStack.peek(); - final Group group = parseGroup(parent); - if (callback == null || parent instanceof Group) { - SwingUtilities.invokeLater(new Runnable(){ - @Override - public void run() { - parent.addElement(group); - } - }); - } - folderStack.push(group); - hashStack.push(null); - if (callback != null && parent instanceof GraphDocument) { - callback.started(group); - } - break; - } - case CLOSE_GROUP: { - if (folderStack.isEmpty()) { - throw new IOException("Unbalanced groups"); - } - folderStack.pop(); - hashStack.pop(); - break; - } - default: - throw new IOException("unknown root : " + type); - } - } - - private Group parseGroup(Folder parent) throws IOException { - String name = readPoolObject(String.class); - String shortName = readPoolObject(String.class); - if (monitor != null) { - monitor.setState(shortName); - } - Method method = readPoolObject(Method.class); - int bci = readInt(); - Group group = new Group(parent); - group.getProperties().setProperty("name", name); - parseProperties(group.getProperties()); - if (method != null) { - InputMethod inMethod = new InputMethod(group, method.name, shortName, bci); - inMethod.setBytecodes("TODO"); - group.setMethod(inMethod); - } - return group; - } - - int lastPosition = 0; - - private InputGraph parseGraph() throws IOException { - if (monitor != null) { - monitor.updateProgress(); - } - String title = readPoolObject(String.class); - digest.reset(); - lastPosition = buffer.position(); - InputGraph graph = parseGraph(title); - - int position = buffer.position(); - buffer.position(lastPosition); - byte[] remaining = new byte[position - buffer.position()]; - buffer.get(remaining); - digest.update(remaining); - assert position == buffer.position(); - lastPosition = buffer.position(); - - byte[] d = digest.digest(); - byte[] hash = hashStack.peek(); - if (hash != null && Arrays.equals(hash, d)) { - graph.getProperties().setProperty("_isDuplicate", "true"); - } else { - hashStack.pop(); - hashStack.push(d); - } - return graph; - } - - private void parseProperties(Properties properties) throws IOException { - int propCount = readShort(); - for (int j = 0; j < propCount; j++) { - String key = readPoolObject(String.class); - Object value = readPropertyObject(); - properties.setProperty(key, value != null ? value.toString() : "null"); - } - } - - private InputGraph parseGraph(String title) throws IOException { - InputGraph graph = new InputGraph(title); - parseProperties(graph.getProperties()); - parseNodes(graph); - parseBlocks(graph); - graph.ensureNodesInBlocks(); - for (InputNode node : graph.getNodes()) { - node.internProperties(); - } - return graph; - } - - private void parseBlocks(InputGraph graph) throws IOException { - int blockCount = readInt(); - List edges = new LinkedList<>(); - for (int i = 0; i < blockCount; i++) { - int id = readInt(); - String name = id >= 0 ? Integer.toString(id) : NO_BLOCK; - InputBlock block = graph.addBlock(name); - int nodeCount = readInt(); - for (int j = 0; j < nodeCount; j++) { - int nodeId = readInt(); - if (nodeId < 0) { - continue; - } - final Properties properties = graph.getNode(nodeId).getProperties(); - final String oldBlock = properties.get("block"); - if(oldBlock != null) { - properties.setProperty("block", oldBlock + ", " + name); - } else { - block.addNode(nodeId); - properties.setProperty("block", name); - } - } - int edgeCount = readInt(); - for (int j = 0; j < edgeCount; j++) { - int to = readInt(); - edges.add(new Edge(id, to)); - } - } - for (Edge e : edges) { - String fromName = e.from >= 0 ? Integer.toString(e.from) : NO_BLOCK; - String toName = e.to >= 0 ? Integer.toString(e.to) : NO_BLOCK; - graph.addBlockEdge(graph.getBlock(fromName), graph.getBlock(toName)); - } - } - - private void parseNodes(InputGraph graph) throws IOException { - int count = readInt(); - Map props = new HashMap<>(); - List inputEdges = new ArrayList<>(count); - List succEdges = new ArrayList<>(count); - for (int i = 0; i < count; i++) { - int id = readInt(); - InputNode node = new InputNode(id); - final Properties properties = node.getProperties(); - NodeClass nodeClass = readPoolObject(NodeClass.class); - int preds = readByte(); - if (preds > 0) { - properties.setProperty("hasPredecessor", "true"); - } - properties.setProperty("idx", Integer.toString(id)); - int propCount = readShort(); - for (int j = 0; j < propCount; j++) { - String key = readPoolObject(String.class); - if (key.equals("hasPredecessor") || key.equals("name") || key.equals("class") || key.equals("id") || key.equals("idx")) { - key = "!data." + key; - } - Object value = readPropertyObject(); - if (value instanceof InputGraph) { - InputGraph subgraph = (InputGraph) value; - subgraph.getProperties().setProperty("name", node.getId() + ":" + key); - node.addSubgraph((InputGraph) value); - } else { - properties.setProperty(key, value != null ? value.toString() : "null"); - props.put(key, value); - } - } - ArrayList currentEdges = new ArrayList<>(); - int portNum = 0; - for (TypedPort p : nodeClass.inputs) { - if (p.isList) { - int size = readShort(); - for (int j = 0; j < size; j++) { - int in = readInt(); - if (in >= 0) { - Edge e = new Edge(in, id, (char) (preds + portNum), p.name + "[" + j + "]", p.type.toString(Length.S), true); - currentEdges.add(e); - inputEdges.add(e); - portNum++; - } - } - } else { - int in = readInt(); - if (in >= 0) { - Edge e = new Edge(in, id, (char) (preds + portNum), p.name, p.type.toString(Length.S), true); - currentEdges.add(e); - inputEdges.add(e); - portNum++; - } - } - - } - portNum = 0; - for (Port p : nodeClass.sux) { - if (p.isList) { - int size = readShort(); - for (int j = 0; j < size; j++) { - int sux = readInt(); - if (sux >= 0) { - Edge e = new Edge(id, sux, (char) portNum, p.name + "[" + j + "]", "Successor", false); - currentEdges.add(e); - succEdges.add(e); - portNum++; - } - } - } else { - int sux = readInt(); - if (sux >= 0) { - Edge e = new Edge(id, sux, (char) portNum, p.name, "Successor", false); - currentEdges.add(e); - succEdges.add(e); - portNum++; - } - } - } - properties.setProperty("name", createName(currentEdges, props, nodeClass.nameTemplate)); - properties.setProperty("class", nodeClass.className); - switch (nodeClass.className) { - case "BeginNode": - properties.setProperty("shortName", "B"); - break; - case "EndNode": - properties.setProperty("shortName", "E"); - break; - } - graph.addNode(node); - props.clear(); - } - - Set nodesWithSuccessor = new HashSet<>(); - - for (Edge e : succEdges) { - assert !e.input; - char fromIndex = e.num; - nodesWithSuccessor.add(graph.getNode(e.from)); - char toIndex = 0; - graph.addEdge(InputEdge.createImmutable(fromIndex, toIndex, e.from, e.to, e.label, e.type)); - } - for (Edge e : inputEdges) { - assert e.input; - char fromIndex = (char) (nodesWithSuccessor.contains(graph.getNode(e.from)) ? 1 : 0); - char toIndex = e.num; - graph.addEdge(InputEdge.createImmutable(fromIndex, toIndex, e.from, e.to, e.label, e.type)); - } - } - - static final Pattern templatePattern = Pattern.compile("\\{(p|i)#([a-zA-Z0-9$_]+)(/(l|m|s))?\\}"); - - private String createName(List edges, Map properties, String template) { - Matcher m = templatePattern.matcher(template); - StringBuffer sb = new StringBuffer(); - while (m.find()) { - String name = m.group(2); - String type = m.group(1); - String result; - switch (type) { - case "i": - StringBuilder inputString = new StringBuilder(); - for(Edge edge : edges) { - if (edge.label.startsWith(name) && (name.length() == edge.label.length() || edge.label.charAt(name.length()) == '[')) { - if (inputString.length() > 0) { - inputString.append(", "); - } - inputString.append(edge.from); - } - } - result = inputString.toString(); - break; - case "p": - Object prop = properties.get(name); - String length = m.group(4); - if (prop == null) { - result = "?"; - } else if (length != null && prop instanceof LengthToString) { - LengthToString lengthProp = (LengthToString) prop; - switch(length) { - default: - case "l": - result = lengthProp.toString(Length.L); - break; - case "m": - result = lengthProp.toString(Length.M); - break; - case "s": - result = lengthProp.toString(Length.S); - break; - } - } else { - result = prop.toString(); - } - break; - default: - result = "#?#"; - break; - } - result = result.replace("\\", "\\\\"); - result = result.replace("$", "\\$"); - m.appendReplacement(sb, result); - } - m.appendTail(sb); - return sb.toString().intern(); - } - - private static class Edge { - final int from; - final int to; - final char num; - final String label; - final String type; - final boolean input; - public Edge(int from, int to) { - this(from, to, (char) 0, null, null, false); - } - public Edge(int from, int to, char num, String label, String type, boolean input) { - this.from = from; - this.to = to; - this.label = label != null ? label.intern() : label; - this.type = type != null ? type.intern() : type; - this.num = num; - this.input = input; - } - } -} diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/GraphParser.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/GraphParser.java index a517ce8e9bd..cd7b8cf71cf 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/GraphParser.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/GraphParser.java @@ -28,5 +28,5 @@ import com.sun.hotspot.igv.data.GraphDocument; import java.io.IOException; public interface GraphParser { - public GraphDocument parse() throws IOException; + GraphDocument parse() throws IOException; } diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/ParseMonitor.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/ParseMonitor.java index ebf86ffbc9e..4fbd13a1ab1 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/ParseMonitor.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/ParseMonitor.java @@ -26,8 +26,8 @@ package com.sun.hotspot.igv.data.serialization; public interface ParseMonitor { - public void updateProgress(); + void updateProgress(); - public void setState(String state); + void setState(String state); } diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Parser.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Parser.java index 31a373991c1..26dc2c6cfb2 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Parser.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Parser.java @@ -29,7 +29,6 @@ import com.sun.hotspot.igv.data.serialization.XMLParser.HandoverElementHandler; import com.sun.hotspot.igv.data.serialization.XMLParser.TopElementHandler; import com.sun.hotspot.igv.data.services.GroupCallback; import java.io.IOException; -import java.io.InputStream; import java.nio.channels.Channels; import java.nio.channels.ReadableByteChannel; import java.util.ArrayList; @@ -39,9 +38,6 @@ import java.util.Map; import javax.swing.SwingUtilities; import javax.xml.parsers.ParserConfigurationException; import javax.xml.parsers.SAXParserFactory; -import javax.xml.transform.Source; -import javax.xml.transform.stream.StreamSource; -import javax.xml.validation.SchemaFactory; import org.xml.sax.InputSource; import org.xml.sax.SAXException; import org.xml.sax.SAXParseException; @@ -95,12 +91,12 @@ public class Parser implements GraphParser { public static final String SUCCESSOR_ELEMENT = "successor"; public static final String ASSEMBLY_ELEMENT = "assembly"; public static final String DIFFERENCE_PROPERTY = "difference"; - private TopElementHandler xmlDocument = new TopElementHandler<>(); - private Map differenceEncoding = new HashMap<>(); - private Map lastParsedGraph = new HashMap<>(); - private GroupCallback groupCallback; - private HashMap idCache = new HashMap<>(); - private ArrayList> blockConnections = new ArrayList<>(); + private final TopElementHandler xmlDocument = new TopElementHandler<>(); + private final Map differenceEncoding = new HashMap<>(); + private final Map lastParsedGraph = new HashMap<>(); + private final GroupCallback groupCallback; + private final HashMap idCache = new HashMap<>(); + private final ArrayList> blockConnections = new ArrayList<>(); private int maxId = 0; private GraphDocument graphDocument; private final ParseMonitor monitor; @@ -118,7 +114,7 @@ public class Parser implements GraphParser { id = maxId++; idCache.put(i, id); } - return id.intValue(); + return id; } // diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Printer.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Printer.java index 8cf190869df..eb3f1451703 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Printer.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Printer.java @@ -36,7 +36,7 @@ import java.util.Set; */ public class Printer { - private InputStream in; + private final InputStream in; public Printer() { this(null); @@ -52,8 +52,7 @@ public class Printer { try { export(xmlWriter, document); - } catch (IOException ex) { - } + } catch (IOException ignored) {} } private void export(XMLWriter xmlWriter, GraphDocument document) throws IOException { diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/XMLParser.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/XMLParser.java index c65d34f7516..5145480a747 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/XMLParser.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/XMLParser.java @@ -23,7 +23,6 @@ */ package com.sun.hotspot.igv.data.serialization; -import com.sun.hotspot.igv.data.Properties; import java.util.HashMap; import java.util.Stack; import org.xml.sax.Attributes; @@ -39,16 +38,10 @@ public class XMLParser implements ContentHandler { public static class MissingAttributeException extends SAXException { - private String name; - public MissingAttributeException(String name) { super("Missing attribute \"" + name + "\""); - this.name = name; } - public String getAttributeName() { - return this.getMessage(); - } } public static class HandoverElementHandler

extends ElementHandler { @@ -76,24 +69,20 @@ public class XMLParser implements ContentHandler { public static class ElementHandler { - private String name; - private Stack object = new Stack<>(); + private final String name; + private final Stack object = new Stack<>(); private Attributes attr; private StringBuilder currentText; private ParseMonitor monitor; - private HashMap> hashtable; - private boolean needsText; - private Stack> parentElement = new Stack<>(); - private Stack

parentObject = new Stack<>(); + private final HashMap> hashtable; + private final boolean needsText; + private final Stack> parentElement = new Stack<>(); + private final Stack

parentObject = new Stack<>(); public ElementHandler(String name) { this(name, false); } - public ElementHandler getParentElement() { - return parentElement.peek(); - } - public P getParentObject() { return parentObject.peek(); } @@ -141,15 +130,6 @@ public class XMLParser implements ContentHandler { return s; } - public void processAttributesAsProperties(Properties p) { - int length = attr.getLength(); - for (int i = 0; i < length; i++) { - String val = attr.getValue(i); - String localName = attr.getLocalName(i); - p.setProperty(val, localName); - } - } - public void startElement(ElementHandler parentElement, Attributes attr, ParseMonitor monitor) throws SAXException { this.currentText = new StringBuilder(); this.attr = attr; @@ -179,8 +159,8 @@ public class XMLParser implements ContentHandler { currentText.append(c, start, length); } } - private Stack stack; - private ParseMonitor monitor; + private final Stack stack; + private final ParseMonitor monitor; public XMLParser(TopElementHandler rootHandler, ParseMonitor monitor) { this.stack = new Stack<>(); diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/XMLWriter.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/XMLWriter.java index b9408d992b8..1e142efda1f 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/XMLWriter.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/XMLWriter.java @@ -36,8 +36,8 @@ import java.util.Stack; */ public class XMLWriter extends Writer { - private Writer inner; - private Stack elementStack; + private final Writer inner; + private final Stack elementStack; public XMLWriter(Writer inner) { this.inner = inner; @@ -114,7 +114,7 @@ public class XMLWriter extends Writer { } public void writeProperties(Properties props) throws IOException { - if (props.iterator().hasNext() == false) { + if (!props.iterator().hasNext()) { return; } diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/ChangedEventTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/ChangedEventTest.java index 89d22f2ce6e..d746dce62fd 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/ChangedEventTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/ChangedEventTest.java @@ -24,8 +24,8 @@ package com.sun.hotspot.igv.data; -import static org.junit.Assert.assertEquals; import org.junit.*; +import static org.junit.Assert.assertEquals; /** * diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/ControllableChangedListenerTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/ControllableChangedListenerTest.java index 999475ce95b..8391985d659 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/ControllableChangedListenerTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/ControllableChangedListenerTest.java @@ -24,8 +24,8 @@ package com.sun.hotspot.igv.data; -import static org.junit.Assert.*; import org.junit.*; +import static org.junit.Assert.*; /** * diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/GroupTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/GroupTest.java index 9c6616b6df6..d22ccf9dca1 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/GroupTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/GroupTest.java @@ -26,8 +26,8 @@ package com.sun.hotspot.igv.data; import java.util.Arrays; import java.util.HashSet; -import static org.junit.Assert.assertEquals; import org.junit.*; +import static org.junit.Assert.assertEquals; /** * diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/InputMethodTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/InputMethodTest.java index 8b3f2371f8d..aabfe8d6547 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/InputMethodTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/InputMethodTest.java @@ -26,8 +26,8 @@ package com.sun.hotspot.igv.data; import static org.hamcrest.CoreMatchers.is; import static org.hamcrest.CoreMatchers.nullValue; -import static org.junit.Assert.assertThat; import org.junit.*; +import static org.junit.Assert.assertThat; /** * diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PairTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PairTest.java index 6b615c62785..73f324c1b2c 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PairTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PairTest.java @@ -25,8 +25,8 @@ package com.sun.hotspot.igv.data; -import static org.junit.Assert.*; import org.junit.*; +import static org.junit.Assert.*; /** * diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PropertiesTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PropertiesTest.java index 0310dd4d8a2..7ed2fa5f493 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PropertiesTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PropertiesTest.java @@ -25,11 +25,7 @@ package com.sun.hotspot.igv.data; -import com.sun.hotspot.igv.data.Properties.InvertPropertyMatcher; -import com.sun.hotspot.igv.data.Properties.PropertyMatcher; -import com.sun.hotspot.igv.data.Properties.PropertySelector; -import com.sun.hotspot.igv.data.Properties.RegexpPropertyMatcher; -import com.sun.hotspot.igv.data.Properties.StringPropertyMatcher; +import com.sun.hotspot.igv.data.Properties.*; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PropertyTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PropertyTest.java index ab90788433d..1f6c760613d 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PropertyTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/PropertyTest.java @@ -25,8 +25,8 @@ package com.sun.hotspot.igv.data; -import static org.junit.Assert.*; import org.junit.*; +import static org.junit.Assert.*; /** * diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/SourceTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/SourceTest.java index 7c525017ceb..b2cf486537e 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/SourceTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/SourceTest.java @@ -26,8 +26,8 @@ package com.sun.hotspot.igv.data; import java.util.Arrays; import java.util.LinkedHashSet; -import static org.junit.Assert.assertEquals; import org.junit.*; +import static org.junit.Assert.assertEquals; /** * diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/Util.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/Util.java index 8ad4977e46d..347dcab8428 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/Util.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/Util.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,16 +33,6 @@ import static org.junit.Assert.*; */ public class Util { - public static void assertGraphDocumentNotEquals(GraphDocument a, GraphDocument b) { - try { - assertGraphDocumentEquals(a, b); - } catch(AssertionError e) { - return; - } - - fail("Graphs documents are equal!"); - } - public static void assertGraphDocumentEquals(GraphDocument a, GraphDocument b) { if (a.getElements().size() != b.getElements().size()) { @@ -61,19 +51,9 @@ public class Util { } } - public static void assertGroupNotEquals(Group a, Group b) { - try { - assertGroupEquals(a, b); - } catch(AssertionError e) { - return; - } - - fail("Groups are equal!"); - } - public static void assertGroupEquals(Group a, Group b) { - if (a.getGraphsCount() != b.getGraphsCount()) { + if (a.getElements().size() != b.getElements().size()) { fail(); } diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/serialization/ParserTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/serialization/ParserTest.java index 1e4dfd5925f..43426046448 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/serialization/ParserTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/serialization/ParserTest.java @@ -26,15 +26,15 @@ package com.sun.hotspot.igv.data.serialization; import com.sun.hotspot.igv.data.*; -import java.io.*; +import java.io.ByteArrayInputStream; +import java.io.CharArrayWriter; +import java.io.IOException; +import java.io.InputStream; import java.nio.channels.Channels; - import static java.nio.charset.StandardCharsets.UTF_8; +import org.junit.*; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; -import org.junit.*; -import org.openide.util.Exceptions; -import org.xml.sax.InputSource; /** * diff --git a/src/utils/IdealGraphVisualizer/Difference/src/main/java/com/sun/hotspot/igv/difference/Difference.java b/src/utils/IdealGraphVisualizer/Difference/src/main/java/com/sun/hotspot/igv/difference/Difference.java index 894f51fba21..185d219c8de 100644 --- a/src/utils/IdealGraphVisualizer/Difference/src/main/java/com/sun/hotspot/igv/difference/Difference.java +++ b/src/utils/IdealGraphVisualizer/Difference/src/main/java/com/sun/hotspot/igv/difference/Difference.java @@ -287,9 +287,6 @@ public class Difference { } private static InputGraph createDiff(InputGraph a, InputGraph b) { - - Set matched = new HashSet<>(); - Set pairs = new HashSet<>(); for (InputNode n : a.getNodes()) { String s = n.getProperties().get(MAIN_PROPERTY); diff --git a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/AbstractFilter.java b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/AbstractFilter.java index f0cff78f1c2..15492d83f3f 100644 --- a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/AbstractFilter.java +++ b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/AbstractFilter.java @@ -38,7 +38,7 @@ public abstract class AbstractFilter implements Filter { private Properties properties; public AbstractFilter() { - changedEvent = new ChangedEvent(this); + changedEvent = new ChangedEvent<>(this); properties = new Properties(); } diff --git a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/ColorFilter.java b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/ColorFilter.java index 9e51f1ba865..a57f34f2c31 100644 --- a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/ColorFilter.java +++ b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/ColorFilter.java @@ -24,8 +24,8 @@ package com.sun.hotspot.igv.filter; import com.sun.hotspot.igv.data.Properties; -import com.sun.hotspot.igv.graph.Connection.ConnectionStyle; import com.sun.hotspot.igv.graph.*; +import com.sun.hotspot.igv.graph.Connection.ConnectionStyle; import java.awt.Color; import java.util.ArrayList; import java.util.List; diff --git a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/CombineFilter.java b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/CombineFilter.java index 5ee30b4d4d8..f26e878132e 100644 --- a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/CombineFilter.java +++ b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/CombineFilter.java @@ -74,7 +74,7 @@ public class CombineFilter extends AbstractFilter { } } - slot.getSource().addSourceNodes(f.getSource()); + slot.getSource().addSourceNode(f.getInputNode()); if (r.getShortProperty() != null) { String s = f.getProperties().get(r.getShortProperty()); if (s != null && s.length() > 0) { @@ -130,7 +130,7 @@ public class CombineFilter extends AbstractFilter { pos = Integer.parseInt(succ.getProperties().get("con")); } OutputSlot slot = f.createOutputSlot(pos); - slot.getSource().addSourceNodes(succ.getSource()); + slot.getSource().addSourceNode(succ.getInputNode()); if (r.getShortProperty() != null) { String s = succ.getProperties().get(r.getShortProperty()); if (s != null && s.length() > 0) { diff --git a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/CustomFilter.java b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/CustomFilter.java index 45a9bae6b54..ce47bcdac69 100644 --- a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/CustomFilter.java +++ b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/CustomFilter.java @@ -25,7 +25,10 @@ package com.sun.hotspot.igv.filter; import com.sun.hotspot.igv.graph.Diagram; -import javax.script.*; +import javax.script.Bindings; +import javax.script.ScriptContext; +import javax.script.ScriptEngine; +import javax.script.ScriptException; import org.openide.cookies.OpenCookie; import org.openide.util.Exceptions; diff --git a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/RemoveBlockFilter.java b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/RemoveBlockFilter.java index 787542eda2b..f1dde87af25 100644 --- a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/RemoveBlockFilter.java +++ b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/RemoveBlockFilter.java @@ -23,9 +23,9 @@ */ package com.sun.hotspot.igv.filter; -import com.sun.hotspot.igv.graph.Diagram; import com.sun.hotspot.igv.graph.Block; import com.sun.hotspot.igv.graph.BlockSelector; +import com.sun.hotspot.igv.graph.Diagram; import java.util.ArrayList; import java.util.HashSet; import java.util.List; diff --git a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/SplitFilter.java b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/SplitFilter.java index 825e4d6560b..a3d87f8e2e7 100644 --- a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/SplitFilter.java +++ b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/SplitFilter.java @@ -56,9 +56,9 @@ public class SplitFilter extends AbstractFilter { for (InputSlot is : f.getInputSlots()) { for (FigureConnection c : is.getConnections()) { OutputSlot os = c.getOutputSlot(); - if (f.getSource().getSourceNodes().size() > 0) { - os.getSource().addSourceNodes(f.getSource()); - os.setAssociatedNode(f.getSource().getSourceNodes().get(0)); + if (f.getInputNode() != null) { + os.getSource().addSourceNode(f.getInputNode()); + os.setAssociatedNode(f.getInputNode()); os.setColor(f.getColor()); } @@ -73,9 +73,9 @@ public class SplitFilter extends AbstractFilter { for (OutputSlot os : f.getOutputSlots()) { for (FigureConnection c : os.getConnections()) { InputSlot is = c.getInputSlot(); - if (f.getSource().getSourceNodes().size() > 0) { - is.getSource().addSourceNodes(f.getSource()); - is.setAssociatedNode(f.getSource().getSourceNodes().get(0)); + if (f.getInputNode() != null) { + is.getSource().addSourceNode(f.getInputNode()); + is.setAssociatedNode(f.getInputNode()); is.setColor(f.getColor()); } diff --git a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/WarningFilter.java b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/WarningFilter.java index 9accbe76b66..2dcff037940 100644 --- a/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/WarningFilter.java +++ b/src/utils/IdealGraphVisualizer/Filter/src/main/java/com/sun/hotspot/igv/filter/WarningFilter.java @@ -24,7 +24,9 @@ package com.sun.hotspot.igv.filter; import com.sun.hotspot.igv.data.Properties; -import com.sun.hotspot.igv.graph.*; +import com.sun.hotspot.igv.graph.Diagram; +import com.sun.hotspot.igv.graph.Figure; +import com.sun.hotspot.igv.graph.Selector; import java.util.ArrayList; import java.util.List; diff --git a/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/FilterNode.java b/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/FilterNode.java index 501b6a32b93..b4cccb824ed 100644 --- a/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/FilterNode.java +++ b/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/FilterNode.java @@ -60,13 +60,7 @@ public class FilterNode extends CheckNode implements LookupListener, ChangedList content.add(filter.getEditor()); this.filter = filter; - filter.getChangedEvent().addListener(new ChangedListener() { - - @Override - public void changed(Filter source) { - update(); - } - }); + filter.getChangedEvent().addListener(source -> update()); update(); diff --git a/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/FilterTopComponent.java b/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/FilterTopComponent.java index 174efb5b84b..b2437f9b5b6 100644 --- a/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/FilterTopComponent.java +++ b/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/FilterTopComponent.java @@ -184,13 +184,7 @@ public final class FilterTopComponent extends TopComponent implements LookupList filterSettings.add(setting); // Sort alphabetically - filterSettings.sort(new Comparator() { - - @Override - public int compare(FilterSetting o1, FilterSetting o2) { - return o1.getName().compareTo(o2.getName()); - } - }); + filterSettings.sort(Comparator.comparing(FilterSetting::getName)); updateComboBox(); } @@ -268,13 +262,7 @@ public final class FilterTopComponent extends TopComponent implements LookupList } public FilterChildren() { - sequence.getChangedEvent().addListener(new ChangedListener() { - - @Override - public void changed(FilterChain source) { - addNotify(); - } - }); + sequence.getChangedEvent().addListener(source -> addNotify()); setBefore(false); } @@ -706,13 +694,4 @@ public final class FilterTopComponent extends TopComponent implements LookupList } updateComboBox(); } - - static final class ResolvableHelper implements Serializable { - - private static final long serialVersionUID = 1L; - - public Object readResolve() { - return FilterTopComponent.getDefault(); - } - } } diff --git a/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/actions/FilterAction.java b/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/actions/FilterAction.java index 41561050aa6..e7a7222b93b 100644 --- a/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/actions/FilterAction.java +++ b/src/utils/IdealGraphVisualizer/FilterWindow/src/main/java/com/sun/hotspot/igv/filterwindow/actions/FilterAction.java @@ -8,7 +8,7 @@ * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * diff --git a/src/utils/IdealGraphVisualizer/FilterWindow/src/main/resources/com/sun/hotspot/igv/filterwindow/layer.xml b/src/utils/IdealGraphVisualizer/FilterWindow/src/main/resources/com/sun/hotspot/igv/filterwindow/layer.xml index 319376b4d5b..aabc0e3829c 100644 --- a/src/utils/IdealGraphVisualizer/FilterWindow/src/main/resources/com/sun/hotspot/igv/filterwindow/layer.xml +++ b/src/utils/IdealGraphVisualizer/FilterWindow/src/main/resources/com/sun/hotspot/igv/filterwindow/layer.xml @@ -18,7 +18,7 @@ - + @@ -28,6 +28,7 @@ + diff --git a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/AnySelector.java b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/AnySelector.java index 3def4463aa0..3871722e8ed 100644 --- a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/AnySelector.java +++ b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/AnySelector.java @@ -23,8 +23,8 @@ */ package com.sun.hotspot.igv.graph; -import java.util.List; import java.util.ArrayList; +import java.util.List; // Selects blocks where any node is selected. public class AnySelector implements BlockSelector { @@ -39,7 +39,7 @@ public class AnySelector implements BlockSelector { public List selected(Diagram d) { List l = new ArrayList<>(); for (Figure f : selector.selected(d)) { - l.add(d.getBlock(f.getBlock())); + l.add(f.getBlock()); } return l; } diff --git a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Block.java b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Block.java index 18a08b8992a..483ca9d40f0 100644 --- a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Block.java +++ b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Block.java @@ -23,9 +23,9 @@ */ package com.sun.hotspot.igv.graph; -import java.awt.Dimension; import com.sun.hotspot.igv.data.InputBlock; import com.sun.hotspot.igv.layout.Cluster; +import java.awt.Dimension; import java.awt.Rectangle; import java.util.HashSet; import java.util.Set; @@ -45,10 +45,6 @@ public class Block implements Cluster { this.diagram = diagram; } - public Cluster getOuter() { - return null; - } - public InputBlock getInputBlock() { return inputBlock; } diff --git a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Diagram.java b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Diagram.java index 445eeae8a9f..c23f3829a28 100644 --- a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Diagram.java +++ b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Diagram.java @@ -23,15 +23,9 @@ */ package com.sun.hotspot.igv.graph; -import com.sun.hotspot.igv.data.InputBlock; -import com.sun.hotspot.igv.data.InputBlockEdge; -import com.sun.hotspot.igv.data.InputEdge; -import com.sun.hotspot.igv.data.InputGraph; -import com.sun.hotspot.igv.data.InputNode; +import com.sun.hotspot.igv.data.*; import com.sun.hotspot.igv.data.Properties; -import com.sun.hotspot.igv.data.Properties.StringPropertyMatcher; import java.awt.Font; -import java.awt.Color; import java.util.*; /** @@ -41,32 +35,19 @@ import java.util.*; public class Diagram { private List

figures; - private Map blocks; - private InputGraph graph; - private int curId; - private String nodeText; - private String shortNodeText; - private String tinyNodeText; - private final Font font; - private final Font slotFont; - private final Font boldFont; + private final Map blocks; + private final String nodeText; + private final String shortNodeText; + private final String tinyNodeText; + public static final Font FONT = new Font("Arial", Font.PLAIN, 12); + public static final Font SLOT_FONT = new Font("Arial", Font.PLAIN, 10); + public static final Font BOLD_FONT = FONT.deriveFont(Font.BOLD); + // Whether widgets derived from this diagram should be adapted for the // control-flow graph view. private boolean cfg; private final Set blockConnections; - public Font getFont() { - return font; - } - - public Font getSlotFont() { - return slotFont; - } - - public Font getBoldFont() { - return boldFont; - } - public boolean isCFG() { return cfg; } @@ -75,21 +56,68 @@ public class Diagram { this.cfg = cfg; } - private Diagram(InputGraph graph, String nodeText, String shortNodeText, - String tinyNodeText) { - figures = new ArrayList<>(); - blocks = new LinkedHashMap<>(8); - this.nodeText = ""; - this.shortNodeText = ""; - this.font = new Font("Arial", Font.PLAIN, 12); - this.slotFont = new Font("Arial", Font.PLAIN, 10); - this.boldFont = this.font.deriveFont(Font.BOLD); - this.cfg = false; - this.blockConnections = new HashSet<>(); - this.graph = graph; + public Diagram(InputGraph graph, String nodeText, String shortNodeText, + String tinyNodeText) { + assert graph != null; + this.nodeText = nodeText; this.shortNodeText = shortNodeText; this.tinyNodeText = tinyNodeText; + this.figures = new ArrayList<>(); + this.blocks = new LinkedHashMap<>(8); + this.blockConnections = new HashSet<>(); + this.cfg = false; + int curId = 0; + + for (InputBlock b : graph.getBlocks()) { + blocks.put(b, new Block(b, this)); + } + + Collection nodes = graph.getNodes(); + Hashtable figureHash = new Hashtable<>(); + for (InputNode n : nodes) { + Figure f = new Figure(this, curId, n); + curId++; + f.getProperties().add(n.getProperties()); + f.setBlock(blocks.get(graph.getBlock(n))); + figureHash.put(n.getId(), f); + this.figures.add(f); + } + + for (InputEdge e : graph.getEdges()) { + int from = e.getFrom(); + int to = e.getTo(); + Figure fromFigure = figureHash.get(from); + Figure toFigure = figureHash.get(to); + + if(fromFigure == null || toFigure == null) continue; + + int fromIndex = e.getFromIndex(); + while (fromFigure.getOutputSlots().size() <= fromIndex) { + fromFigure.createOutputSlot(); + } + OutputSlot outputSlot = fromFigure.getOutputSlots().get(fromIndex); + + int toIndex = e.getToIndex(); + while (toFigure.getInputSlots().size() <= toIndex) { + toFigure.createInputSlot(); + } + InputSlot inputSlot = toFigure.getInputSlots().get(toIndex); + + FigureConnection c = createConnection(inputSlot, outputSlot, e.getLabel()); + + if (e.getState() == InputEdge.State.NEW) { + c.setStyle(Connection.ConnectionStyle.BOLD); + } else if (e.getState() == InputEdge.State.DELETED) { + c.setStyle(Connection.ConnectionStyle.DASHED); + } + } + + for (InputBlockEdge e : graph.getBlockEdges()) { + Block p = getBlock(e.getFrom()); + Block s = getBlock(e.getTo()); + blockConnections.add(new BlockConnection(p, s, e.getLabel())); + } } public Block getBlock(InputBlock b) { @@ -113,27 +141,16 @@ public class Diagram { return tinyNodeText; } - public void updateBlocks() { - blocks.clear(); - for (InputBlock b : graph.getBlocks()) { - Block curBlock = new Block(b, this); - blocks.put(b, curBlock); - } - } - public Collection getBlocks() { return Collections.unmodifiableCollection(blocks.values()); } - public List
getFigures() { - return Collections.unmodifiableList(figures); + public Collection getInputBlocks() { + return Collections.unmodifiableCollection(blocks.keySet()); } - public Figure createFigure() { - Figure f = new Figure(this, curId); - curId++; - this.figures.add(f); - return f; + public List
getFigures() { + return Collections.unmodifiableList(figures); } public FigureConnection createConnection(InputSlot inputSlot, OutputSlot outputSlot, String label) { @@ -142,88 +159,11 @@ public class Diagram { return new FigureConnection(inputSlot, outputSlot, label); } - public Map> calcSourceToFigureRelation() { - Map> map = new HashMap<>(); - - for(InputNode node : this.getGraph().getNodes()) { - map.put(node, new HashSet
()); - } - - for(Figure f : this.getFigures()) { - for(InputNode node : f.getSource().getSourceNodes()) { - map.get(node).add(f); - } - } - - return map; - } - - public static Diagram createDiagram(InputGraph graph, String nodeText, - String shortNodeText, - String tinyNodeText) { - if (graph == null) { - return null; - } - - Diagram d = new Diagram(graph, nodeText, shortNodeText, tinyNodeText); - d.updateBlocks(); - - Collection nodes = graph.getNodes(); - Hashtable figureHash = new Hashtable<>(); - for (InputNode n : nodes) { - Figure f = d.createFigure(); - f.getSource().addSourceNode(n); - f.getProperties().add(n.getProperties()); - f.setSubgraphs(n.getSubgraphs()); - f.setBlock(graph.getBlock(n)); - figureHash.put(n.getId(), f); - } - - for (InputEdge e : graph.getEdges()) { - - int from = e.getFrom(); - int to = e.getTo(); - Figure fromFigure = figureHash.get(from); - Figure toFigure = figureHash.get(to); - - if(fromFigure == null || toFigure == null) continue; - assert fromFigure != null && toFigure != null; - - int fromIndex = e.getFromIndex(); - while (fromFigure.getOutputSlots().size() <= fromIndex) { - fromFigure.createOutputSlot(); - } - OutputSlot outputSlot = fromFigure.getOutputSlots().get(fromIndex); - - int toIndex = e.getToIndex(); - while (toFigure.getInputSlots().size() <= toIndex) { - toFigure.createInputSlot(); - } - InputSlot inputSlot = toFigure.getInputSlots().get(toIndex); - - FigureConnection c = d.createConnection(inputSlot, outputSlot, e.getLabel()); - - if (e.getState() == InputEdge.State.NEW) { - c.setStyle(Connection.ConnectionStyle.BOLD); - } else if (e.getState() == InputEdge.State.DELETED) { - c.setStyle(Connection.ConnectionStyle.DASHED); - } - } - - for (InputBlockEdge e : graph.getBlockEdges()) { - Block p = d.getBlock(e.getFrom()); - Block s = d.getBlock(e.getTo()); - d.blockConnections.add(new BlockConnection(p, s, e.getLabel())); - } - - return d; - } - public void removeAllBlocks(Set blocksToRemove) { Set
figuresToRemove = new HashSet<>(); for (Block b : blocksToRemove) { for (Figure f : getFigures()) { - if (f.getBlock() == b.getInputBlock()) { + if (f.getBlock() == b) { figuresToRemove.add(f); } } @@ -273,14 +213,6 @@ public class Diagram { this.figures.remove(succ); } - public String getName() { - return graph.getName(); - } - - public InputGraph getGraph() { - return graph; - } - public Set getConnections() { Set connections = new HashSet<>(); for (Figure f : figures) { @@ -302,24 +234,6 @@ public class Diagram { return connections; } - public Figure getRootFigure() { - Properties.PropertySelector
selector = new Properties.PropertySelector<>(figures); - Figure root = selector.selectSingle(new StringPropertyMatcher("name", "Root")); - if (root == null) { - root = selector.selectSingle(new StringPropertyMatcher("name", "Start")); - } - if (root == null) { - List
rootFigures = getRootFigures(); - if (rootFigures.size() > 0) { - root = rootFigures.get(0); - } else if (figures.size() > 0) { - root = figures.get(0); - } - } - - return root; - } - public void printStatistics() { System.out.println("============================================================="); System.out.println("Diagram statistics"); @@ -354,14 +268,4 @@ public class Diagram { System.out.println("============================================================="); } - - public List
getRootFigures() { - ArrayList
rootFigures = new ArrayList<>(); - for (Figure f : figures) { - if (f.getPredecessors().size() == 0) { - rootFigures.add(f); - } - } - return rootFigures; - } } diff --git a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Figure.java b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Figure.java index b29ff1d4e29..880d3931d46 100644 --- a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Figure.java +++ b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Figure.java @@ -23,18 +23,15 @@ */ package com.sun.hotspot.igv.graph; -import com.sun.hotspot.igv.data.InputBlock; -import com.sun.hotspot.igv.data.InputGraph; import com.sun.hotspot.igv.data.InputNode; import com.sun.hotspot.igv.data.Properties; -import com.sun.hotspot.igv.data.Source; import com.sun.hotspot.igv.layout.Cluster; import com.sun.hotspot.igv.layout.Vertex; import java.awt.*; import java.util.List; import java.util.*; -public class Figure extends Properties.Entity implements Source.Provider, Vertex { +public class Figure extends Properties.Entity implements Vertex { public static final int INSET = 8; public static final int SLOT_WIDTH = 10; @@ -46,20 +43,19 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex public static final int WARNING_WIDTH = 16; protected List inputSlots; protected List outputSlots; - private Source source; - private Diagram diagram; + private final InputNode inputNode; + private final Diagram diagram; private Point position; - private List
predecessors; - private List
successors; - private List subgraphs; + private final List
predecessors; + private final List
successors; private Color color; private String warning; - private int id; - private String idString; + private final int id; + private final String idString; private String[] lines; private int heightCash = -1; private int widthCash = -1; - private InputBlock block; + private Block block; private final FontMetrics metrics; public int getHeight() { @@ -132,20 +128,19 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex widthCash = Math.max(widthCash, Figure.getSlotsWidth(outputSlots)); } - protected Figure(Diagram diagram, int id) { + protected Figure(Diagram diagram, int id, InputNode node) { this.diagram = diagram; - this.source = new Source(); - inputSlots = new ArrayList<>(5); - outputSlots = new ArrayList<>(1); - predecessors = new ArrayList<>(6); - successors = new ArrayList<>(6); + this.inputNode = node; + this.inputSlots = new ArrayList<>(5); + this.outputSlots = new ArrayList<>(1); + this.predecessors = new ArrayList<>(6); + this.successors = new ArrayList<>(6); this.id = id; - idString = Integer.toString(id); - + this.idString = Integer.toString(id); this.position = new Point(0, 0); this.color = Color.WHITE; Canvas canvas = new Canvas(); - metrics = canvas.getFontMetrics(diagram.getFont().deriveFont(Font.BOLD)); + this.metrics = canvas.getFontMetrics(Diagram.FONT.deriveFont(Font.BOLD)); } public int getId() { @@ -172,11 +167,11 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex return diagram.isCFG() && !getPredecessors().isEmpty(); } - public void setBlock(InputBlock block) { + public void setBlock(Block block) { this.block = block; } - public InputBlock getBlock() { + public Block getBlock() { return block; } @@ -185,19 +180,11 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex } public Set
getPredecessorSet() { - Set
result = new HashSet<>(); - for (Figure f : getPredecessors()) { - result.add(f); - } - return Collections.unmodifiableSet(result); + return Collections.unmodifiableSet(new HashSet<>(getPredecessors())); } public Set
getSuccessorSet() { - Set
result = new HashSet<>(); - for (Figure f : getSuccessors()) { - result.add(f); - } - return Collections.unmodifiableSet(result); + return Collections.unmodifiableSet(new HashSet<>(getSuccessors())); } public List
getSuccessors() { @@ -222,14 +209,6 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex successors.remove(f); } - public List getSubgraphs() { - return subgraphs; - } - - public void setSubgraphs(List subgraphs) { - this.subgraphs = subgraphs; - } - @Override public void setPosition(Point p) { this.position = p; @@ -244,9 +223,8 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex return diagram; } - @Override - public Source getSource() { - return source; + public InputNode getInputNode() { + return inputNode; } public InputSlot createInputSlot() { @@ -255,13 +233,6 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex return slot; } - public InputSlot createInputSlot(int index) { - InputSlot slot = new InputSlot(this, index); - inputSlots.add(slot); - inputSlots.sort(Slot.slotIndexComparator); - return slot; - } - public void removeSlot(Slot s) { assert inputSlots.contains(s) || outputSlots.contains(s); @@ -273,15 +244,12 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex if (inputSlots.contains(s)) { inputSlots.remove(s); - } else if (outputSlots.contains(s)) { - outputSlots.remove(s); - } + } else outputSlots.remove(s); } - public OutputSlot createOutputSlot() { + public void createOutputSlot() { OutputSlot slot = new OutputSlot(this, -1); outputSlots.add(slot); - return slot; } public OutputSlot createOutputSlot(int index) { @@ -345,13 +313,13 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex String[] strings = diagram.getNodeText().split("\n"); List result = new ArrayList<>(strings.length + 1); - for (int i = 0; i < strings.length; i++) { - result.add(getProperties().resolveString(strings[i])); + for (String string : strings) { + result.add(getProperties().resolveString(string)); } if (hasInputList()) { String inputList = " ← "; - List inputs = new ArrayList(getPredecessors().size()); + List inputs = new ArrayList<>(getPredecessors().size()); for (Figure p : getPredecessors()) { inputs.add(p.getProperties().resolveString(diagram.getTinyNodeText())); } @@ -366,13 +334,12 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex } lines = result.toArray(new String[0]); - // Set the "label" property of each input node, so that by default + // Set the "label" property of the input node, so that by default // search is done on the node label (without line breaks). See also // class NodeQuickSearch in the View module. - for (InputNode n : getSource().getSourceNodes()) { - String label = n.getProperties().resolveString(diagram.getNodeText()); - n.getProperties().setProperty("label", label.replaceAll("\\R", " ")); - } + String label = inputNode.getProperties().resolveString(diagram.getNodeText()); + inputNode.getProperties().setProperty("label", label.replaceAll("\\R", " ")); + // Update figure dimensions, as these are affected by the node text. updateWidth(); updateHeight(); @@ -390,33 +357,18 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex return idString; } - public InputNode getFirstSourceNode() { - return getSource().getSourceNodes().get(0); - } - public static int getVerticalOffset() { return Figure.SLOT_WIDTH - Figure.OVERLAPPING; } public Cluster getCluster() { - if (getSource().getSourceNodes().size() == 0) { - assert false : "Should never reach here, every figure must have at least one source node!"; - return null; - } else { - final InputBlock inputBlock = diagram.getGraph().getBlock(getFirstSourceNode()); - assert inputBlock != null; - Cluster result = diagram.getBlock(inputBlock); - assert result != null; - return result; - } + return block; } @Override public boolean isRoot() { - - List sourceNodes = source.getSourceNodes(); - if (sourceNodes.size() > 0 && getFirstSourceNode().getProperties().get("name") != null) { - return getFirstSourceNode().getProperties().get("name").equals("Root"); + if (inputNode != null && inputNode.getProperties().get("name") != null) { + return inputNode.getProperties().get("name").equals("Root"); } else { return false; } @@ -426,8 +378,4 @@ public class Figure extends Properties.Entity implements Source.Provider, Vertex public int compareTo(Vertex f) { return toString().compareTo(f.toString()); } - - public Rectangle getBounds() { - return new Rectangle(this.getPosition(), new Dimension(this.getWidth(), this.getHeight())); - } } diff --git a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/FigureConnection.java b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/FigureConnection.java index a38ca07e1bb..ebdee9229e8 100644 --- a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/FigureConnection.java +++ b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/FigureConnection.java @@ -23,8 +23,8 @@ */ package com.sun.hotspot.igv.graph; -import com.sun.hotspot.igv.layout.Port; import com.sun.hotspot.igv.layout.Cluster; +import com.sun.hotspot.igv.layout.Port; import java.awt.Color; import java.awt.Point; import java.util.ArrayList; diff --git a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Slot.java b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Slot.java index bce5266e83d..f5c0b2c2ff4 100644 --- a/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Slot.java +++ b/src/utils/IdealGraphVisualizer/Graph/src/main/java/com/sun/hotspot/igv/graph/Slot.java @@ -78,24 +78,7 @@ public abstract class Slot implements Port, Source.Provider, Properties.Provider } return p; } - public static final Comparator slotIndexComparator = new Comparator() { - - @Override - public int compare(Slot o1, Slot o2) { - return o1.wantedIndex - o2.wantedIndex; - } - }; - public static final Comparator slotFigureComparator = new Comparator() { - - @Override - public int compare(Slot o1, Slot o2) { - return o1.figure.getId() - o2.figure.getId(); - } - }; - - public InputNode getAssociatedNode() { - return associatedNode; - } + public static final Comparator slotIndexComparator = Comparator.comparingInt(o -> o.wantedIndex); public void setAssociatedNode(InputNode node) { associatedNode = node; @@ -107,7 +90,7 @@ public abstract class Slot implements Port, Source.Provider, Properties.Provider } else { BufferedImage image = new BufferedImage(1, 1, BufferedImage.TYPE_INT_RGB); Graphics g = image.getGraphics(); - g.setFont(figure.getDiagram().getSlotFont().deriveFont(Font.BOLD)); + g.setFont(Diagram.SLOT_FONT.deriveFont(Font.BOLD)); FontMetrics metrics = g.getFontMetrics(); return Math.max(Figure.SLOT_WIDTH, metrics.stringWidth(shortName) + 6); } diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterEdge.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterEdge.java index b243b88d194..a7266ebd5fa 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterEdge.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterEdge.java @@ -23,9 +23,9 @@ */ package com.sun.hotspot.igv.hierarchicallayout; +import com.sun.hotspot.igv.layout.Cluster; import com.sun.hotspot.igv.layout.Link; import com.sun.hotspot.igv.layout.Port; -import com.sun.hotspot.igv.layout.Cluster; import java.awt.Point; import java.util.List; @@ -35,8 +35,8 @@ import java.util.List; */ public class ClusterEdge implements Link { - private ClusterNode from; - private ClusterNode to; + private final ClusterNode from; + private final ClusterNode to; private List points; public ClusterEdge(ClusterNode from, ClusterNode to) { diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterIngoingConnection.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterIngoingConnection.java index db8b4c7257c..4d97b06d3c3 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterIngoingConnection.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterIngoingConnection.java @@ -23,9 +23,9 @@ */ package com.sun.hotspot.igv.hierarchicallayout; +import com.sun.hotspot.igv.layout.Cluster; import com.sun.hotspot.igv.layout.Link; import com.sun.hotspot.igv.layout.Port; -import com.sun.hotspot.igv.layout.Cluster; import java.awt.Point; import java.util.ArrayList; import java.util.List; @@ -37,28 +37,16 @@ import java.util.List; public class ClusterIngoingConnection implements Link { private List controlPoints; - private ClusterInputSlotNode inputSlotNode; - private Link connection; - private Port inputSlot; - private Port outputSlot; + private final Port inputSlot; + private final Port outputSlot; public ClusterIngoingConnection(ClusterInputSlotNode inputSlotNode, Link c) { - this.inputSlotNode = inputSlotNode; - this.connection = c; - this.controlPoints = new ArrayList(); + this.controlPoints = new ArrayList<>(); inputSlot = c.getTo(); outputSlot = inputSlotNode.getOutputSlot(); } - public Link getConnection() { - return connection; - } - - public ClusterInputSlotNode getInputSlotNode() { - return inputSlotNode; - } - public Port getTo() { return inputSlot; } diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterInputSlotNode.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterInputSlotNode.java index c398a6e3d74..22c5abda75c 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterInputSlotNode.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterInputSlotNode.java @@ -35,23 +35,12 @@ import java.awt.Point; */ public class ClusterInputSlotNode implements Vertex { - private final int SIZE = 0; private Point position; - private Port inputSlot; - private Port outputSlot; - private ClusterNode blockNode; - private InterClusterConnection interBlockConnection; - private Cluster cluster; - private ClusterIngoingConnection conn; + private final Port inputSlot; + private final Port outputSlot; + private final ClusterNode blockNode; - public void setIngoingConnection(ClusterIngoingConnection c) { - conn = c; - } - - public ClusterIngoingConnection getIngoingConnection() { - return conn; - } - private String id; + private final String id; @Override public String toString() { @@ -79,7 +68,7 @@ public class ClusterInputSlotNode implements Vertex { @Override public String toString() { - return "OutPort of " + thisNode.toString(); + return "OutPort of " + thisNode; } }; @@ -98,7 +87,7 @@ public class ClusterInputSlotNode implements Vertex { @Override public String toString() { - return "InPort of " + thisNode.toString(); + return "InPort of " + thisNode; } }; } @@ -107,16 +96,12 @@ public class ClusterInputSlotNode implements Vertex { return inputSlot; } - public InterClusterConnection getInterBlockConnection() { - return interBlockConnection; - } - public Port getOutputSlot() { return outputSlot; } public Dimension getSize() { - return new Dimension(SIZE, SIZE); + return new Dimension(0, 0); } public void setPosition(Point p) { @@ -127,12 +112,8 @@ public class ClusterInputSlotNode implements Vertex { return position; } - public void setInterBlockConnection(InterClusterConnection interBlockConnection) { - this.interBlockConnection = interBlockConnection; - } - public Cluster getCluster() { - return cluster; + return null; } public boolean isRoot() { diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterNode.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterNode.java index 0a6631c72f3..80151e69d06 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterNode.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterNode.java @@ -29,11 +29,7 @@ import com.sun.hotspot.igv.layout.Port; import com.sun.hotspot.igv.layout.Vertex; import java.awt.Dimension; import java.awt.Point; -import java.util.ArrayList; -import java.util.Collections; -import java.util.HashSet; -import java.util.List; -import java.util.Set; +import java.util.*; /** * @@ -43,14 +39,12 @@ public class ClusterNode implements Vertex { private Cluster cluster; private Port inputSlot; - private Port outputSlot; - private Set subNodes; + private final Set subNodes; private Dimension size; private Point position; - private Set subEdges; - private boolean dirty; + private final Set subEdges; private boolean root; - private String name; + private final String name; private final int border; private final Dimension nodeOffset; private final int headerVerticalSpace; @@ -59,10 +53,10 @@ public class ClusterNode implements Vertex { public ClusterNode(Cluster cluster, String name, int border, Dimension nodeOffset, int headerVerticalSpace, Dimension emptySize) { - this.subNodes = new HashSet(); - this.subEdges = new HashSet(); + this.subNodes = new HashSet<>(); + this.subEdges = new HashSet<>(); this.cluster = cluster; - position = new Point(0, 0); + this.position = new Point(0, 0); this.name = name; this.border = border; this.nodeOffset = nodeOffset; @@ -94,8 +88,6 @@ public class ClusterNode implements Vertex { } public void updateSize() { - - calculateSize(); final ClusterNode widget = this; @@ -114,22 +106,6 @@ public class ClusterNode implements Vertex { return "ClusterInput(" + name + ")"; } }; - - outputSlot = new Port() { - - public Point getRelativePosition() { - return new Point(size.width / 2, 0);//size.height); - } - - public Vertex getVertex() { - return widget; - } - - @Override - public String toString() { - return "ClusterOutput(" + name + ")"; - } - }; } private void calculateSize() { @@ -174,7 +150,7 @@ public class ClusterNode implements Vertex { } for (Link l : subEdges) { - List points = new ArrayList(l.getControlPoints()); + List points = new ArrayList<>(l.getControlPoints()); for (Point p : points) { p.x -= minX; p.y -= minY; @@ -192,10 +168,6 @@ public class ClusterNode implements Vertex { } - public Port getOutputSlot() { - return outputSlot; - } - public Dimension getSize() { return size; } @@ -215,7 +187,7 @@ public class ClusterNode implements Vertex { for (Link e : subEdges) { List arr = e.getControlPoints(); - ArrayList newArr = new ArrayList(arr.size()); + ArrayList newArr = new ArrayList<>(arr.size()); for (Point p : arr) { if (p != null) { Point p2 = new Point(p); @@ -238,10 +210,6 @@ public class ClusterNode implements Vertex { cluster = c; } - public void setDirty(boolean b) { - dirty = b; - } - public void setRoot(boolean b) { root = b; } diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterOutgoingConnection.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterOutgoingConnection.java index 9848bb58618..b63ef4bb1ee 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterOutgoingConnection.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterOutgoingConnection.java @@ -23,9 +23,9 @@ */ package com.sun.hotspot.igv.hierarchicallayout; +import com.sun.hotspot.igv.layout.Cluster; import com.sun.hotspot.igv.layout.Link; import com.sun.hotspot.igv.layout.Port; -import com.sun.hotspot.igv.layout.Cluster; import java.awt.Point; import java.util.ArrayList; import java.util.List; @@ -37,18 +37,13 @@ import java.util.List; public class ClusterOutgoingConnection implements Link { private List intermediatePoints; - private ClusterOutputSlotNode outputSlotNode; - private Link connection; - private Port inputSlot; - private Port outputSlot; + private final Port inputSlot; + private final Port outputSlot; public ClusterOutgoingConnection(ClusterOutputSlotNode outputSlotNode, Link c) { - this.outputSlotNode = outputSlotNode; - this.connection = c; - this.intermediatePoints = new ArrayList(); - - outputSlot = c.getFrom(); - inputSlot = outputSlotNode.getInputSlot(); + this.intermediatePoints = new ArrayList<>(); + this.outputSlot = c.getFrom(); + this.inputSlot = outputSlotNode.getInputSlot(); } public Port getTo() { diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterOutputSlotNode.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterOutputSlotNode.java index 52a334ec4f3..2073efc9fcf 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterOutputSlotNode.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/ClusterOutputSlotNode.java @@ -35,15 +35,13 @@ import java.awt.Point; */ public class ClusterOutputSlotNode implements Vertex { - private final int SIZE = 0; private Point position; - private Port inputSlot; - private Port outputSlot; - private ClusterNode blockNode; - private boolean root; + private final Port inputSlot; + private final Port outputSlot; + private final ClusterNode blockNode; private Cluster cluster; private ClusterOutgoingConnection conn; - private String id; + private final String id; public void setOutgoingConnection(ClusterOutgoingConnection c) { this.conn = c; @@ -79,7 +77,7 @@ public class ClusterOutputSlotNode implements Vertex { @Override public String toString() { - return "InPort of " + thisNode.toString(); + return "InPort of " + thisNode; } }; @@ -88,7 +86,7 @@ public class ClusterOutputSlotNode implements Vertex { public Point getRelativePosition() { Point p = new Point(thisNode.getPosition()); p.x += blockNode.getBorder(); - p.y = 0;//thisBlockNode.getSize().height; + p.y = 0; return p; } @@ -98,13 +96,13 @@ public class ClusterOutputSlotNode implements Vertex { @Override public String toString() { - return "OutPort of " + thisNode.toString(); + return "OutPort of " + thisNode; } }; } public Dimension getSize() { - return new Dimension(SIZE, SIZE); + return new Dimension(0, 0); } public void setPosition(Point p) { @@ -127,16 +125,12 @@ public class ClusterOutputSlotNode implements Vertex { cluster = c; } - public void setRoot(boolean b) { - root = b; - } - public Cluster getCluster() { return cluster; } public boolean isRoot() { - return root; + return false; } public int compareTo(Vertex o) { diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Edge.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Edge.java deleted file mode 100644 index 6f990b545a6..00000000000 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Edge.java +++ /dev/null @@ -1,90 +0,0 @@ -/* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ -package com.sun.hotspot.igv.hierarchicallayout; - -/** - * - * @author Thomas Wuerthinger - */ -public class Edge { - - private E data; - private Node source; - private Node dest; - - protected Edge(Graph graph, Node source, Node dest, E data) { - setData(data); - this.source = source; - this.dest = dest; - assert source != null; - assert dest != null; - assert source.getGraph() == dest.getGraph(); - assert source.getGraph() != null; - assert dest.getGraph() != null; - } - - public Node getSource() { - return source; - } - - public Node getDest() { - return dest; - } - - public E getData() { - return data; - } - - public void setData(E e) { - data = e; - } - - public void remove() { - source.getGraph().removeEdge(this, null); - } - - public boolean isSelfLoop() { - return source == dest; - } - - public void reverse() { - - // Remove from current source / dest - source.removeOutEdge(this); - dest.removeInEdge(this); - - Node tmp = source; - source = dest; - dest = tmp; - - // Add to new source / dest - source.addOutEdge(this); - dest.addInEdge(this); - } - - @Override - public String toString() { - return "Edge (" + source + " -- " + dest + "): " + data; - } -} diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Graph.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Graph.java deleted file mode 100644 index e19d3ebf5b8..00000000000 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Graph.java +++ /dev/null @@ -1,292 +0,0 @@ -/* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ -package com.sun.hotspot.igv.hierarchicallayout; - -import java.util.*; - -/** - * - * @author Thomas Wuerthinger - */ -public class Graph { - - private HashMap> nodes; - private HashMap> edges; - private List> nodeList; - - public Graph() { - nodes = new HashMap<>(); - edges = new HashMap<>(); - nodeList = new ArrayList<>(); - } - - public Node createNode(N data, Object key) { - Node n = new Node<>(this, data); - assert key == null || !nodes.containsKey(key); - if (key != null) { - nodes.put(key, n); - } - nodeList.add(n); - return n; - } - - public Edge createEdge(Node source, Node dest, E data, Object key) { - Edge e = new Edge<>(this, source, dest, data); - source.addOutEdge(e); - dest.addInEdge(e); - if (key != null) { - edges.put(key, e); - } - return e; - } - - public Node getNode(Object key) { - return nodes.get(key); - } - - public Edge getEdge(Object key) { - return edges.get(key); - } - - public Collection> getEdges() { - return Collections.unmodifiableCollection(edges.values()); - } - - public Collection> getNodes() { - return Collections.unmodifiableList(nodeList); - } - - public void removeEdge(Edge e, Object key) { - assert key == null || edges.containsKey(key); - if (key != null) { - edges.remove(key); - } - e.getSource().removeOutEdge(e); - e.getDest().removeInEdge(e); - } - - public class DFSTraversalVisitor { - - public void visitNode(Node n) { - } - - public boolean visitEdge(Edge e, boolean backEdge) { - return true; - } - } - - public class BFSTraversalVisitor { - - public void visitNode(Node n, int depth) { - } - } - - public List> getNodesWithInDegree(int x) { - return getNodesWithInDegree(x, true); - } - - public List> getNodesWithInDegree(int x, boolean countSelfLoops) { - - List> result = new ArrayList<>(); - for (Node n : getNodes()) { - if (n.getInDegree(countSelfLoops) == x) { - result.add(n); - } - } - - return result; - - } - - private void markReachable(Node startingNode) { - ArrayList> arr = new ArrayList<>(); - arr.add(startingNode); - for (Node n : getNodes()) { - n.setReachable(false); - } - traverseDFS(arr, new DFSTraversalVisitor() { - - @Override - public void visitNode(Node n) { - n.setReachable(true); - } - }); - } - - public void traverseBFS(Node startingNode, BFSTraversalVisitor tv, boolean longestPath) { - - if (longestPath) { - markReachable(startingNode); - } - - for (Node n : getNodes()) { - n.setVisited(false); - n.setActive(false); - } - - Queue> queue = new LinkedList<>(); - queue.add(startingNode); - startingNode.setVisited(true); - int layer = 0; - Node lastOfLayer = startingNode; - Node lastAdded = null; - - while (!queue.isEmpty()) { - - Node current = queue.poll(); - tv.visitNode(current, layer); - current.setActive(false); - - - for (Edge e : current.getOutEdges()) { - if (!e.getDest().isVisited()) { - - boolean allow = true; - if (longestPath) { - for (Node pred : e.getDest().getPredecessors()) { - if ((!pred.isVisited() || pred.isActive()) && pred.isReachable()) { - allow = false; - break; - } - } - } - - if (allow) { - queue.offer(e.getDest()); - lastAdded = e.getDest(); - e.getDest().setVisited(true); - e.getDest().setActive(true); - } - } - } - - if (current == lastOfLayer && !queue.isEmpty()) { - lastOfLayer = lastAdded; - layer++; - } - } - } - - public void traverseDFS(DFSTraversalVisitor tv) { - traverseDFS(getNodes(), tv); - } - - public void traverseDFS(Collection> startingNodes, DFSTraversalVisitor tv) { - - for (Node n : getNodes()) { - n.setVisited(false); - n.setActive(false); - } - - boolean result = false; - for (Node n : startingNodes) { - traverse(tv, n); - } - } - - private void traverse(DFSTraversalVisitor tv, Node n) { - - if (!n.isVisited()) { - n.setVisited(true); - n.setActive(true); - tv.visitNode(n); - - for (Edge e : n.getOutEdges()) { - - Node next = e.getDest(); - if (next.isActive()) { - tv.visitEdge(e, true); - } else { - if (tv.visitEdge(e, false)) { - traverse(tv, next); - } - } - } - - n.setActive(false); - } - - } - - public boolean hasCycles() { - - for (Node n : getNodes()) { - n.setVisited(false); - n.setActive(false); - } - - boolean result = false; - for (Node n : getNodes()) { - result |= checkCycles(n); - if (result) { - break; - } - } - return result; - } - - private boolean checkCycles(Node n) { - - if (n.isActive()) { - return true; - } - - if (!n.isVisited()) { - - n.setVisited(true); - n.setActive(true); - - for (Node succ : n.getSuccessors()) { - if (checkCycles(succ)) { - return true; - } - } - - n.setActive(false); - - } - - return false; - } - - @Override - public String toString() { - - StringBuilder s = new StringBuilder(); - s.append("Nodes: "); - for (Node n : getNodes()) { - s.append(n.toString()); - s.append("\n"); - } - - s.append("Edges: "); - - for (Edge e : getEdges()) { - s.append(e.toString()); - s.append("\n"); - } - - return s.toString(); - } -} diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalCFGLayoutManager.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalCFGLayoutManager.java index 58322aa171f..c712c2f935e 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalCFGLayoutManager.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalCFGLayoutManager.java @@ -23,22 +23,15 @@ */ package com.sun.hotspot.igv.hierarchicallayout; -import java.awt.Dimension; -import java.awt.Rectangle; -import java.awt.Canvas; -import java.awt.Font; -import java.awt.FontMetrics; -import java.util.*; -import com.sun.hotspot.igv.layout.Cluster; -import com.sun.hotspot.igv.layout.LayoutGraph; import com.sun.hotspot.igv.layout.LayoutManager; -import com.sun.hotspot.igv.layout.Link; -import com.sun.hotspot.igv.layout.Vertex; +import com.sun.hotspot.igv.layout.*; +import java.awt.*; +import java.util.*; public class HierarchicalCFGLayoutManager implements LayoutManager { private static final int BLOCK_BORDER = 5; - private FontMetrics fontMetrics; + private final FontMetrics fontMetrics; // Lays out nodes within a single cluster (basic block). private LayoutManager subManager; // Lays out clusters in the CFG. @@ -78,13 +71,12 @@ public class HierarchicalCFGLayoutManager implements LayoutManager { // Compute layout for each cluster. for (Cluster c : clusters) { ClusterNode n = clusterNode.get(c); - subManager.doLayout(new LayoutGraph(n.getSubEdges(), n.getSubNodes()), new HashSet()); + subManager.doLayout(new LayoutGraph(n.getSubEdges(), n.getSubNodes()), new HashSet<>()); n.updateSize(); } // Compute inter-cluster layout. - manager.doLayout(new LayoutGraph(clusterEdges, new HashSet<>(clusterNode.values())), - new HashSet()); + manager.doLayout(new LayoutGraph(clusterEdges, new HashSet<>(clusterNode.values())), new HashSet<>()); // Write back results. writeBackClusterBounds(clusterNode); @@ -144,11 +136,11 @@ public class HierarchicalCFGLayoutManager implements LayoutManager { // Map from "primitive" cluster edges to their input links. Map, Link> inputLink = new HashMap<>(); for (Link l : graph.getLinks()) { - inputLink.put(new AbstractMap.SimpleEntry(l.getFromCluster(), l.getToCluster()), l); + inputLink.put(new AbstractMap.SimpleEntry<>(l.getFromCluster(), l.getToCluster()), l); } for (ClusterEdge ce : clusterEdges) { assert (ce.getControlPoints() != null); - Link l = inputLink.get(new AbstractMap.SimpleEntry(ce.getFromCluster(), ce.getToCluster())); + Link l = inputLink.get(new AbstractMap.SimpleEntry<>(ce.getFromCluster(), ce.getToCluster())); l.setControlPoints(ce.getControlPoints()); } } diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalClusterLayoutManager.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalClusterLayoutManager.java index 5adb982659d..badfb0e036a 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalClusterLayoutManager.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalClusterLayoutManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,20 +23,10 @@ */ package com.sun.hotspot.igv.hierarchicallayout; +import com.sun.hotspot.igv.layout.*; import java.awt.Point; import java.awt.Rectangle; -import java.util.HashMap; -import java.util.List; -import java.util.Set; -import java.util.ArrayList; -import java.util.HashSet; -import java.util.TreeSet; -import com.sun.hotspot.igv.layout.Cluster; -import com.sun.hotspot.igv.layout.LayoutGraph; -import com.sun.hotspot.igv.layout.LayoutManager; -import com.sun.hotspot.igv.layout.Link; -import com.sun.hotspot.igv.layout.Port; -import com.sun.hotspot.igv.layout.Vertex; +import java.util.*; /** * @@ -53,10 +43,6 @@ public class HierarchicalClusterLayoutManager implements LayoutManager { this.combine = combine; } - public void doLayout(LayoutGraph graph) { - doLayout(graph, new HashSet(), new HashSet(), new HashSet()); - } - public void doLayout(LayoutGraph graph, Set importantLinks) { doLayout(graph); } @@ -69,34 +55,32 @@ public class HierarchicalClusterLayoutManager implements LayoutManager { this.manager = manager; } - public void doLayout(LayoutGraph graph, Set firstLayerHint, Set lastLayerHint, Set importantLinks) { + public void doLayout(LayoutGraph graph) { assert graph.verify(); - HashMap> lists = new HashMap>(); - HashMap> listsConnection = new HashMap>(); - HashMap> clusterInputSlotHash = new HashMap>(); - HashMap> clusterOutputSlotHash = new HashMap>(); + HashMap> listsConnection = new HashMap<>(); + HashMap> clusterInputSlotHash = new HashMap<>(); + HashMap> clusterOutputSlotHash = new HashMap<>(); - HashMap clusterNodes = new HashMap(); - HashMap> clusterInputSlotSet = new HashMap>(); - HashMap> clusterOutputSlotSet = new HashMap>(); - Set clusterEdges = new HashSet(); - Set interClusterEdges = new HashSet(); - HashMap linkClusterOutgoingConnection = new HashMap(); - HashMap linkInterClusterConnection = new HashMap(); - HashMap linkClusterIngoingConnection = new HashMap(); - Set clusterNodeSet = new HashSet(); + HashMap clusterNodes = new HashMap<>(); + HashMap> clusterInputSlotSet = new HashMap<>(); + HashMap> clusterOutputSlotSet = new HashMap<>(); + Set clusterEdges = new HashSet<>(); + Set interClusterEdges = new HashSet<>(); + HashMap linkClusterOutgoingConnection = new HashMap<>(); + HashMap linkInterClusterConnection = new HashMap<>(); + HashMap linkClusterIngoingConnection = new HashMap<>(); + Set clusterNodeSet = new HashSet<>(); Set cluster = graph.getClusters(); int z = 0; for (Cluster c : cluster) { - lists.put(c, new ArrayList()); - listsConnection.put(c, new ArrayList()); - clusterInputSlotHash.put(c, new HashMap()); - clusterOutputSlotHash.put(c, new HashMap()); - clusterOutputSlotSet.put(c, new TreeSet()); - clusterInputSlotSet.put(c, new TreeSet()); + listsConnection.put(c, new ArrayList<>()); + clusterInputSlotHash.put(c, new HashMap<>()); + clusterOutputSlotHash.put(c, new HashMap<>()); + clusterOutputSlotSet.put(c, new TreeSet<>()); + clusterInputSlotSet.put(c, new TreeSet<>()); ClusterNode cn = new ClusterNode(c, "" + z); clusterNodes.put(c, cn); clusterNodeSet.add(cn); @@ -156,7 +140,7 @@ public class HierarchicalClusterLayoutManager implements LayoutManager { } if (outputSlotNode == null) { - outputSlotNode = new ClusterOutputSlotNode(clusterNodes.get(fromCluster), "Out " + fromCluster.toString() + " " + samePort.toString()); + outputSlotNode = new ClusterOutputSlotNode(clusterNodes.get(fromCluster), "Out " + fromCluster.toString() + " " + samePort); clusterOutputSlotSet.get(fromCluster).add(outputSlotNode); ClusterOutgoingConnection conn = new ClusterOutgoingConnection(outputSlotNode, l); outputSlotNode.setOutgoingConnection(conn); @@ -171,16 +155,13 @@ public class HierarchicalClusterLayoutManager implements LayoutManager { } if (inputSlotNode == null) { - inputSlotNode = new ClusterInputSlotNode(clusterNodes.get(toCluster), "In " + toCluster.toString() + " " + samePort.toString()); + inputSlotNode = new ClusterInputSlotNode(clusterNodes.get(toCluster), "In " + toCluster.toString() + " " + samePort); clusterInputSlotSet.get(toCluster).add(inputSlotNode); } ClusterIngoingConnection conn = new ClusterIngoingConnection(inputSlotNode, l); - inputSlotNode.setIngoingConnection(conn); clusterNodes.get(toCluster).addSubEdge(conn); - if (samePort != null) { - clusterInputSlotHash.get(toCluster).put(samePort, inputSlotNode); - } + clusterInputSlotHash.get(toCluster).put(samePort, inputSlotNode); linkClusterIngoingConnection.put(l, conn); @@ -194,13 +175,13 @@ public class HierarchicalClusterLayoutManager implements LayoutManager { Timing t = null; if (TRACE) { - new Timing("Child timing"); + t = new Timing("Child timing"); t.start(); } for (Cluster c : cluster) { ClusterNode n = clusterNodes.get(c); - subManager.doLayout(new LayoutGraph(n.getSubEdges(), n.getSubNodes()), new HashSet()); + subManager.doLayout(new LayoutGraph(n.getSubEdges(), n.getSubNodes()), new HashSet<>()); n.updateSize(); } @@ -235,7 +216,7 @@ public class HierarchicalClusterLayoutManager implements LayoutManager { assert conn2 != null; assert conn3 != null; - List points = new ArrayList(); + List points = new ArrayList<>(); points.addAll(conn1.getControlPoints()); points.addAll(conn2.getControlPoints()); diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalLayoutManager.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalLayoutManager.java index d76b681eed5..4bb99cf9cae 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalLayoutManager.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/HierarchicalLayoutManager.java @@ -56,9 +56,9 @@ public class HierarchicalLayoutManager implements LayoutManager { SAME_OUTPUTS } // Options - private Combine combine; - private int dummyWidth; - private int dummyHeight; + private final Combine combine; + private final int dummyWidth; + private final int dummyHeight; private int xOffset; private int layerOffset; private int maxLayerLength; @@ -71,14 +71,13 @@ public class HierarchicalLayoutManager implements LayoutManager { private HashMap vertexToLayoutNode; private HashMap> reversedLinkStartPoints; private HashMap> reversedLinkEndPoints; - private HashMap bottomEdgeHash; private HashMap> splitStartPoints; private HashMap> splitEndPoints; private LayoutGraph graph; private List[] layers; private int layerCount; private Set importantLinks; - private Set linksToFollow; + private final Set linksToFollow; private class LayoutNode { @@ -123,7 +122,7 @@ public class HierarchicalLayoutManager implements LayoutManager { } } - private abstract class AlgorithmPart { + private abstract static class AlgorithmPart { public void start() { if (CHECK) { @@ -159,10 +158,6 @@ public class HierarchicalLayoutManager implements LayoutManager { } } - public HierarchicalLayoutManager() { - this(Combine.NONE); - } - public HierarchicalLayoutManager(Combine b) { this.combine = b; this.dummyWidth = DUMMY_WIDTH; @@ -183,10 +178,6 @@ public class HierarchicalLayoutManager implements LayoutManager { this.layerOffset = layerOffset; } - public int getMaxLayerLength() { - return maxLayerLength; - } - public void setMaxLayerLength(int v) { maxLayerLength = v; } @@ -216,7 +207,7 @@ public class HierarchicalLayoutManager implements LayoutManager { @Override public void doLayout(LayoutGraph graph) { - doLayout(graph, new HashSet()); + doLayout(graph, new HashSet<>()); } @@ -231,7 +222,6 @@ public class HierarchicalLayoutManager implements LayoutManager { selfEdges = new HashSet<>(); reversedLinkStartPoints = new HashMap<>(); reversedLinkEndPoints = new HashMap<>(); - bottomEdgeHash = new HashMap<>(); nodes = new ArrayList<>(); splitStartPoints = new HashMap<>(); splitEndPoints = new HashMap<>(); @@ -452,7 +442,6 @@ public class HierarchicalLayoutManager implements LayoutManager { points.add(null); points.addAll(splitEndPoints.get(e.link)); - //checkPoints(points); if (reversedLinks.contains(e.link)) { Collections.reverse(points); } @@ -476,7 +465,6 @@ public class HierarchicalLayoutManager implements LayoutManager { if (reversedLinks.contains(e.link)) { Collections.reverse(points); } - //checkPoints(points); assert !linkPositions.containsKey(e.link); linkPositions.put(e.link, points); } @@ -538,105 +526,60 @@ public class HierarchicalLayoutManager implements LayoutManager { } } - private static class Segment { - - public float d; - public int orderNumber = -1; - public ArrayList nodes = new ArrayList<>(); - public HashSet succs = new HashSet<>(); - public HashSet preds = new HashSet<>(); - public Region region; - } - private static final Comparator segmentComparator = new Comparator() { - - @Override - public int compare(Segment s1, Segment s2) { - return s1.orderNumber - s2.orderNumber; + private static final Comparator nodePositionComparator = Comparator.comparingInt(n -> n.pos); + private static final Comparator nodeProcessingDownComparator = (n1, n2) -> { + int n1VIP = 0; + for (LayoutEdge e : n1.preds) { + if (e.vip) { + n1VIP++; + } } - }; - - private static class Region { - - public float d; - public int minOrderNumber; - public SortedSet segments = new TreeSet<>(segmentComparator); - public HashSet succs = new HashSet<>(4); - public HashSet preds = new HashSet<>(4); - } - private static final Comparator regionComparator = new Comparator() { - - @Override - public int compare(Region r1, Region r2) { - return r1.minOrderNumber - r2.minOrderNumber; + int n2VIP = 0; + for (LayoutEdge e : n2.preds) { + if (e.vip) { + n2VIP++; + } } - }; - private static final Comparator nodePositionComparator = new Comparator() { - - @Override - public int compare(LayoutNode n1, LayoutNode n2) { - return n1.pos - n2.pos; + if (n1VIP != n2VIP) { + return n2VIP - n1VIP; } - }; - private static final Comparator nodeProcessingDownComparator = new Comparator() { - @Override - public int compare(LayoutNode n1, LayoutNode n2) { - int n1VIP = 0; - for (LayoutEdge e : n1.preds) { - if (e.vip) { - n1VIP++; - } - } - int n2VIP = 0; - for (LayoutEdge e : n2.preds) { - if (e.vip) { - n2VIP++; - } - } - if (n1VIP != n2VIP) { - return n2VIP - n1VIP; - } - if (n1.vertex == null) { - if (n2.vertex == null) { - return 0; - } - return -1; - } + if (n1.vertex == null) { if (n2.vertex == null) { - return 1; + return 0; } - return n1.preds.size() - n2.preds.size(); + return -1; } + if (n2.vertex == null) { + return 1; + } + return n1.preds.size() - n2.preds.size(); }; - private static final Comparator nodeProcessingUpComparator = new Comparator() { - - @Override - public int compare(LayoutNode n1, LayoutNode n2) { - int n1VIP = 0; - for (LayoutEdge e : n1.succs) { - if (e.vip) { - n1VIP++; - } + private static final Comparator nodeProcessingUpComparator = (n1, n2) -> { + int n1VIP = 0; + for (LayoutEdge e : n1.succs) { + if (e.vip) { + n1VIP++; } - int n2VIP = 0; - for (LayoutEdge e : n2.succs) { - if (e.vip) { - n2VIP++; - } - } - if (n1VIP != n2VIP) { - return n2VIP - n1VIP; - } - if (n1.vertex == null) { - if (n2.vertex == null) { - return 0; - } - return -1; - } - if (n2.vertex == null) { - return 1; - } - return n1.succs.size() - n2.succs.size(); } + int n2VIP = 0; + for (LayoutEdge e : n2.succs) { + if (e.vip) { + n2VIP++; + } + } + if (n1VIP != n2VIP) { + return n2VIP - n1VIP; + } + if (n1.vertex == null) { + if (n2.vertex == null) { + return 0; + } + return -1; + } + if (n2.vertex == null) { + return 1; + } + return n1.succs.size() - n2.succs.size(); }; private class AssignXCoordinates extends AlgorithmPart { @@ -683,22 +626,19 @@ public class HierarchicalLayoutManager implements LayoutManager { for (int i = 0; i < SWEEP_ITERATIONS; i++) { sweepDown(); adjustSpace(); - sweepUp(false); + sweepUp(); adjustSpace(); } sweepDown(); adjustSpace(); - sweepUp(true); + sweepUp(); } private void adjustSpace() { for (int i = 0; i < layers.length; i++) { - // space[i] = new ArrayList<>(); - int curX = 0; for (LayoutNode n : layers[i]) { space[i].add(n.x); -// curX += n.width + xOffset; } } } @@ -781,7 +721,7 @@ public class HierarchicalLayoutManager implements LayoutManager { } } - private void sweepUp(boolean onlyDummies) { + private void sweepUp() { for (int i = layers.length - 1; i >= 0; i--) { NodeRow r = new NodeRow(space[i]); for (LayoutNode n : upProcessingOrder[i]) { @@ -791,16 +731,6 @@ public class HierarchicalLayoutManager implements LayoutManager { } } - private void doubleSweep() { - for (int i = layers.length - 2; i >= 0; i--) { - NodeRow r = new NodeRow(space[i]); - for (LayoutNode n : upProcessingOrder[i]) { - int optimal = calculateOptimalBoth(n); - r.insert(n, optimal); - } - } - } - private void sweepDown() { for (int i = 1; i < layers.length; i++) { NodeRow r = new NodeRow(space[i]); @@ -814,8 +744,8 @@ public class HierarchicalLayoutManager implements LayoutManager { private static class NodeRow { - private TreeSet treeSet; - private ArrayList space; + private final TreeSet treeSet; + private final ArrayList space; public NodeRow(ArrayList space) { treeSet = new TreeSet<>(nodePositionComparator); @@ -832,7 +762,7 @@ public class HierarchicalLayoutManager implements LayoutManager { SortedSet headSet = treeSet.headSet(n); - LayoutNode leftNeighbor = null; + LayoutNode leftNeighbor; int minX = Integer.MIN_VALUE; if (!headSet.isEmpty()) { leftNeighbor = headSet.last(); @@ -843,7 +773,7 @@ public class HierarchicalLayoutManager implements LayoutManager { n.x = minX; } else { - LayoutNode rightNeighbor = null; + LayoutNode rightNeighbor; SortedSet tailSet = treeSet.tailSet(n); int maxX = Integer.MAX_VALUE; if (!tailSet.isEmpty()) { @@ -851,11 +781,7 @@ public class HierarchicalLayoutManager implements LayoutManager { maxX = rightNeighbor.x - offset(n, rightNeighbor) - n.width; } - if (pos > maxX) { - n.x = maxX; - } else { - n.x = pos; - } + n.x = Math.min(pos, maxX); assert minX <= maxX : minX + " vs " + maxX; } @@ -863,13 +789,7 @@ public class HierarchicalLayoutManager implements LayoutManager { treeSet.add(n); } } - private static Comparator crossingNodeComparator = new Comparator() { - - @Override - public int compare(LayoutNode n1, LayoutNode n2) { - return n1.crossingNumber - n2.crossingNumber; - } - }; + private static final Comparator crossingNodeComparator = Comparator.comparingInt(n -> n.crossingNumber); private class CrossingReduction extends AlgorithmPart { @@ -945,10 +865,9 @@ public class HierarchicalLayoutManager implements LayoutManager { } private void updatePositions() { - - for (int i = 0; i < layers.length; i++) { + for (List layer : layers) { int z = 0; - for (LayoutNode n : layers[i]) { + for (LayoutNode n : layer) { n.pos = z; z++; } @@ -1088,18 +1007,18 @@ public class HierarchicalLayoutManager implements LayoutManager { protected void run() { int curY = 0; - for (int i = 0; i < layers.length; i++) { + for (List layer : layers) { int maxHeight = 0; int baseLine = 0; int bottomBaseLine = 0; - for (LayoutNode n : layers[i]) { + for (LayoutNode n : layer) { maxHeight = Math.max(maxHeight, n.height - n.yOffset - n.bottomYOffset); baseLine = Math.max(baseLine, n.yOffset); bottomBaseLine = Math.max(bottomBaseLine, n.bottomYOffset); } int maxXOffset = 0; - for (LayoutNode n : layers[i]) { + for (LayoutNode n : layer) { if (n.vertex == null) { // Dummy node n.y = curY; @@ -1147,13 +1066,7 @@ public class HierarchicalLayoutManager implements LayoutManager { if (combine == Combine.SAME_OUTPUTS) { - Comparator comparator = new Comparator() { - - @Override - public int compare(LayoutEdge e1, LayoutEdge e2) { - return e1.to.layer - e2.to.layer; - } - }; + Comparator comparator = Comparator.comparingInt(e -> e.to.layer); HashMap> portHash = new HashMap<>(); ArrayList currentNodes = new ArrayList<>(nodes); for (LayoutNode n : currentNodes) { @@ -1165,12 +1078,12 @@ public class HierarchicalLayoutManager implements LayoutManager { for (LayoutEdge e : succs) { assert e.from.layer < e.to.layer; if (e.from.layer != e.to.layer - 1) { - if (maxLayerLength != -1 && e.to.layer - e.from.layer > maxLayerLength/* && e.to.preds.size() > 1 && e.from.succs.size() > 1*/) { + if (maxLayerLength != -1 && e.to.layer - e.from.layer > maxLayerLength) { assert maxLayerLength > 2; e.to.preds.remove(e); e.from.succs.remove(e); - LayoutEdge topEdge = null; + LayoutEdge topEdge; if (combine == Combine.SAME_OUTPUTS && topNodeHash.containsKey(e.relativeFrom)) { LayoutNode topNode = topNodeHash.get(e.relativeFrom); @@ -1193,19 +1106,19 @@ public class HierarchicalLayoutManager implements LayoutManager { topEdge = new LayoutEdge(); topEdge.relativeFrom = e.relativeFrom; topEdge.from = e.from; - topEdge.relativeTo = topNode.width / 2; + topEdge.relativeTo = 0; topEdge.to = topNode; topEdge.link = e.link; topEdge.vip = e.vip; e.from.succs.add(topEdge); topNode.preds.add(topEdge); topNodeHash.put(e.relativeFrom, topNode); - bottomNodeHash.put(e.relativeFrom, new HashMap()); + bottomNodeHash.put(e.relativeFrom, new HashMap<>()); } HashMap hash = bottomNodeHash.get(e.relativeFrom); - LayoutNode bottomNode = null; + LayoutNode bottomNode; if (hash.containsKey(e.to.layer)) { bottomNode = hash.get(e.to.layer); } else { @@ -1226,13 +1139,12 @@ public class HierarchicalLayoutManager implements LayoutManager { bottomEdge.link = e.link; bottomEdge.vip = e.vip; e.to.preds.add(bottomEdge); - bottomEdgeHash.put(topEdge, bottomEdge); bottomNode.succs.add(bottomEdge); } else { Integer i = e.relativeFrom; if (!portHash.containsKey(i)) { - portHash.put(i, new ArrayList()); + portHash.put(i, new ArrayList<>()); } portHash.get(i).add(e); } @@ -1565,7 +1477,7 @@ public class HierarchicalLayoutManager implements LayoutManager { final int offset = xOffset + DUMMY_WIDTH; - int curX = 0; + int curY = 0; int curWidth = node.width + reversedDown.size() * offset; for (int pos : reversedDown) { ArrayList reversedSuccs = new ArrayList<>(); @@ -1577,15 +1489,15 @@ public class HierarchicalLayoutManager implements LayoutManager { } ArrayList startPoints = new ArrayList<>(); - startPoints.add(new Point(curWidth, curX)); - startPoints.add(new Point(pos, curX)); + startPoints.add(new Point(curWidth, curY)); + startPoints.add(new Point(pos, curY)); startPoints.add(new Point(pos, reversedDown.size() * offset)); for (LayoutEdge e : reversedSuccs) { reversedLinkStartPoints.put(e.link, startPoints); } - node.inOffsets.put(pos, -curX); - curX += offset; + node.inOffsets.put(pos, -curY); + curY += offset; node.height += offset; node.yOffset += offset; curWidth -= offset; @@ -1597,13 +1509,7 @@ public class HierarchicalLayoutManager implements LayoutManager { } node.width += widthFactor * offset; - if (hasReversedDown) { - curX = -offset; - } else { - curX = offset; - } - - curX = 0; + int curX = 0; int minX = 0; if (hasReversedDown) { minX = -offset * reversedUp.size(); @@ -1761,33 +1667,29 @@ public class HierarchicalLayoutManager implements LayoutManager { } } } - private Comparator linkComparator = new Comparator() { + private final Comparator linkComparator = (l1, l2) -> { + if (l1.isVIP() && !l2.isVIP()) { + return -1; + } - @Override - public int compare(Link l1, Link l2) { - if (l1.isVIP() && !l2.isVIP()) { - return -1; - } + if (!l1.isVIP() && l2.isVIP()) { + return 1; + } - if (!l1.isVIP() && l2.isVIP()) { - return 1; - } - - int result = l1.getFrom().getVertex().compareTo(l2.getFrom().getVertex()); - if (result != 0) { - return result; - } - result = l1.getTo().getVertex().compareTo(l2.getTo().getVertex()); - if (result != 0) { - return result; - } - result = l1.getFrom().getRelativePosition().x - l2.getFrom().getRelativePosition().x; - if (result != 0) { - return result; - } - result = l1.getTo().getRelativePosition().x - l2.getTo().getRelativePosition().x; + int result = l1.getFrom().getVertex().compareTo(l2.getFrom().getVertex()); + if (result != 0) { return result; } + result = l1.getTo().getVertex().compareTo(l2.getTo().getVertex()); + if (result != 0) { + return result; + } + result = l1.getFrom().getRelativePosition().x - l2.getFrom().getRelativePosition().x; + if (result != 0) { + return result; + } + result = l1.getTo().getRelativePosition().x - l2.getTo().getRelativePosition().x; + return result; }; private class BuildDatastructure extends AlgorithmPart { @@ -1797,11 +1699,8 @@ public class HierarchicalLayoutManager implements LayoutManager { // Set up nodes List vertices = new ArrayList<>(graph.getVertices()); // Order roots first to create more natural layer assignments. - Collections.sort(vertices, - (Vertex a, Vertex b) -> - a.isRoot() == b.isRoot() ? - a.compareTo(b) : - Boolean.compare(b.isRoot(), a.isRoot())); + vertices.sort((Vertex a, Vertex b) -> + a.isRoot() == b.isRoot() ? a.compareTo(b) : Boolean.compare(b.isRoot(), a.isRoot())); for (Vertex v : vertices) { LayoutNode node = new LayoutNode(); diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/InterClusterConnection.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/InterClusterConnection.java index 2019263b6ec..0ff9a7dd04c 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/InterClusterConnection.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/InterClusterConnection.java @@ -23,9 +23,9 @@ */ package com.sun.hotspot.igv.hierarchicallayout; +import com.sun.hotspot.igv.layout.Cluster; import com.sun.hotspot.igv.layout.Link; import com.sun.hotspot.igv.layout.Port; -import com.sun.hotspot.igv.layout.Cluster; import java.awt.Point; import java.util.ArrayList; import java.util.List; @@ -36,22 +36,14 @@ import java.util.List; */ public class InterClusterConnection implements Link { - private Port inputSlot; - private Port outputSlot; + private final Port inputSlot; + private final Port outputSlot; private List intermediatePoints; - private ClusterInputSlotNode inputSlotNode; - private ClusterOutputSlotNode outputSlotNode; public InterClusterConnection(ClusterOutputSlotNode outputSlotNode, ClusterInputSlotNode inputSlotNode) { - this.outputSlotNode = outputSlotNode; - this.inputSlotNode = inputSlotNode; this.inputSlot = inputSlotNode.getInputSlot(); this.outputSlot = outputSlotNode.getOutputSlot(); - intermediatePoints = new ArrayList(); - } - - public ClusterOutputSlotNode getOutputSlotNode() { - return outputSlotNode; + this.intermediatePoints = new ArrayList<>(); } public Port getTo() { diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/LinearLayoutManager.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/LinearLayoutManager.java index b52631f2861..32f56e69bf9 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/LinearLayoutManager.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/LinearLayoutManager.java @@ -41,7 +41,7 @@ public class LinearLayoutManager implements LayoutManager { @Override public void doLayout(LayoutGraph graph) { - doLayout(graph, new HashSet()); + doLayout(graph, new HashSet<>()); } @Override diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Node.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Node.java deleted file mode 100644 index f98b1598002..00000000000 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Node.java +++ /dev/null @@ -1,161 +0,0 @@ -/* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ -package com.sun.hotspot.igv.hierarchicallayout; - -import java.util.ArrayList; -import java.util.Collections; -import java.util.List; - -/** - * - * @author Thomas Wuerthinger - */ -public class Node { - - private N data; - private List> inEdges; - private List> outEdges; - private boolean visited; - private boolean active; - private boolean reachable; - private Graph graph; - - protected boolean isVisited() { - return visited; - } - - protected void setVisited(boolean b) { - visited = b; - } - - protected boolean isReachable() { - return reachable; - } - - protected void setReachable(boolean b) { - reachable = b; - } - - protected boolean isActive() { - return active; - } - - protected void setActive(boolean b) { - active = b; - } - - public int getInDegree() { - return getInDegree(true); - } - - public int getInDegree(boolean countSelfLoops) { - if (countSelfLoops) { - return inEdges.size(); - } else { - int cnt = 0; - for (Edge e : inEdges) { - if (e.getSource() != this) { - cnt++; - } - } - return cnt; - } - } - - public int getOutDegree() { - return outEdges.size(); - } - - protected Node(Graph graph, N data) { - setData(data); - this.graph = graph; - inEdges = new ArrayList<>(); - outEdges = new ArrayList<>(); - } - - protected void addInEdge(Edge e) { - inEdges.add(e); - } - - public Graph getGraph() { - return graph; - } - - protected void addOutEdge(Edge e) { - outEdges.add(e); - } - - protected void removeInEdge(Edge e) { - //assert inEdges.contains(e); - inEdges.remove(e); - } - - protected void removeOutEdge(Edge e) { - //assert outEdges.contains(e); - outEdges.remove(e); - } - - public List> getInEdges() { - return Collections.unmodifiableList(inEdges); - } - - public List> getOutEdges() { - return Collections.unmodifiableList(outEdges); - } - - public List> getSuccessors() { - ArrayList> succ = new ArrayList<>(); - for (Edge e : getOutEdges()) { - Node n = e.getDest(); - if (!succ.contains(n)) { - succ.add(n); - } - } - return succ; - } - - public List> getPredecessors() { - ArrayList> pred = new ArrayList<>(); - for (Edge e : getInEdges()) { - Node n = e.getSource(); - if (!pred.contains(n)) { - pred.add(n); - } - } - return pred; - } - - public N getData() { - return data; - } - - public void setData(N d) { - data = d; - } - - @Override - public String toString() { - return "Node: " + data; - } -} diff --git a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Timing.java b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Timing.java index 7272e80d761..080516df120 100644 --- a/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Timing.java +++ b/src/utils/IdealGraphVisualizer/HierarchicalLayout/src/main/java/com/sun/hotspot/igv/hierarchicallayout/Timing.java @@ -31,7 +31,7 @@ public class Timing { private long lastValue; private long sum; - private String name; + private final String name; public Timing(String name) { this.name = name; @@ -49,7 +49,7 @@ public class Timing { } public void print() { - System.out.println(toString()); + System.out.println(); } public void start() { diff --git a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Cluster.java b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Cluster.java index 2cf31b60d8e..e6938cb2f19 100644 --- a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Cluster.java +++ b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Cluster.java @@ -33,11 +33,9 @@ import java.util.Set; */ public interface Cluster extends Comparable { - public Cluster getOuter(); + void setBounds(Rectangle r); - public void setBounds(Rectangle r); + Set getSuccessors(); - public Set getSuccessors(); - - public Dimension getNodeOffset(); + Dimension getNodeOffset(); } diff --git a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/LayoutGraph.java b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/LayoutGraph.java index 0409aa82d10..ad358cba299 100644 --- a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/LayoutGraph.java +++ b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/LayoutGraph.java @@ -31,14 +31,14 @@ import java.util.*; */ public class LayoutGraph { - private Set links; - private SortedSet vertices; - private HashMap> inputPorts; - private HashMap> outputPorts; - private HashMap> portLinks; + private final Set links; + private final SortedSet vertices; + private final HashMap> inputPorts; + private final HashMap> outputPorts; + private final HashMap> portLinks; public LayoutGraph(Set links) { - this(links, new HashSet()); + this(links, new HashSet<>()); } public LayoutGraph(Set links, Set additionalVertices) { @@ -61,8 +61,8 @@ public class LayoutGraph { if (!vertices.contains(v1)) { - outputPorts.put(v1, new HashSet(1)); - inputPorts.put(v1, new HashSet(3)); + outputPorts.put(v1, new HashSet<>(1)); + inputPorts.put(v1, new HashSet<>(3)); vertices.add(v1); assert vertices.contains(v1); } @@ -70,8 +70,8 @@ public class LayoutGraph { if (!vertices.contains(v2)) { vertices.add(v2); assert vertices.contains(v2); - outputPorts.put(v2, new HashSet(1)); - inputPorts.put(v2, new HashSet(3)); + outputPorts.put(v2, new HashSet<>(1)); + inputPorts.put(v2, new HashSet<>(3)); } if (!portLinks.containsKey(p)) { @@ -80,7 +80,7 @@ public class LayoutGraph { } if (!portLinks.containsKey(p2)) { - portLinks.put(p2, new HashSet(3)); + portLinks.put(p2, new HashSet<>(3)); } outputPorts.get(v1).add(p); @@ -92,10 +92,9 @@ public class LayoutGraph { for (Vertex v : additionalVertices) { if (!vertices.contains(v)) { - outputPorts.put(v, new HashSet(1)); - inputPorts.put(v, new HashSet(3)); + outputPorts.put(v, new HashSet<>(1)); + inputPorts.put(v, new HashSet<>(3)); vertices.add(v); - vertices.contains(v); } } } @@ -184,12 +183,12 @@ public class LayoutGraph { } public Set findRootVertices() { - return findRootVertices(new HashSet()); + return findRootVertices(new HashSet<>()); } public SortedSet getClusters() { - SortedSet clusters = new TreeSet(); + SortedSet clusters = new TreeSet<>(); for (Vertex v : getVertices()) { if (v.getCluster() != null) { clusters.add(v.getCluster()); diff --git a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/LayoutManager.java b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/LayoutManager.java index 8ae848b4d04..86a0d02e16b 100644 --- a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/LayoutManager.java +++ b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/LayoutManager.java @@ -31,7 +31,7 @@ import java.util.Set; */ public interface LayoutManager { - public void doLayout(LayoutGraph graph); + void doLayout(LayoutGraph graph); - public void doLayout(LayoutGraph graph, Set importantLinks); + void doLayout(LayoutGraph graph, Set importantLinks); } diff --git a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Link.java b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Link.java index f6fa2a868c2..681ef7af33a 100644 --- a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Link.java +++ b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Link.java @@ -32,17 +32,17 @@ import java.util.List; */ public interface Link { - public Port getFrom(); + Port getFrom(); - public Cluster getFromCluster(); + Cluster getFromCluster(); - public Port getTo(); + Port getTo(); - public Cluster getToCluster(); + Cluster getToCluster(); - public boolean isVIP(); + boolean isVIP(); - public List getControlPoints(); + List getControlPoints(); - public void setControlPoints(List list); + void setControlPoints(List list); } diff --git a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Port.java b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Port.java index f2776b5050f..ecbaa6a2e0a 100644 --- a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Port.java +++ b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Port.java @@ -31,7 +31,7 @@ import java.awt.Point; */ public interface Port { - public Vertex getVertex(); + Vertex getVertex(); - public Point getRelativePosition(); + Point getRelativePosition(); } diff --git a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Vertex.java b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Vertex.java index 6350e52faef..cd415cc0ac4 100644 --- a/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Vertex.java +++ b/src/utils/IdealGraphVisualizer/Layout/src/main/java/com/sun/hotspot/igv/layout/Vertex.java @@ -32,13 +32,13 @@ import java.awt.Point; */ public interface Vertex extends Comparable { - public Dimension getSize(); + Dimension getSize(); - public Point getPosition(); + Point getPosition(); - public void setPosition(Point p); + void setPosition(Point p); - public boolean isRoot(); + boolean isRoot(); - public Cluster getCluster(); + Cluster getCluster(); } diff --git a/src/utils/IdealGraphVisualizer/NetworkConnection/src/main/java/com/sun/hotspot/igv/connection/Client.java b/src/utils/IdealGraphVisualizer/NetworkConnection/src/main/java/com/sun/hotspot/igv/connection/Client.java index 5bba5c4fb6d..2f4b6cff0db 100644 --- a/src/utils/IdealGraphVisualizer/NetworkConnection/src/main/java/com/sun/hotspot/igv/connection/Client.java +++ b/src/utils/IdealGraphVisualizer/NetworkConnection/src/main/java/com/sun/hotspot/igv/connection/Client.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,8 +24,6 @@ */ package com.sun.hotspot.igv.connection; -import com.sun.hotspot.igv.data.GraphDocument; -import com.sun.hotspot.igv.data.serialization.BinaryParser; import com.sun.hotspot.igv.data.serialization.Parser; import com.sun.hotspot.igv.data.services.GroupCallback; import java.io.IOException; @@ -33,16 +31,12 @@ import java.nio.channels.SocketChannel; import org.openide.util.Exceptions; public class Client implements Runnable { - private final boolean binary; private final SocketChannel socket; - private final GraphDocument rootDocument; private final GroupCallback callback; - public Client(SocketChannel socket, GraphDocument rootDocument, GroupCallback callback, boolean binary) { + public Client(SocketChannel socket, GroupCallback callback) { this.callback = callback; this.socket = socket; - this.binary = binary; - this.rootDocument = rootDocument; } @Override @@ -51,13 +45,8 @@ public class Client implements Runnable { try { final SocketChannel channel = socket; channel.configureBlocking(true); - if (binary) { - new BinaryParser(channel, null, rootDocument, callback).parse(); - } else { - // signal readiness to client VM (old protocol) - channel.socket().getOutputStream().write('y'); - new Parser(channel, null, callback).parse(); - } + channel.socket().getOutputStream().write('y'); + new Parser(channel, null, callback).parse(); } catch (IOException ex) { Exceptions.printStackTrace(ex); } finally { diff --git a/src/utils/IdealGraphVisualizer/NetworkConnection/src/main/java/com/sun/hotspot/igv/connection/Server.java b/src/utils/IdealGraphVisualizer/NetworkConnection/src/main/java/com/sun/hotspot/igv/connection/Server.java index c755e2cdb35..523f4d2017d 100644 --- a/src/utils/IdealGraphVisualizer/NetworkConnection/src/main/java/com/sun/hotspot/igv/connection/Server.java +++ b/src/utils/IdealGraphVisualizer/NetworkConnection/src/main/java/com/sun/hotspot/igv/connection/Server.java @@ -24,7 +24,6 @@ */ package com.sun.hotspot.igv.connection; -import com.sun.hotspot.igv.data.GraphDocument; import com.sun.hotspot.igv.data.services.GroupCallback; import com.sun.hotspot.igv.settings.Settings; import java.io.IOException; @@ -42,16 +41,12 @@ import org.openide.util.RequestProcessor; * @author Thomas Wuerthinger */ public class Server implements PreferenceChangeListener { - private final boolean binary; private ServerSocketChannel serverSocket; - private final GraphDocument rootDocument; private final GroupCallback callback; private int port; private Runnable serverRunnable; - public Server(GraphDocument rootDocument, GroupCallback callback, boolean binary) { - this.binary = binary; - this.rootDocument = rootDocument; + public Server(GroupCallback callback) { this.callback = callback; initializeNetwork(); Settings.get().addPreferenceChangeListener(this); @@ -59,22 +54,20 @@ public class Server implements PreferenceChangeListener { @Override public void preferenceChange(PreferenceChangeEvent e) { - - int curPort = Integer.parseInt(Settings.get().get(binary ? Settings.PORT_BINARY : Settings.PORT, binary ? Settings.PORT_BINARY_DEFAULT : Settings.PORT_DEFAULT)); + int curPort = Integer.parseInt(Settings.get().get(Settings.PORT, Settings.PORT_DEFAULT)); if (curPort != port) { initializeNetwork(); } } private void initializeNetwork() { - - int curPort = Integer.parseInt(Settings.get().get(binary ? Settings.PORT_BINARY : Settings.PORT, binary ? Settings.PORT_BINARY_DEFAULT : Settings.PORT_DEFAULT)); + int curPort = Integer.parseInt(Settings.get().get(Settings.PORT, Settings.PORT_DEFAULT)); this.port = curPort; try { serverSocket = ServerSocketChannel.open(); serverSocket.bind(new InetSocketAddress(curPort)); } catch (Throwable ex) { - NotifyDescriptor message = new NotifyDescriptor.Message("Could not create server. Listening for incoming binary data is disabled.", NotifyDescriptor.ERROR_MESSAGE); + NotifyDescriptor message = new NotifyDescriptor.Message("Could not create server. Listening for incoming data is disabled.", NotifyDescriptor.ERROR_MESSAGE); DialogDisplayer.getDefault().notifyLater(message); return; } @@ -90,10 +83,10 @@ public class Server implements PreferenceChangeListener { clientSocket.close(); return; } - RequestProcessor.getDefault().post(new Client(clientSocket, rootDocument, callback, binary), 0, Thread.MAX_PRIORITY); + RequestProcessor.getDefault().post(new Client(clientSocket, callback), 0, Thread.MAX_PRIORITY); } catch (IOException ex) { serverSocket = null; - NotifyDescriptor message = new NotifyDescriptor.Message("Error during listening for incoming connections. Listening for incoming binary data is disabled.", NotifyDescriptor.ERROR_MESSAGE); + NotifyDescriptor message = new NotifyDescriptor.Message("Error during listening for incoming connections. Listening for incoming data is disabled.", NotifyDescriptor.ERROR_MESSAGE); DialogDisplayer.getDefault().notifyLater(message); return; } diff --git a/src/utils/IdealGraphVisualizer/SelectionCoordinator/src/main/java/com/sun/hotspot/igv/selectioncoordinator/SelectionCoordinator.java b/src/utils/IdealGraphVisualizer/SelectionCoordinator/src/main/java/com/sun/hotspot/igv/selectioncoordinator/SelectionCoordinator.java index a62cf5d187e..687b09b77e2 100644 --- a/src/utils/IdealGraphVisualizer/SelectionCoordinator/src/main/java/com/sun/hotspot/igv/selectioncoordinator/SelectionCoordinator.java +++ b/src/utils/IdealGraphVisualizer/SelectionCoordinator/src/main/java/com/sun/hotspot/igv/selectioncoordinator/SelectionCoordinator.java @@ -35,11 +35,11 @@ import java.util.Set; */ public class SelectionCoordinator { - private static SelectionCoordinator singleInstance = new SelectionCoordinator(); - private Set selectedObjects; - private Set highlightedObjects; - private ChangedEvent selectedChangedEvent; - private ChangedEvent highlightedChangedEvent; + private static final SelectionCoordinator singleInstance = new SelectionCoordinator(); + private final Set selectedObjects; + private final Set highlightedObjects; + private final ChangedEvent selectedChangedEvent; + private final ChangedEvent highlightedChangedEvent; public static SelectionCoordinator getInstance() { return singleInstance; @@ -52,11 +52,11 @@ public class SelectionCoordinator { highlightedObjects = new HashSet<>(); } - public Set getSelectedObjects() { + public Set getSelectedObjects() { return Collections.unmodifiableSet(selectedObjects); } - public Set getHighlightedObjects() { + public Set getHighlightedObjects() { return Collections.unmodifiableSet(highlightedObjects); } @@ -68,72 +68,18 @@ public class SelectionCoordinator { return selectedChangedEvent; } - public void addHighlighted(Object o) { - if (!highlightedObjects.contains(o)) { - highlightedObjects.add(o); - highlightedObjectsChanged(); - } - } - public void removeHighlighted(Object o) { - if (highlightedObjects.contains(o)) { - highlightedObjects.remove(o); - highlightedObjectsChanged(); - } - } - - public void addAllHighlighted(Set s) { - int oldSize = highlightedObjects.size(); - highlightedObjects.addAll(s); - if (oldSize != highlightedObjects.size()) { - highlightedObjectsChanged(); - } - } - - public void removeAllHighlighted(Set s) { - int oldSize = highlightedObjects.size(); - highlightedObjects.removeAll(s); - if (oldSize != highlightedObjects.size()) { - highlightedObjectsChanged(); - } - } - - private void highlightedObjectsChanged() { - highlightedChangedEvent.fire(); - - } - - public void addAllSelected(Set s) { - int oldSize = selectedObjects.size(); - selectedObjects.addAll(s); - if (oldSize != selectedObjects.size()) { - selectedObjectsChanged(); - } - } - - public void removeAllSelected(Set s) { - int oldSize = selectedObjects.size(); - selectedObjects.removeAll(s); - if (oldSize != selectedObjects.size()) { - selectedObjectsChanged(); - } - } - - public void setSelectedObjects(Set s) { + public void setSelectedObjects(Set s) { assert s != null; selectedObjects.clear(); selectedObjects.addAll(s); - selectedObjectsChanged(); + getSelectedChangedEvent().fire(); } - private void selectedObjectsChanged() { - selectedChangedEvent.fire(); - } - - public void setHighlightedObjects(Set s) { + public void setHighlightedObjects(Set s) { assert s != null; - this.highlightedObjects.clear(); - this.highlightedObjects.addAll(s); - highlightedObjectsChanged(); + highlightedObjects.clear(); + highlightedObjects.addAll(s); + getHighlightedChangedEvent().fire(); } } diff --git a/src/utils/IdealGraphVisualizer/ServerCompiler/src/main/java/com/sun/hotspot/igv/servercompiler/ServerCompilerScheduler.java b/src/utils/IdealGraphVisualizer/ServerCompiler/src/main/java/com/sun/hotspot/igv/servercompiler/ServerCompilerScheduler.java index 830b40b8d43..c1287157022 100644 --- a/src/utils/IdealGraphVisualizer/ServerCompiler/src/main/java/com/sun/hotspot/igv/servercompiler/ServerCompilerScheduler.java +++ b/src/utils/IdealGraphVisualizer/ServerCompiler/src/main/java/com/sun/hotspot/igv/servercompiler/ServerCompilerScheduler.java @@ -4,13 +4,13 @@ * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this + * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * @@ -24,6 +24,9 @@ */ package com.sun.hotspot.igv.servercompiler; +import com.ibm.wala.util.graph.Graph; +import com.ibm.wala.util.graph.dominators.Dominators; +import com.ibm.wala.util.graph.impl.SlowSparseNumberedGraph; import com.sun.hotspot.igv.data.InputBlock; import com.sun.hotspot.igv.data.InputEdge; import com.sun.hotspot.igv.data.InputGraph; @@ -33,9 +36,6 @@ import java.util.*; import java.util.function.Predicate; import org.openide.ErrorManager; import org.openide.util.lookup.ServiceProvider; -import com.ibm.wala.util.graph.Graph; -import com.ibm.wala.util.graph.impl.SlowSparseNumberedGraph; -import com.ibm.wala.util.graph.dominators.Dominators; /** * @@ -122,13 +122,7 @@ public class ServerCompilerScheduler implements Scheduler { Map> controlSuccs = new HashMap<>(); // Nodes reachable in backward traversal from root. private Map dominatorMap; - private static final Comparator edgeComparator = new Comparator() { - - @Override - public int compare(InputEdge o1, InputEdge o2) { - return o1.getToIndex() - o2.getToIndex(); - } - }; + private static final Comparator edgeComparator = Comparator.comparingInt(InputEdge::getToIndex); public void buildBlocks() { @@ -173,7 +167,7 @@ public class ServerCompilerScheduler implements Scheduler { rootBlock = block; } blockCount++; - Set blockTerminators = new HashSet(); + Set blockTerminators = new HashSet<>(); // Move forwards until a terminator node is found, assigning all // visited nodes to the current block. while (true) { @@ -283,12 +277,12 @@ public class ServerCompilerScheduler implements Scheduler { Node n = new Node(); n.preds.add(p); n.succs.add(s); - controlSuccs.put(n, Arrays.asList(s)); + controlSuccs.put(n, Collections.singletonList(s)); n.isCFG = true; // Update predecessor node p. p.succs.remove(s); p.succs.add(n); - controlSuccs.put(p, Arrays.asList(n)); + controlSuccs.put(p, Collections.singletonList(n)); // Update successor node s. Collections.replaceAll(s.preds, p, n); return n; @@ -373,30 +367,27 @@ public class ServerCompilerScheduler implements Scheduler { } } - private static final Comparator schedulePriority = new Comparator(){ - @Override - public int compare(Node n1, Node n2) { - // Order by rank, then idx. - int r1 = n1.rank, r2 = n2.rank; - int o1, o2; - if (r1 != r2) { // Different rank. - o1 = r1; - o2 = r2; - } else { // Same rank, order by idx. - o1 = Integer.parseInt(n1.inputNode.getProperties().get("idx")); - o2 = Integer.parseInt(n2.inputNode.getProperties().get("idx")); - } - return Integer.compare(o1, o2); - }; - }; + private static final Comparator schedulePriority = (n1, n2) -> { + // Order by rank, then idx. + int r1 = n1.rank, r2 = n2.rank; + int o1, o2; + if (r1 != r2) { // Different rank. + o1 = r1; + o2 = r2; + } else { // Same rank, order by idx. + o1 = Integer.parseInt(n1.inputNode.getProperties().get("idx")); + o2 = Integer.parseInt(n2.inputNode.getProperties().get("idx")); + } + return Integer.compare(o1, o2); + }; private List scheduleBlock(Collection nodes) { - List schedule = new ArrayList(); + List schedule = new ArrayList<>(); // Initialize ready priority queue with nodes without predecessors. - Queue ready = new PriorityQueue(schedulePriority); + Queue ready = new PriorityQueue<>(schedulePriority); // Set of nodes that have been enqueued. - Set visited = new HashSet(nodes.size()); + Set visited = new HashSet<>(nodes.size()); for (Node n : nodes) { if (n.preds.isEmpty()) { ready.add(n); @@ -712,9 +703,7 @@ public class ServerCompilerScheduler implements Scheduler { // Find all nodes reachable in backward traversal from root. private Set reachableNodes() { Node root = findRoot(); - if (root == null) { - assert false : "No root found!"; - } + assert root != null : "No root found!"; Set reachable = new HashSet<>(); reachable.add(root); Stack stack = new Stack<>(); @@ -753,7 +742,7 @@ public class ServerCompilerScheduler implements Scheduler { int to = e.getTo(); if (!edgeMap.containsKey(to)) { - edgeMap.put(to, new ArrayList()); + edgeMap.put(to, new ArrayList<>()); } @@ -862,7 +851,7 @@ public class ServerCompilerScheduler implements Scheduler { } for (String warning : n.warnings) { if (!nodesPerWarning.containsKey(warning)) { - nodesPerWarning.put(warning, new HashSet()); + nodesPerWarning.put(warning, new HashSet<>()); } nodesPerWarning.get(warning).add(n); } diff --git a/src/utils/IdealGraphVisualizer/Settings/src/main/java/com/sun/hotspot/igv/settings/Settings.java b/src/utils/IdealGraphVisualizer/Settings/src/main/java/com/sun/hotspot/igv/settings/Settings.java index 6373d513120..d80f4ab3687 100644 --- a/src/utils/IdealGraphVisualizer/Settings/src/main/java/com/sun/hotspot/igv/settings/Settings.java +++ b/src/utils/IdealGraphVisualizer/Settings/src/main/java/com/sun/hotspot/igv/settings/Settings.java @@ -47,9 +47,7 @@ public class Settings { public static final String DEFAULT_VIEW = "defaultView"; public static final int DEFAULT_VIEW_DEFAULT = DefaultView.SEA_OF_NODES; public static final String PORT = "port"; - public static final String PORT_BINARY = "portBinary"; public static final String PORT_DEFAULT = "4444"; - public static final String PORT_BINARY_DEFAULT = "4445"; public static final String DIRECTORY = "directory"; public static final String DIRECTORY_DEFAULT = System.getProperty("user.dir"); diff --git a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/DoubleClickAction.java b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/DoubleClickAction.java index 49a10576a7f..6c0b82f1ae7 100644 --- a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/DoubleClickAction.java +++ b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/DoubleClickAction.java @@ -32,7 +32,7 @@ import org.netbeans.api.visual.widget.Widget; */ public class DoubleClickAction extends WidgetAction.Adapter { - private DoubleClickHandler handler; + private final DoubleClickHandler handler; public DoubleClickAction(DoubleClickHandler handler) { this.handler = handler; diff --git a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/DoubleClickHandler.java b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/DoubleClickHandler.java index 3664949a2ef..a3e4cc801a5 100644 --- a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/DoubleClickHandler.java +++ b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/DoubleClickHandler.java @@ -32,5 +32,5 @@ import org.netbeans.api.visual.widget.Widget; */ public interface DoubleClickHandler { - public void handleDoubleClick(Widget w, WidgetMouseEvent e); + void handleDoubleClick(Widget w, WidgetMouseEvent e); } diff --git a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/ExtendedSatelliteComponent.java b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/ExtendedSatelliteComponent.java deleted file mode 100644 index 2f0808028ca..00000000000 --- a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/ExtendedSatelliteComponent.java +++ /dev/null @@ -1,208 +0,0 @@ -/* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ -package com.sun.hotspot.igv.util; - -import java.awt.*; -import java.awt.event.*; -import javax.swing.JComponent; -import org.netbeans.api.visual.widget.Scene; - -/** - * @author David Kaspar - * @author Thomas Wuerthinger - */ -public class ExtendedSatelliteComponent extends JComponent implements MouseListener, MouseMotionListener, Scene.SceneListener, ComponentListener { - - private Scene scene; - private Image image; - private int imageWidth; - private int imageHeight; - - public ExtendedSatelliteComponent(Scene scene) { - this.scene = scene; - setDoubleBuffered(true); - setPreferredSize(new Dimension(128, 128)); - addMouseListener(this); - addMouseMotionListener(this); - } - - @Override - public void addNotify() { - super.addNotify(); - scene.addSceneListener(this); - JComponent viewComponent = scene.getView(); - if (viewComponent == null) { - viewComponent = scene.createView(); - } - viewComponent.addComponentListener(this); - repaint(); - } - - @Override - public void removeNotify() { - scene.getView().removeComponentListener(this); - scene.removeSceneListener(this); - super.removeNotify(); - } - - public void update() { - this.image = null; - repaint(); - } - - @Override - public void paint(Graphics g) { - Graphics2D gr = (Graphics2D) g; - super.paint(g); - Rectangle bounds = scene.getBounds(); - Dimension size = getSize(); - - double sx = bounds.width > 0 ? (double) size.width / bounds.width : 0.0; - double sy = bounds.width > 0 ? (double) size.height / bounds.height : 0.0; - double scale = Math.min(sx, sy); - - int vw = (int) (scale * bounds.width); - int vh = (int) (scale * bounds.height); - int vx = (size.width - vw) / 2; - int vy = (size.height - vh) / 2; - - - if (image == null || vw != imageWidth || vh != imageHeight) { - - imageWidth = vw; - imageHeight = vh; - image = this.createImage(imageWidth, imageHeight); - Graphics2D ig = (Graphics2D) image.getGraphics(); - ig.scale(scale, scale); - scene.paint(ig); - } - - gr.drawImage(image, vx, vy, this); - - JComponent component = scene.getView(); - double zoomFactor = scene.getZoomFactor(); - Rectangle viewRectangle = component != null ? component.getVisibleRect() : null; - if (viewRectangle != null) { - Rectangle window = new Rectangle( - (int) ((double) viewRectangle.x * scale / zoomFactor), - (int) ((double) viewRectangle.y * scale / zoomFactor), - (int) ((double) viewRectangle.width * scale / zoomFactor), - (int) ((double) viewRectangle.height * scale / zoomFactor)); - window.translate(vx, vy); - gr.setColor(new Color(200, 200, 200, 128)); - gr.fill(window); - gr.setColor(Color.BLACK); - gr.drawRect(window.x, window.y, window.width - 1, window.height - 1); - } - } - - @Override - public void mouseClicked(MouseEvent e) { - } - - @Override - public void mousePressed(MouseEvent e) { - moveVisibleRect(e.getPoint()); - } - - @Override - public void mouseReleased(MouseEvent e) { - moveVisibleRect(e.getPoint()); - } - - @Override - public void mouseEntered(MouseEvent e) { - } - - @Override - public void mouseExited(MouseEvent e) { - } - - @Override - public void mouseDragged(MouseEvent e) { - moveVisibleRect(e.getPoint()); - } - - @Override - public void mouseMoved(MouseEvent e) { - } - - private void moveVisibleRect(Point center) { - JComponent component = scene.getView(); - if (component == null) { - return; - } - double zoomFactor = scene.getZoomFactor(); - Rectangle bounds = scene.getBounds(); - Dimension size = getSize(); - - double sx = bounds.width > 0 ? (double) size.width / bounds.width : 0.0; - double sy = bounds.width > 0 ? (double) size.height / bounds.height : 0.0; - double scale = Math.min(sx, sy); - - int vw = (int) (scale * bounds.width); - int vh = (int) (scale * bounds.height); - int vx = (size.width - vw) / 2; - int vy = (size.height - vh) / 2; - - int cx = (int) ((double) (center.x - vx) / scale * zoomFactor); - int cy = (int) ((double) (center.y - vy) / scale * zoomFactor); - - Rectangle visibleRect = component.getVisibleRect(); - visibleRect.x = cx - visibleRect.width / 2; - visibleRect.y = cy - visibleRect.height / 2; - component.scrollRectToVisible(visibleRect); - - } - - @Override - public void sceneRepaint() { - } - - @Override - public void sceneValidating() { - } - - @Override - public void sceneValidated() { - } - - @Override - public void componentResized(ComponentEvent e) { - repaint(); - } - - @Override - public void componentMoved(ComponentEvent e) { - repaint(); - } - - @Override - public void componentShown(ComponentEvent e) { - } - - @Override - public void componentHidden(ComponentEvent e) { - } -} diff --git a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/LookupHistory.java b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/LookupHistory.java index 0b6f27cf8d4..e97b65ba7ff 100644 --- a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/LookupHistory.java +++ b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/LookupHistory.java @@ -38,12 +38,12 @@ import org.openide.util.Utilities; */ public class LookupHistory { - private static Map cache = new HashMap<>(); + private static final Map cache = new HashMap<>(); private static class LookupHistoryImpl extends Event> implements LookupListener { - private Class klass; - private Result result; + private final Class klass; + private final Result result; private T last; public LookupHistoryImpl(Class klass) { diff --git a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/PropertiesConverter.java b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/PropertiesConverter.java index 583def3540b..ccaab04a703 100644 --- a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/PropertiesConverter.java +++ b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/PropertiesConverter.java @@ -26,7 +26,6 @@ package com.sun.hotspot.igv.util; import com.sun.hotspot.igv.data.Properties; import com.sun.hotspot.igv.data.Property; -import com.sun.hotspot.igv.util.StringUtils; /** * @@ -45,4 +44,4 @@ public class PropertiesConverter { sb.append(""); return sb.toString(); } -} \ No newline at end of file +} diff --git a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/PropertiesSheet.java b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/PropertiesSheet.java index 22fd64a4bd1..1ed0a1b42ac 100644 --- a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/PropertiesSheet.java +++ b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/PropertiesSheet.java @@ -26,7 +26,6 @@ package com.sun.hotspot.igv.util; import com.sun.hotspot.igv.data.Properties; import com.sun.hotspot.igv.data.Property; -import java.lang.reflect.InvocationTargetException; import org.openide.nodes.Node; import org.openide.nodes.Sheet; @@ -49,7 +48,7 @@ public class PropertiesSheet { } @Override - public String getValue() throws IllegalAccessException, InvocationTargetException { + public String getValue() { return p.getValue(); } @@ -59,7 +58,7 @@ public class PropertiesSheet { } @Override - public void setValue(String arg0) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException { + public void setValue(String arg0) throws IllegalArgumentException { properties.setProperty(p.getName(), arg0); } }; diff --git a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/RangeSlider.java b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/RangeSlider.java index 19d76c66b06..2c01e791706 100644 --- a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/RangeSlider.java +++ b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/RangeSlider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,12 +26,16 @@ package com.sun.hotspot.igv.util; import com.sun.hotspot.igv.data.ChangedListener; import java.awt.*; -import java.awt.geom.*; import java.awt.event.MouseEvent; import java.awt.event.MouseListener; import java.awt.event.MouseMotionListener; +import java.awt.geom.Ellipse2D; +import java.awt.geom.Rectangle2D; import java.util.List; -import javax.swing.*; +import javax.swing.JComponent; +import javax.swing.JViewport; +import javax.swing.Scrollable; +import javax.swing.SwingConstants; /** * @@ -52,10 +56,13 @@ public class RangeSlider extends JComponent implements ChangedListener= 0 && index < getPaintingModel().getPositions().size(); + assert index >= 0 && index < model.getPositions().size(); return getXOffset() * (index + 1); } private float getXOffset() { - int size = getPaintingModel().getPositions().size(); + int size = model.getPositions().size(); float width = (float)getWidth(); return (width / (size + 1)); } @@ -186,12 +192,12 @@ public class RangeSlider extends JComponent implements ChangedListener list = getPaintingModel().getPositions(); + List list = model.getPositions(); float barStartY = getBarStartY(); g.setColor(BAR_COLOR); @@ -212,7 +218,7 @@ public class RangeSlider extends JComponent implements ChangedListener= getBarStartY()) { - float destX = getEndXPosition(getPaintingModel().getSecondPosition()); + float destX = getEndXPosition(getSecondPos()); float off = Math.abs(destX - p.x); return off <= MOUSE_ENDING_OFFSET; } @@ -267,7 +273,7 @@ public class RangeSlider extends JComponent implements ChangedListener= getBarStartY()) { - float destX = getStartXPosition(getPaintingModel().getFirstPosition()); + float destX = getStartXPosition(getFirstPos()); float off = Math.abs(destX - p.x); return off <= MOUSE_ENDING_OFFSET; } @@ -276,7 +282,7 @@ public class RangeSlider extends JComponent implements ChangedListener= getBarStartY() && !isOverFirstPosition(p) && !isOverSecondPosition(p)) { - return p.x > getStartXPosition(getPaintingModel().getFirstPosition()) && p.x < getEndXPosition(getPaintingModel().getSecondPosition()); + return p.x > getStartXPosition(getFirstPos()) && p.x < getEndXPosition(getSecondPos()); } return false; } @@ -289,28 +295,25 @@ public class RangeSlider extends JComponent implements ChangedListener= model.getPositions().size()) { - newIndex = model.getPositions().size() - (model.getSecondPosition() - model.getFirstPosition()) - 1; + tempFirstPos = getIndexFromPosition(newFirstX) + 1; + if (tempFirstPos + model.getSecondPosition() - model.getFirstPosition() >= model.getPositions().size()) { + tempFirstPos = model.getPositions().size() - (model.getSecondPosition() - model.getFirstPosition()) - 1; } - int secondPosition = newIndex + model.getSecondPosition() - model.getFirstPosition(); - tempModel.setPositions(newIndex, secondPosition); + tempSecondPos = tempFirstPos + model.getSecondPosition() - model.getFirstPosition(); update(); } else if (state == State.DragFirstPosition) { - int firstPosition = getIndexFromPosition(e.getPoint().x) + 1; - int secondPosition = model.getSecondPosition(); - if (firstPosition > secondPosition) { - firstPosition--; + tempFirstPos = getIndexFromPosition(e.getPoint().x) + 1; + tempSecondPos = model.getSecondPosition(); + if (tempFirstPos > tempSecondPos) { + tempFirstPos--; } - tempModel.setPositions(firstPosition, secondPosition); update(); } else if (state == State.DragSecondPosition) { - int firstPosition = model.getFirstPosition(); - int secondPosition = getIndexFromPosition(e.getPoint().x); - if (secondPosition < firstPosition) { - secondPosition++; + tempFirstPos = model.getFirstPosition(); + tempSecondPos = getIndexFromPosition(e.getPoint().x); + if (tempSecondPos < tempFirstPos) { + tempSecondPos++; } - tempModel.setPositions(firstPosition, secondPosition); update(); } } @@ -319,19 +322,19 @@ public class RangeSlider extends JComponent implements ChangedListener= startX && x <= endX) { return i; } } - return getPaintingModel().getPositions().size() - 1; + return model.getPositions().size() - 1; } private int getCircleIndexFromPosition(int x) { int result = 0; - for (int i = 1; i < getPaintingModel().getPositions().size(); i++) { + for (int i = 1; i < model.getPositions().size(); i++) { if (x > getStartXPosition(i)) { result = i; } @@ -345,8 +348,6 @@ public class RangeSlider extends JComponent implements ChangedListener { // Warning: Update setData method if fields are added - private ChangedEvent changedEvent; - private ChangedEvent colorChangedEvent; + private final ChangedEvent changedEvent; + private final ChangedEvent colorChangedEvent; private List positions; private int firstPosition; private int secondPosition; private List colors; public void setData(RangeSliderModel model) { - boolean changed = false; - changed |= (positions != model.positions); + boolean changed = (positions != model.positions); positions = model.positions; changed |= (firstPosition != model.firstPosition); firstPosition = model.firstPosition; diff --git a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/StringUtils.java b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/StringUtils.java index 9027c65bc41..dffa5cccf48 100644 --- a/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/StringUtils.java +++ b/src/utils/IdealGraphVisualizer/Util/src/main/java/com/sun/hotspot/igv/util/StringUtils.java @@ -117,7 +117,7 @@ public class StringUtils { * Rank a match of a query in a word. Full matches of a word rank highest, * followed by partial matches at the word start, followed by the rest of * matches in increasing size of the partially matched word, for example: - * + *

* rank("5", "5") = 1 (full match) * rank("5", "554") = 2 (start match) * rank("5", "25") = 3 (middle match with excess 1) diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/BlockQuickSearch.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/BlockQuickSearch.java index 09e0e452036..1e0f75dbd8c 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/BlockQuickSearch.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/BlockQuickSearch.java @@ -23,14 +23,14 @@ */ package com.sun.hotspot.igv.view; -import com.sun.hotspot.igv.data.InputGraph; import com.sun.hotspot.igv.data.InputBlock; +import com.sun.hotspot.igv.data.InputGraph; import com.sun.hotspot.igv.data.Properties.RegexpPropertyMatcher; import com.sun.hotspot.igv.data.services.InputGraphProvider; import com.sun.hotspot.igv.util.LookupHistory; import com.sun.hotspot.igv.util.StringUtils; -import java.util.List; import java.util.ArrayList; +import java.util.List; import java.util.regex.Pattern; import org.netbeans.spi.quicksearch.SearchProvider; import org.netbeans.spi.quicksearch.SearchRequest; diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramScene.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramScene.java index 35a2c312431..b290468b741 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramScene.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramScene.java @@ -40,7 +40,9 @@ import com.sun.hotspot.igv.view.actions.CustomizablePanAction; import com.sun.hotspot.igv.view.actions.MouseZoomAction; import com.sun.hotspot.igv.view.widgets.*; import java.awt.*; -import java.awt.event.*; +import java.awt.event.ActionEvent; +import java.awt.event.MouseEvent; +import java.awt.event.MouseWheelListener; import java.util.List; import java.util.*; import javax.swing.*; @@ -70,21 +72,24 @@ import org.openide.util.lookup.InstanceContent; */ public class DiagramScene extends ObjectScene implements DiagramViewer { - private CustomizablePanAction panAction; - private WidgetAction hoverAction; - private WidgetAction selectAction; - private Lookup lookup; - private InstanceContent content; - private Action[] actions; - private Action[] actionsWithSelection; - private LayerWidget connectionLayer; - private JScrollPane scrollPane; + private final CustomizablePanAction panAction; + private final WidgetAction hoverAction; + private final WidgetAction selectAction; + private final Lookup lookup; + private final InstanceContent content; + private final Action[] actions; + private final Action[] actionsWithSelection; + private final LayerWidget connectionLayer; + private final JScrollPane scrollPane; private UndoRedo.Manager undoRedoManager; - private LayerWidget mainLayer; - private LayerWidget blockLayer; + private final LayerWidget mainLayer; + private final LayerWidget blockLayer; private DiagramViewModel model; private DiagramViewModel modelCopy; private boolean rebuilding; + private boolean undoRedoEnabled = true; + + /** * The alpha level of partially visible figures. @@ -104,49 +109,21 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { public static final int SLOT_OFFSET = 8; public static final int ANIMATION_LIMIT = 40; - private PopupMenuProvider popupMenuProvider = new PopupMenuProvider() { - - @Override - public JPopupMenu getPopupMenu(Widget widget, Point localLocation) { - return DiagramScene.this.createPopupMenu(); - } - }; - - private RectangularSelectDecorator rectangularSelectDecorator = new RectangularSelectDecorator() { - - @Override - public Widget createSelectionWidget() { - Widget widget = new Widget(DiagramScene.this); - widget.setBorder(BorderFactory.createLineBorder(Color.black, 2)); - widget.setForeground(Color.red); - return widget; - } - }; - @SuppressWarnings("unchecked") public T getWidget(Object o) { - Widget w = this.findWidget(o); + Widget w = findWidget(o); return (T) w; } @SuppressWarnings("unchecked") public T getWidget(Object o, Class klass) { - Widget w = this.findWidget(o); + Widget w = findWidget(o); return (T) w; } - private static boolean intersects(Set s1, Set s2) { - for (Object o : s1) { - if (s2.contains(o)) { - return true; - } - } - return false; - } - public double getZoomMinFactor() { - double factorWidth = getScrollPane().getViewport().getViewRect().getWidth() / getBounds().getWidth() ; - double factorHeight = getScrollPane().getViewport().getViewRect().getHeight() / getBounds().getHeight(); + double factorWidth = scrollPane.getViewport().getViewRect().getWidth() / getBounds().getWidth() ; + double factorHeight = scrollPane.getViewport().getViewRect().getHeight() / getBounds().getHeight(); double zoomToFit = 0.98 * Math.min(factorWidth, factorHeight); return Math.min(zoomToFit, ZOOM_MIN_FACTOR); } @@ -213,94 +190,35 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { @Override public void centerFigures(List

list) { - - boolean b = getUndoRedoEnabled(); - setUndoRedoEnabled(false); + boolean enableUndoRedo = undoRedoEnabled; + undoRedoEnabled = false; gotoFigures(list); - setUndoRedoEnabled(b); + undoRedoEnabled = enableUndoRedo; } - private Set getObjectsFromIdSet(Set set) { - Set selectedObjects = new HashSet<>(); - for (Figure f : getModel().getDiagramToView().getFigures()) { - if (intersects(f.getSource().getSourceNodesAsSet(), set)) { - selectedObjects.add(f); - } - - for (Slot s : f.getSlots()) { - if (intersects(s.getSource().getSourceNodesAsSet(), set)) { - selectedObjects.add(s); - } - } - } - return selectedObjects; - } - private ControllableChangedListener highlightedCoordinatorListener = new ControllableChangedListener() { + private final ControllableChangedListener highlightedCoordinatorListener = new ControllableChangedListener() { @Override public void filteredChanged(SelectionCoordinator source) { - DiagramScene.this.setHighlightedObjects(getObjectsFromIdSet(source.getHighlightedObjects())); - DiagramScene.this.validate(); + setHighlightedObjects(idSetToObjectSet(source.getHighlightedObjects())); + validate(); } }; - private ControllableChangedListener selectedCoordinatorListener = new ControllableChangedListener() { + private final ControllableChangedListener selectedCoordinatorListener = new ControllableChangedListener() { @Override public void filteredChanged(SelectionCoordinator source) { - DiagramScene.this.gotoSelection(source.getSelectedObjects()); - DiagramScene.this.validate(); + gotoSelection(source.getSelectedObjects()); + validate(); } }; - private RectangularSelectProvider rectangularSelectProvider = new RectangularSelectProvider() { - - @Override - public void performSelection(Rectangle rectangle) { - if (rectangle.width < 0) { - rectangle.x += rectangle.width; - rectangle.width *= -1; - } - - if (rectangle.height < 0) { - rectangle.y += rectangle.height; - rectangle.height *= -1; - } - - Set selectedObjects = new HashSet<>(); - for (Figure f : getModel().getDiagramToView().getFigures()) { - FigureWidget w = getWidget(f); - if (w != null) { - Rectangle r = new Rectangle(w.getBounds()); - r.setLocation(w.getLocation()); - - if (r.intersects(rectangle)) { - selectedObjects.add(f); - } - - for (Slot s : f.getSlots()) { - SlotWidget sw = getWidget(s); - Rectangle r2 = new Rectangle(sw.getBounds()); - r2.setLocation(sw.convertLocalToScene(new Point(0, 0))); - - if (r2.intersects(rectangle)) { - selectedObjects.add(s); - } - } - } else { - assert false : "w should not be null here!"; - } - } - - setSelectedObjects(selectedObjects); - } - }; - - public Point getScrollPosition() { - return getScrollPane().getViewport().getViewPosition(); + private Point getScrollPosition() { + return scrollPane.getViewport().getViewPosition(); } - public void setScrollPosition(Point p) { - getScrollPane().getViewport().setViewPosition(p); + private void setScrollPosition(Point p) { + scrollPane.getViewport().setViewPosition(p); } private JScrollPane createScrollPane(MouseZoomAction mouseZoomAction) { @@ -334,104 +252,15 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { scrollPane.addMouseWheelListener(mouseZoomAction); return scrollPane; } - private ObjectSceneListener selectionChangedListener = new ObjectSceneListener() { - - @Override - public void objectAdded(ObjectSceneEvent arg0, Object arg1) { - } - - @Override - public void objectRemoved(ObjectSceneEvent arg0, Object arg1) { - } - - @Override - public void objectStateChanged(ObjectSceneEvent e, Object o, ObjectState oldState, ObjectState newState) { - } - - @Override - public void selectionChanged(ObjectSceneEvent e, Set oldSet, Set newSet) { - DiagramScene scene = (DiagramScene) e.getObjectScene(); - if (scene.isRebuilding()) { - return; - } - - content.set(newSet, null); - - Set nodeSelection = new HashSet<>(); - for (Object o : newSet) { - if (o instanceof Properties.Provider) { - final Properties.Provider provider = (Properties.Provider) o; - AbstractNode node = new AbstractNode(Children.LEAF) { - - @Override - protected Sheet createSheet() { - Sheet s = super.createSheet(); - PropertiesSheet.initializeSheet(provider.getProperties(), s); - return s; - } - }; - node.setDisplayName(provider.getProperties().get("name")); - content.add(node); - } - - - if (o instanceof Figure) { - nodeSelection.addAll(((Figure) o).getSource().getSourceNodesAsSet()); - } else if (o instanceof Slot) { - nodeSelection.addAll(((Slot) o).getSource().getSourceNodesAsSet()); - } - } - getModel().setSelectedNodes(nodeSelection); - - boolean b = selectedCoordinatorListener.isEnabled(); - selectedCoordinatorListener.setEnabled(false); - SelectionCoordinator.getInstance().setSelectedObjects(nodeSelection); - selectedCoordinatorListener.setEnabled(b); - - } - - @Override - public void highlightingChanged(ObjectSceneEvent e, Set oldSet, Set newSet) { - Set nodeHighlighting = new HashSet<>(); - for (Object o : newSet) { - if (o instanceof Figure) { - nodeHighlighting.addAll(((Figure) o).getSource().getSourceNodesAsSet()); - } else if (o instanceof Slot) { - nodeHighlighting.addAll(((Slot) o).getSource().getSourceNodesAsSet()); - } - } - boolean b = highlightedCoordinatorListener.isEnabled(); - highlightedCoordinatorListener.setEnabled(false); - SelectionCoordinator.getInstance().setHighlightedObjects(nodeHighlighting); - highlightedCoordinatorListener.setEnabled(true); - } - - @Override - public void hoverChanged(ObjectSceneEvent e, Object oldObject, Object newObject) { - Set newHighlightedObjects = new HashSet<>(DiagramScene.this.getHighlightedObjects()); - if (oldObject != null) { - newHighlightedObjects.remove(oldObject); - } - if (newObject != null) { - newHighlightedObjects.add(newObject); - } - DiagramScene.this.setHighlightedObjects(newHighlightedObjects); - } - - @Override - public void focusChanged(ObjectSceneEvent arg0, Object arg1, Object arg2) { - } - }; public DiagramScene(Action[] actions, Action[] actionsWithSelection, DiagramViewModel model) { - this.actions = actions; this.actionsWithSelection = actionsWithSelection; content = new InstanceContent(); lookup = new AbstractLookup(content); - this.setCheckClipping(true); + setCheckClipping(true); MouseZoomAction mouseZoomAction = new MouseZoomAction(this); scrollPane = createScrollPane(mouseZoomAction); @@ -442,7 +271,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { // pressed without any modifier keys, otherwise it will not consume it // and the selection action (below) will handle the event panAction = new CustomizablePanAction(MouseEvent.BUTTON1_DOWN_MASK); - this.getActions().addAction(panAction); + getActions().addAction(panAction); selectAction = new CustomSelectAction(new SelectProvider() { public boolean isAimingAllowed(Widget widget, Point localLocation, boolean invertSelection) { @@ -471,41 +300,167 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } }); - this.getActions().addAction(selectAction); + getActions().addAction(selectAction); blockLayer = new LayerWidget(this); - this.addChild(blockLayer); + addChild(blockLayer); connectionLayer = new LayerWidget(this); - this.addChild(connectionLayer); + addChild(connectionLayer); mainLayer = new LayerWidget(this); - this.addChild(mainLayer); + addChild(mainLayer); - this.setBorder(BorderFactory.createLineBorder(Color.white, BORDER_SIZE)); - this.setLayout(LayoutFactory.createAbsoluteLayout()); - this.getActions().addAction(mouseZoomAction); - this.getActions().addAction(ActionFactory.createPopupMenuAction(popupMenuProvider)); + setBorder(BorderFactory.createLineBorder(Color.white, BORDER_SIZE)); + setLayout(LayoutFactory.createAbsoluteLayout()); + getActions().addAction(mouseZoomAction); + getActions().addAction(ActionFactory.createPopupMenuAction((widget, localLocation) -> createPopupMenu())); LayerWidget selectLayer = new LayerWidget(this); - this.addChild(selectLayer); - this.getActions().addAction(ActionFactory.createRectangularSelectAction(rectangularSelectDecorator, selectLayer, rectangularSelectProvider)); + addChild(selectLayer); + RectangularSelectDecorator rectangularSelectDecorator = () -> { + Widget widget = new Widget(DiagramScene.this); + widget.setBorder(BorderFactory.createLineBorder(Color.black, 2)); + widget.setForeground(Color.red); + return widget; + }; + RectangularSelectProvider rectangularSelectProvider = rectangle -> { + if (rectangle.width < 0) { + rectangle.x += rectangle.width; + rectangle.width *= -1; + } - boolean b = this.getUndoRedoEnabled(); - this.setUndoRedoEnabled(false); - this.setNewModel(model); - this.setUndoRedoEnabled(b); - this.addObjectSceneListener(selectionChangedListener, ObjectSceneEventType.OBJECT_SELECTION_CHANGED, ObjectSceneEventType.OBJECT_HIGHLIGHTING_CHANGED, ObjectSceneEventType.OBJECT_HOVER_CHANGED); + if (rectangle.height < 0) { + rectangle.y += rectangle.height; + rectangle.height *= -1; + } + + Set selectedObjects = new HashSet<>(); + for (Figure f : getModel().getDiagram().getFigures()) { + FigureWidget w = getWidget(f); + if (w != null) { + assert w.getBounds() != null; + Rectangle r = new Rectangle(w.getBounds()); + r.setLocation(w.getLocation()); + + if (r.intersects(rectangle)) { + selectedObjects.add(f); + } + + for (Slot s : f.getSlots()) { + SlotWidget sw = getWidget(s); + assert sw.getBounds() != null; + Rectangle r2 = new Rectangle(sw.getBounds()); + r2.setLocation(sw.convertLocalToScene(new Point(0, 0))); + + if (r2.intersects(rectangle)) { + selectedObjects.add(s); + } + } + } else { + assert false : "w should not be null here!"; + } + } + + setSelectedObjects(selectedObjects); + }; + getActions().addAction(ActionFactory.createRectangularSelectAction(rectangularSelectDecorator, selectLayer, rectangularSelectProvider)); + + boolean enableUndoRedo = undoRedoEnabled; + undoRedoEnabled = false; + setNewModel(model); + undoRedoEnabled = enableUndoRedo; + ObjectSceneListener selectionChangedListener = new ObjectSceneListener() { + + @Override + public void objectAdded(ObjectSceneEvent arg0, Object arg1) {} + + @Override + public void objectRemoved(ObjectSceneEvent arg0, Object arg1) {} + + @Override + public void objectStateChanged(ObjectSceneEvent e, Object o, ObjectState oldState, ObjectState newState) {} + + @Override + public void selectionChanged(ObjectSceneEvent e, Set oldSet, Set newSet) { + DiagramScene scene = (DiagramScene) e.getObjectScene(); + if (scene.isRebuilding()) { + return; + } + + content.set(newSet, null); + + Set nodeSelection = new HashSet<>(); + for (Object o : newSet) { + if (o instanceof Properties.Provider) { + final Properties.Provider provider = (Properties.Provider) o; + AbstractNode node = new AbstractNode(Children.LEAF) { + + @Override + protected Sheet createSheet() { + Sheet s = super.createSheet(); + PropertiesSheet.initializeSheet(provider.getProperties(), s); + return s; + } + }; + node.setDisplayName(provider.getProperties().get("name")); + content.add(node); + } + + + if (o instanceof Figure) { + nodeSelection.add(((Figure) o).getInputNode().getId()); + } else if (o instanceof Slot) { + nodeSelection.addAll(((Slot) o).getSource().getSourceNodesAsSet()); + } + } + getModel().setSelectedNodes(nodeSelection); + + boolean b = selectedCoordinatorListener.isEnabled(); + selectedCoordinatorListener.setEnabled(false); + SelectionCoordinator.getInstance().setSelectedObjects(nodeSelection); + selectedCoordinatorListener.setEnabled(b); + + } + + @Override + public void highlightingChanged(ObjectSceneEvent e, Set oldSet, Set newSet) { + Set nodeHighlighting = new HashSet<>(); + for (Object o : newSet) { + if (o instanceof Figure) { + nodeHighlighting.add(((Figure) o).getInputNode().getId()); + } else if (o instanceof Slot) { + nodeHighlighting.addAll(((Slot) o).getSource().getSourceNodesAsSet()); + } + } + highlightedCoordinatorListener.setEnabled(false); + SelectionCoordinator.getInstance().setHighlightedObjects(nodeHighlighting); + highlightedCoordinatorListener.setEnabled(true); + } + + @Override + public void hoverChanged(ObjectSceneEvent e, Object oldObject, Object newObject) { + Set newHighlightedObjects = new HashSet<>(getHighlightedObjects()); + if (oldObject != null) { + newHighlightedObjects.remove(oldObject); + } + if (newObject != null) { + newHighlightedObjects.add(newObject); + } + setHighlightedObjects(newHighlightedObjects); + } + + @Override + public void focusChanged(ObjectSceneEvent arg0, Object arg1, Object arg2) { + } + }; + addObjectSceneListener(selectionChangedListener, ObjectSceneEventType.OBJECT_SELECTION_CHANGED, ObjectSceneEventType.OBJECT_HIGHLIGHTING_CHANGED, ObjectSceneEventType.OBJECT_HOVER_CHANGED); } public DiagramViewModel getModel() { return model; } - public JScrollPane getScrollPane() { - return scrollPane; - } - @Override public Component getComponent() { return scrollPane; @@ -524,7 +479,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { if (f.getCluster() != null) { name += "B" + f.getCluster().toString(); } - final boolean hidden = !this.getWidget(f, FigureWidget.class).isVisible(); + final boolean hidden = !getWidget(f, FigureWidget.class).isVisible(); if (hidden) { if (f.getCluster() != null) { name += ", "; @@ -557,7 +512,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { return a; } - public void setNewModel(DiagramViewModel model) { + private void setNewModel(DiagramViewModel model) { assert this.model == null : "can set model only once!"; this.model = model; this.modelCopy = null; @@ -575,31 +530,30 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { rebuilding = true; - Collection objects = new ArrayList<>(this.getObjects()); + Collection objects = new ArrayList<>(getObjects()); for (Object o : objects) { - this.removeObject(o); + removeObject(o); } - Diagram d = getModel().getDiagramToView(); + Diagram d = getModel().getDiagram(); Map maxWidth = new HashMap<>(); - for (InputBlock b : d.getGraph().getBlocks()) { + for (InputBlock b : d.getInputBlocks()) { maxWidth.put(b, 10); } for (Figure f : d.getFigures()) { // Update node text, since it might differ across views. f.updateLines(); // Compute max node width in each block. - if (f.getWidth() > maxWidth.get(f.getBlock())) { - maxWidth.put(f.getBlock(), f.getWidth()); + if (f.getWidth() > maxWidth.get(f.getBlock().getInputBlock())) { + maxWidth.put(f.getBlock().getInputBlock(), f.getWidth()); } } for (Figure f : d.getFigures()) { - // Set all nodes' width to the maximum width in the blocks? if (getModel().getShowCFG()) { - f.setWidth(maxWidth.get(f.getBlock())); + f.setWidth(maxWidth.get(f.getBlock().getInputBlock())); } FigureWidget w = new FigureWidget(f, hoverAction, selectAction, this, mainLayer); @@ -608,7 +562,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { w.getActions().addAction(hoverAction); w.setVisible(false); - this.addObject(f, w); + addObject(f, w); for (InputSlot s : f.getInputSlots()) { SlotWidget sw = new InputSlotWidget(s, this, w, w); @@ -628,28 +582,28 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } if (getModel().getShowBlocks() || getModel().getShowCFG()) { - for (InputBlock bn : d.getGraph().getBlocks()) { + for (InputBlock bn : d.getInputBlocks()) { BlockWidget w = new BlockWidget(this, d, bn); w.setVisible(false); - this.addObject(bn, w); + addObject(bn, w); blockLayer.addChild(w); } } rebuilding = false; - this.smallUpdate(true); + smallUpdate(true); } - public boolean isRebuilding() { + protected boolean isRebuilding() { return rebuilding; } private void smallUpdate(boolean relayout) { - this.updateHiddenNodes(model.getHiddenNodes(), relayout); - boolean b = this.getUndoRedoEnabled(); - this.setUndoRedoEnabled(false); - this.setUndoRedoEnabled(b); - this.validate(); + updateHiddenNodes(model.getHiddenNodes(), relayout); + boolean enableUndoRedo = undoRedoEnabled; + undoRedoEnabled = false; + undoRedoEnabled = enableUndoRedo; + validate(); } private boolean isVisible(Connection c) { @@ -672,7 +626,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } private void relayout(Set oldVisibleWidgets) { - Diagram diagram = getModel().getDiagramToView(); + Diagram diagram = getModel().getDiagram(); HashSet
figures = new HashSet<>(); @@ -694,7 +648,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { if (getModel().getShowSea()) { doSeaLayout(figures, edges); } else if (getModel().getShowBlocks()) { - doClusteredLayout(figures, edges); + doClusteredLayout(edges); } else if (getModel().getShowCFG()) { doCFGLayout(figures, edges); } @@ -708,18 +662,18 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { manager.doLayout(new LayoutGraph(edges, figures)); } - private void doClusteredLayout(HashSet
figures, HashSet edges) { + private void doClusteredLayout(HashSet edges) { HierarchicalClusterLayoutManager m = new HierarchicalClusterLayoutManager(HierarchicalLayoutManager.Combine.SAME_OUTPUTS); HierarchicalLayoutManager manager = new HierarchicalLayoutManager(HierarchicalLayoutManager.Combine.SAME_OUTPUTS); manager.setMaxLayerLength(9); manager.setMinLayerDifference(3); m.setManager(manager); m.setSubManager(new HierarchicalLayoutManager(HierarchicalLayoutManager.Combine.SAME_OUTPUTS)); - m.doLayout(new LayoutGraph(edges, figures)); + m.doLayout(new LayoutGraph(edges)); } private void doCFGLayout(HashSet
figures, HashSet edges) { - Diagram diagram = getModel().getDiagramToView(); + Diagram diagram = getModel().getDiagram(); HierarchicalCFGLayoutManager m = new HierarchicalCFGLayoutManager(); HierarchicalLayoutManager manager = new HierarchicalLayoutManager(HierarchicalLayoutManager.Combine.SAME_OUTPUTS); manager.setMaxLayerLength(9); @@ -728,9 +682,9 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { manager.setXOffset(25); manager.setLayerOffset(25); m.setManager(manager); - Map nodeFig = new HashMap(); + Map nodeFig = new HashMap<>(); for (Figure f : figures) { - InputNode n = f.getFirstSourceNode(); + InputNode n = f.getInputNode(); if (n != null) { nodeFig.put(n, f); } @@ -738,10 +692,9 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { // Compute global ranking among figures given by in-block order. If // needed, this could be cached as long as it is computed for all the // figures in the model, not just the visible ones. - Map figureRank = - new HashMap(figures.size()); + Map figureRank = new HashMap<>(figures.size()); int r = 0; - for (InputBlock b : getModel().getGraphToView().getBlocks()) { + for (InputBlock b : diagram.getInputBlocks()) { for (InputNode n : b.getNodes()) { Figure f = nodeFig.get(n); if (f != null) { @@ -772,9 +725,9 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { private void relayoutWithoutLayout(Set oldVisibleWidgets) { - Diagram diagram = getModel().getDiagramToView(); + Diagram diagram = getModel().getDiagram(); - SceneAnimator animator = this.getSceneAnimator(); + SceneAnimator animator = getSceneAnimator(); connectionLayer.removeChildren(); int visibleFigureCount = 0; for (Figure f : diagram.getFigures()) { @@ -839,11 +792,11 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } } - this.validate(); + validate(); } private final Point specialNullPoint = new Point(Integer.MAX_VALUE, Integer.MAX_VALUE); - private void processOutputSlot(Set> lastLineCache, OutputSlot s, List connections, int controlPointIndex, Point lastPoint, LineWidget predecessor, int offx, int offy, SceneAnimator animator) { + private void processOutputSlot(Set> lastLineCache, OutputSlot outputSlot, List connections, int controlPointIndex, Point lastPoint, LineWidget predecessor, int offx, int offy, SceneAnimator animator) { Map> pointMap = new HashMap<>(connections.size()); for (Connection c : connections) { @@ -861,7 +814,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { if (cur == null) { // Long connection, has been cut vertically. cur = specialNullPoint; } else if (c.hasSlots()) { - if (controlPointIndex == 0 && !s.shouldShowName()) { + if (controlPointIndex == 0 && !outputSlot.shouldShowName()) { cur = new Point(cur.x, cur.y - SLOT_OFFSET); } else if (controlPointIndex == controlPoints.size() - 1 && !((Slot)c.getTo()).shouldShowName()) { @@ -902,9 +855,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } LineWidget newPredecessor = predecessor; - if (p == specialNullPoint) { - } else if (lastPoint == specialNullPoint) { - } else if (lastPoint != null) { + if (p != specialNullPoint && lastPoint != specialNullPoint && lastPoint != null) { Point p1 = new Point(lastPoint.x + offx, lastPoint.y + offy); Point p2 = new Point(p.x + offx, p.y + offy); @@ -913,17 +864,17 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { if (lastLineCache.contains(curPair)) { curAnimator = null; } - LineWidget w = new LineWidget(this, s, connectionList, p1, p2, predecessor, curAnimator, isBold, isDashed); - w.setVisible(isVisible); + LineWidget lineWidget = new LineWidget(this, outputSlot, connectionList, p1, p2, predecessor, curAnimator, isBold, isDashed); + lineWidget.setVisible(isVisible); lineCache.add(curPair); - newPredecessor = w; - connectionLayer.addChild(w); - this.addObject(new ConnectionSet(connectionList), w); - w.getActions().addAction(hoverAction); + newPredecessor = lineWidget; + connectionLayer.addChild(lineWidget); + addObject(new ConnectionSet(connectionList), lineWidget); + lineWidget.getActions().addAction(hoverAction); } - processOutputSlot(lastLineCache, s, connectionList, controlPointIndex + 1, p, newPredecessor, offx, offy, animator); + processOutputSlot(lastLineCache, outputSlot, connectionList, controlPointIndex + 1, p, newPredecessor, offx, offy, animator); } } @@ -952,7 +903,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { return lookup; } - public void gotoFigures(final List
figures) { + private void gotoFigures(final List
figures) { Rectangle overall = null; getModel().showFigures(figures); for (Figure f : figures) { @@ -961,6 +912,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { if (fw != null) { Rectangle r = fw.getBounds(); Point p = fw.getLocation(); + assert r != null; Rectangle r2 = new Rectangle(p.x, p.y, r.width, r.height); if (overall == null) { @@ -975,23 +927,22 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } } - public void gotoBlock(final Block block) { + private void gotoBlock(final Block block) { BlockWidget bw = getWidget(block.getInputBlock()); if (bw != null) { centerRectangle(bw.getBounds()); } } - private Set idSetToObjectSet(Set ids) { - + private Set idSetToObjectSet(Set ids) { Set result = new HashSet<>(); - for (Figure f : getModel().getDiagramToView().getFigures()) { - if (DiagramScene.doesIntersect(f.getSource().getSourceNodesAsSet(), ids)) { + for (Figure f : getModel().getDiagram().getFigures()) { + if (ids.contains(f.getInputNode().getId())) { result.add(f); } for (Slot s : f.getSlots()) { - if (DiagramScene.doesIntersect(s.getSource().getSourceNodesAsSet(), ids)) { + if (!Collections.disjoint(s.getSource().getSourceNodesAsSet(), ids)) { result.add(s); } } @@ -999,12 +950,12 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { return result; } - public void gotoSelection(Set ids) { + private void gotoSelection(Set ids) { Rectangle overall = null; - Set hiddenNodes = new HashSet<>(this.getModel().getHiddenNodes()); + Set hiddenNodes = new HashSet<>(getModel().getHiddenNodes()); hiddenNodes.removeAll(ids); - this.getModel().showNot(hiddenNodes); + getModel().setHiddenNodes(hiddenNodes); Set objects = idSetToObjectSet(ids); for (Object o : objects) { @@ -1014,6 +965,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { Rectangle r = w.getBounds(); Point p = w.convertLocalToScene(new Point(0, 0)); + assert r != null; Rectangle r2 = new Rectangle(p.x, p.y, r.width, r.height); if (overall == null) { @@ -1032,7 +984,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { private void centerRectangle(Rectangle r) { Rectangle rect = convertSceneToView(r); - Rectangle viewRect = getScrollPane().getViewport().getViewRect(); + Rectangle viewRect = scrollPane.getViewport().getViewRect(); double factor = Math.min(viewRect.getWidth() / rect.getWidth(), viewRect.getHeight() / rect.getHeight()); if (factor < 1.0) { centredZoom(getZoomFactor() * factor, null); @@ -1045,11 +997,10 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { viewRect.y = rect.y + rect.height / 2 - viewRect.height / 2; // Ensure to be within area viewRect.x = Math.max(0, viewRect.x); - viewRect.x = Math.min(getScrollPane().getViewport().getViewSize().width - viewRect.width, viewRect.x); + viewRect.x = Math.min(scrollPane.getViewport().getViewSize().width - viewRect.width, viewRect.x); viewRect.y = Math.max(0, viewRect.y); - viewRect.y = Math.min(getScrollPane().getViewport().getViewSize().height - viewRect.height, viewRect.y); + viewRect.y = Math.min(scrollPane.getViewport().getViewSize().height - viewRect.height, viewRect.y); getView().scrollRectToVisible(viewRect); - } @Override @@ -1072,28 +1023,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } private boolean isVisible(Figure f) { - for (Integer n : f.getSource().getSourceNodesAsSet()) { - if (getModel().getHiddenNodes().contains(n)) { - return false; - } - } - return true; - } - - public static boolean doesIntersect(Set s1, Set s2) { - if (s1.size() > s2.size()) { - Set tmp = s1; - s1 = s2; - s2 = tmp; - } - - for (Object o : s1) { - if (s2.contains(o)) { - return true; - } - } - - return false; + return !getModel().getHiddenNodes().contains(f.getInputNode().getId()); } @Override @@ -1110,10 +1040,10 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { private void updateHiddenNodes(Set newHiddenNodes, boolean doRelayout) { - Diagram diagram = getModel().getDiagramToView(); + Diagram diagram = getModel().getDiagram(); assert diagram != null; - Set visibleBlocks = new HashSet(); + Set visibleBlocks = new HashSet<>(); Set oldVisibleWidgets = new HashSet<>(); for (Figure f : diagram.getFigures()) { @@ -1124,7 +1054,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } if (getModel().getShowBlocks() || getModel().getShowCFG()) { - for (InputBlock b : diagram.getGraph().getBlocks()) { + for (InputBlock b : diagram.getInputBlocks()) { BlockWidget w = getWidget(b); if (w.isVisible()) { oldVisibleWidgets.add(w); @@ -1133,19 +1063,15 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { } for (Figure f : diagram.getFigures()) { - boolean hiddenAfter = doesIntersect(f.getSource().getSourceNodesAsSet(), newHiddenNodes); - FigureWidget w = getWidget(f); w.setBoundary(false); - if (!hiddenAfter) { - // Figure is shown - w.setVisible(true); - for (InputNode n : f.getSource().getSourceNodes()) { - visibleBlocks.add(diagram.getGraph().getBlock(n)); - } - } else { + if (newHiddenNodes.contains(f.getInputNode().getId())) { // Figure is hidden w.setVisible(false); + } else { + // Figure is shown + w.setVisible(true); + visibleBlocks.add(f.getBlock().getInputBlock()); } } @@ -1168,9 +1094,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { if (b) { w.setBoundary(true); - for (InputNode n : f.getSource().getSourceNodes()) { - visibleBlocks.add(diagram.getGraph().getBlock(n)); - } + visibleBlocks.add(f.getBlock().getInputBlock()); boundaries.add(w); } } @@ -1186,19 +1110,19 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { if (getModel().getShowCFG()) { // Blockless figures and artificial blocks are hidden in this view. for (Figure f : diagram.getFigures()) { - if (f.getBlock().isArtificial()) { + if (f.getBlock().getInputBlock().isArtificial()) { FigureWidget w = getWidget(f); w.setVisible(false); } } if (getModel().getShowEmptyBlocks()) { // Add remaining blocks. - visibleBlocks.addAll(diagram.getGraph().getBlocks()); + visibleBlocks.addAll(diagram.getInputBlocks()); } } if (getModel().getShowBlocks() || getModel().getShowCFG()) { - for (InputBlock b : diagram.getGraph().getBlocks()) { + for (InputBlock b : diagram.getInputBlocks()) { // A block is visible if it is marked as such, except for // artificial or null blocks in the CFG view. @@ -1206,44 +1130,27 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { !(getModel().getShowCFG() && (b.isArtificial() || b.getNodes().isEmpty())); BlockWidget w = getWidget(b); - if (visibleAfter) { - // Block must be shown - w.setVisible(true); - } else { - // Block must be hidden - w.setVisible(false); - } + w.setVisible(visibleAfter); } } if (doRelayout) { relayout(oldVisibleWidgets); } - this.validate(); + validate(); addUndo(); } private void showFigure(Figure f) { HashSet newHiddenNodes = new HashSet<>(getModel().getHiddenNodes()); - newHiddenNodes.removeAll(f.getSource().getSourceNodesAsSet()); - this.model.setHiddenNodes(newHiddenNodes); - } - - public void show(final Figure f) { - showFigure(f); - } - - public void setSelectedObjects(Object... args) { - Set set = new HashSet<>(); - for (Object o : args) { - set.add(o); - } - super.setSelectedObjects(set); + newHiddenNodes.remove(f.getInputNode().getId()); + getModel().setHiddenNodes(newHiddenNodes); } private void centerWidget(Widget w) { Rectangle r = w.getBounds(); Point p = w.getLocation(); + assert r != null; centerRectangle(new Rectangle(p.x, p.y, r.width, r.height)); } @@ -1255,7 +1162,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { FigureWidget fw = getWidget(f); if (fw != null) { centerWidget(fw); - setSelection(Arrays.asList(f)); + setSelection(Collections.singletonList(f)); } } @@ -1263,7 +1170,7 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { JPopupMenu menu = new JPopupMenu(); Action[] currentActions = actionsWithSelection; - if (this.getSelectedObjects().isEmpty()) { + if (getSelectedObjects().isEmpty()) { currentActions = actions; } for (Action a : currentActions) { @@ -1278,10 +1185,10 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { private static class DiagramUndoRedo extends AbstractUndoableEdit implements ChangedListener { - private DiagramViewModel oldModel; - private DiagramViewModel newModel; - private Point oldScrollPosition; - private DiagramScene scene; + private final DiagramViewModel oldModel; + private final DiagramViewModel newModel; + private final Point oldScrollPosition; + private final DiagramScene scene; public DiagramUndoRedo(DiagramScene scene, Point oldScrollPosition, DiagramViewModel oldModel, DiagramViewModel newModel) { assert oldModel != null; @@ -1295,53 +1202,35 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { @Override public void redo() throws CannotRedoException { super.redo(); - boolean b = scene.getUndoRedoEnabled(); - scene.setUndoRedoEnabled(false); + boolean enableUndoRedo = scene.undoRedoEnabled; + scene.undoRedoEnabled = false; scene.getModel().getViewChangedEvent().addListener(this); scene.getModel().setData(newModel); scene.getModel().getViewChangedEvent().removeListener(this); - scene.setUndoRedoEnabled(b); + scene.undoRedoEnabled = enableUndoRedo; + } @Override public void undo() throws CannotUndoException { super.undo(); - boolean b = scene.getUndoRedoEnabled(); - scene.setUndoRedoEnabled(false); + boolean enableUndoRedo = scene.undoRedoEnabled; + scene.undoRedoEnabled = false; scene.getModel().getViewChangedEvent().addListener(this); scene.getModel().setData(oldModel); scene.getModel().getViewChangedEvent().removeListener(this); - SwingUtilities.invokeLater(new Runnable() { + SwingUtilities.invokeLater(() -> scene.setScrollPosition(oldScrollPosition)); - @Override - public void run() { - scene.setScrollPosition(oldScrollPosition); - } - }); - - scene.setUndoRedoEnabled(b); + scene.undoRedoEnabled = enableUndoRedo; } @Override public void changed(DiagramViewModel source) { scene.getModel().getViewChangedEvent().removeListener(this); - if (oldModel.getHiddenNodes().equals(newModel.getHiddenNodes())) { - scene.smallUpdate(false); - } else { - scene.smallUpdate(true); - } + scene.smallUpdate(!oldModel.getHiddenNodes().equals(newModel.getHiddenNodes())); } } - private boolean undoRedoEnabled = true; - - public void setUndoRedoEnabled(boolean b) { - this.undoRedoEnabled = b; - } - - public boolean getUndoRedoEnabled() { - return undoRedoEnabled; - } private final ChangedListener fullChange = new ChangedListener() { @Override @@ -1372,13 +1261,10 @@ public class DiagramScene extends ObjectScene implements DiagramViewer { private void addUndo() { - DiagramViewModel newModelCopy = model.copy(); - if (undoRedoEnabled) { - this.getUndoRedoManager().undoableEditHappened(new UndoableEditEvent(this, new DiagramUndoRedo(this, this.getScrollPosition(), modelCopy, newModelCopy))); + getUndoRedoManager().undoableEditHappened(new UndoableEditEvent(this, new DiagramUndoRedo(this, getScrollPosition(), modelCopy, newModelCopy))); } - - this.modelCopy = newModelCopy; + modelCopy = newModelCopy; } } diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramViewModel.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramViewModel.java index 1a0b2b70b97..15e3ba8c395 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramViewModel.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramViewModel.java @@ -24,6 +24,7 @@ */ package com.sun.hotspot.igv.view; +import com.sun.hotspot.igv.data.Properties; import com.sun.hotspot.igv.data.*; import com.sun.hotspot.igv.data.services.Scheduler; import com.sun.hotspot.igv.difference.Difference; @@ -35,14 +36,8 @@ import com.sun.hotspot.igv.graph.MatcherSelector; import com.sun.hotspot.igv.settings.Settings; import com.sun.hotspot.igv.util.RangeSliderModel; import java.awt.Color; +import java.util.*; import org.openide.util.Lookup; -import java.util.Arrays; -import java.util.ArrayList; -import java.util.Collection; -import java.util.HashSet; -import java.util.Iterator; -import java.util.List; -import java.util.Set; /** * @@ -54,33 +49,27 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene private Group group; private ArrayList graphs; private Set hiddenNodes; - private Set onScreenNodes; private Set selectedNodes; private FilterChain filterChain; private FilterChain sequenceFilterChain; private Diagram diagram; - private InputGraph inputGraph; - private ChangedEvent diagramChangedEvent; - private ChangedEvent viewChangedEvent; - private ChangedEvent hiddenNodesChangedEvent; - private ChangedEvent viewPropertiesChangedEvent; + private InputGraph cachedInputGraph; + private final ChangedEvent diagramChangedEvent; + private final ChangedEvent viewChangedEvent; + private final ChangedEvent hiddenNodesChangedEvent; + private final ChangedEvent viewPropertiesChangedEvent; private boolean showSea; private boolean showBlocks; private boolean showCFG; private boolean showNodeHull; private boolean showEmptyBlocks; private boolean hideDuplicates; - private ChangedListener filterChainChangedListener = new ChangedListener() { - @Override - public void changed(FilterChain source) { - diagramChanged(); - } - }; + private final ChangedListener filterChainChangedListener = source -> updateDiagram(); @Override public DiagramViewModel copy() { - DiagramViewModel result = new DiagramViewModel(group, filterChain, sequenceFilterChain); + DiagramViewModel result = new DiagramViewModel(cachedInputGraph, filterChain, sequenceFilterChain); result.setData(this); return result; } @@ -91,9 +80,6 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene public void setData(DiagramViewModel newModel) { super.setData(newModel); - boolean diagramChanged = false; - boolean viewChanged = false; - boolean viewPropertiesChanged = false; if (group != newModel.group) { if (group != null) { @@ -106,26 +92,27 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene filterGraphs(); } - diagramChanged |= (filterChain != newModel.filterChain); - this.filterChain = newModel.filterChain; + boolean diagramChanged = filterChain != newModel.filterChain; diagramChanged |= (sequenceFilterChain != newModel.sequenceFilterChain); - this.sequenceFilterChain = newModel.sequenceFilterChain; diagramChanged |= (diagram != newModel.diagram); - this.diagram = newModel.diagram; - viewChanged |= (hiddenNodes != newModel.hiddenNodes); - this.hiddenNodes = newModel.hiddenNodes; - viewChanged |= (onScreenNodes != newModel.onScreenNodes); - this.onScreenNodes = newModel.onScreenNodes; + + boolean viewChanged = hiddenNodes != newModel.hiddenNodes; viewChanged |= (selectedNodes != newModel.selectedNodes); - this.selectedNodes = newModel.selectedNodes; - viewPropertiesChanged |= (showSea != newModel.showSea); - this.showSea = newModel.showSea; + + boolean viewPropertiesChanged = (showSea != newModel.showSea); viewPropertiesChanged |= (showBlocks != newModel.showBlocks); - this.showBlocks = newModel.showBlocks; viewPropertiesChanged |= (showCFG != newModel.showCFG); - this.showCFG = newModel.showCFG; viewPropertiesChanged |= (showNodeHull != newModel.showNodeHull); - this.showNodeHull = newModel.showNodeHull; + + filterChain = newModel.filterChain; + sequenceFilterChain = newModel.sequenceFilterChain; + diagram = newModel.diagram; + hiddenNodes = newModel.hiddenNodes; + selectedNodes = newModel.selectedNodes; + showSea = newModel.showSea; + showBlocks = newModel.showBlocks; + showCFG = newModel.showCFG; + showNodeHull = newModel.showNodeHull; if (diagramChanged) { diagramChangedEvent.fire(); @@ -198,15 +185,16 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene viewPropertiesChangedEvent.fire(); } - public DiagramViewModel(Group g, FilterChain filterChain, FilterChain sequenceFilterChain) { - super(Arrays.asList("default")); - this.showSea = Settings.get().getInt(Settings.DEFAULT_VIEW, Settings.DEFAULT_VIEW_DEFAULT) == Settings.DefaultView.SEA_OF_NODES; - this.showBlocks = Settings.get().getInt(Settings.DEFAULT_VIEW, Settings.DEFAULT_VIEW_DEFAULT) == Settings.DefaultView.CLUSTERED_SEA_OF_NODES; - this.showCFG = Settings.get().getInt(Settings.DEFAULT_VIEW, Settings.DEFAULT_VIEW_DEFAULT) == Settings.DefaultView.CONTROL_FLOW_GRAPH; - this.showNodeHull = true; - this.showEmptyBlocks = true; - this.group = g; + public DiagramViewModel(InputGraph graph, FilterChain filterChain, FilterChain sequenceFilterChain) { + super(Collections.singletonList("default")); + + showSea = Settings.get().getInt(Settings.DEFAULT_VIEW, Settings.DEFAULT_VIEW_DEFAULT) == Settings.DefaultView.SEA_OF_NODES; + showBlocks = Settings.get().getInt(Settings.DEFAULT_VIEW, Settings.DEFAULT_VIEW_DEFAULT) == Settings.DefaultView.CLUSTERED_SEA_OF_NODES; + showCFG = Settings.get().getInt(Settings.DEFAULT_VIEW, Settings.DEFAULT_VIEW_DEFAULT) == Settings.DefaultView.CONTROL_FLOW_GRAPH; + showNodeHull = true; + showEmptyBlocks = true; + group = graph.getGroup(); group.getChangedEvent().addListener(groupContentChangedListener); filterGraphs(); assert filterChain != null; @@ -214,7 +202,6 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene assert sequenceFilterChain != null; this.sequenceFilterChain = sequenceFilterChain; hiddenNodes = new HashSet<>(); - onScreenNodes = new HashSet<>(); selectedNodes = new HashSet<>(); super.getChangedEvent().addListener(this); diagramChangedEvent = new ChangedEvent<>(this); @@ -222,9 +209,10 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene hiddenNodesChangedEvent = new ChangedEvent<>(this); viewPropertiesChangedEvent = new ChangedEvent<>(this); - filterChain.getChangedEvent().addListener(filterChainChangedListener); sequenceFilterChain.getChangedEvent().addListener(filterChainChangedListener); + + selectGraph(graph); } private final ChangedListener groupContentChangedListener = new ChangedListener() { @@ -266,14 +254,10 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene return hiddenNodes; } - public Set getOnScreenNodes() { - return onScreenNodes; - } - public void setSelectedNodes(Set nodes) { this.selectedNodes = nodes; List colors = new ArrayList<>(); - for (String s : getPositions()) { + for (String ignored : getPositions()) { colors.add(Color.black); } if (nodes.size() >= 1) { @@ -311,14 +295,10 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene viewChangedEvent.fire(); } - public void showNot(final Set nodes) { - setHiddenNodes(nodes); - } - - public void showFigures(Collection
f) { + public void showFigures(Collection
figures) { HashSet newHiddenNodes = new HashSet<>(getHiddenNodes()); - for (Figure fig : f) { - newHiddenNodes.removeAll(fig.getSource().getSourceNodesAsSet()); + for (Figure f : figures) { + newHiddenNodes.remove(f.getInputNode().getId()); } setHiddenNodes(newHiddenNodes); } @@ -327,10 +307,8 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene public Set
getSelectedFigures() { Set
result = new HashSet<>(); for (Figure f : diagram.getFigures()) { - for (InputNode node : f.getSource().getSourceNodes()) { - if (getSelectedNodes().contains(node.getId())) { - result.add(f); - } + if (getSelectedNodes().contains(f.getInputNode().getId())) { + result.add(f); } } return result; @@ -341,7 +319,7 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene } public void showOnly(final Set nodes) { - final HashSet allNodes = new HashSet<>(getGraphToView().getGroup().getAllNodes()); + final HashSet allNodes = new HashSet<>(getGroup().getAllNodes()); allNodes.removeAll(nodes); setHiddenNodes(allNodes); } @@ -351,42 +329,40 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene hiddenNodesChangedEvent.fire(); } - public void setOnScreenNodes(Set onScreenNodes) { - this.onScreenNodes = onScreenNodes; - viewChangedEvent.fire(); - } - public FilterChain getSequenceFilterChain() { return filterChain; } - public void setSequenceFilterChain(FilterChain chain) { - assert chain != null : "sequenceFilterChain must never be null"; - sequenceFilterChain.getChangedEvent().removeListener(filterChainChangedListener); - sequenceFilterChain = chain; - sequenceFilterChain.getChangedEvent().addListener(filterChainChangedListener); - diagramChanged(); - } - - private void diagramChanged() { + private void updateDiagram() { // clear diagram - diagram = null; - getDiagramChangedEvent().fire(); + InputGraph graph = getGraph(); + if (graph.getBlocks().isEmpty()) { + Scheduler s = Lookup.getDefault().lookup(Scheduler.class); + graph.clearBlocks(); + s.schedule(graph); + graph.ensureNodesInBlocks(); + } + diagram = new Diagram(graph, + Settings.get().get(Settings.NODE_TEXT, Settings.NODE_TEXT_DEFAULT), + Settings.get().get(Settings.NODE_SHORT_TEXT, Settings.NODE_SHORT_TEXT_DEFAULT), + Settings.get().get(Settings.NODE_TINY_TEXT, Settings.NODE_TINY_TEXT_DEFAULT)); + getFilterChain().apply(diagram, getSequenceFilterChain()); + if (graph.isDiffGraph()) { + ColorFilter f = new ColorFilter(""); + f.addRule(stateColorRule("same", Color.white)); + f.addRule(stateColorRule("changed", Color.orange)); + f.addRule(stateColorRule("new", Color.green)); + f.addRule(stateColorRule("deleted", Color.red)); + f.apply(diagram); + } + getDiagramChangedEvent().fire(); } public FilterChain getFilterChain() { return filterChain; } - public void setFilterChain(FilterChain chain) { - assert chain != null : "filterChain must never be null"; - filterChain.getChangedEvent().removeListener(filterChainChangedListener); - filterChain = chain; - filterChain.getChangedEvent().addListener(filterChainChangedListener); - diagramChanged(); - } - /* * Select the set of graphs to be presented. */ @@ -462,59 +438,23 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene return new ColorFilter.ColorRule(new MatcherSelector(new Properties.RegexpPropertyMatcher("state", state)), color); } - public Diagram getDiagramToView() { - - if (diagram == null) { - InputGraph graph = getGraphToView(); - if (graph.getBlocks().isEmpty()) { - Scheduler s = Lookup.getDefault().lookup(Scheduler.class); - graph.clearBlocks(); - s.schedule(graph); - graph.ensureNodesInBlocks(); - } - diagram = Diagram.createDiagram(graph, - Settings.get().get(Settings.NODE_TEXT, Settings.NODE_TEXT_DEFAULT), - Settings.get().get(Settings.NODE_SHORT_TEXT, Settings.NODE_SHORT_TEXT_DEFAULT), - Settings.get().get(Settings.NODE_TINY_TEXT, Settings.NODE_TINY_TEXT_DEFAULT)); - getFilterChain().apply(diagram, getSequenceFilterChain()); - if (graph.isDiffGraph()) { - ColorFilter f = new ColorFilter(""); - f.addRule(stateColorRule("same", Color.white)); - f.addRule(stateColorRule("changed", Color.orange)); - f.addRule(stateColorRule("new", Color.green)); - f.addRule(stateColorRule("deleted", Color.red)); - f.apply(diagram); - } - } - + public Diagram getDiagram() { diagram.setCFG(getShowCFG()); return diagram; } - public InputGraph getGraphToView() { - if (inputGraph == null) { - if (getFirstGraph() != getSecondGraph()) { - inputGraph = Difference.createDiffGraph(getFirstGraph(), getSecondGraph()); - } else { - inputGraph = getFirstGraph(); - } - } - - return inputGraph; + public InputGraph getGraph() { + return cachedInputGraph; } @Override public void changed(RangeSliderModel source) { - inputGraph = null; - diagramChanged(); - } - - void setSelectedFigures(List
list) { - Set newSelectedNodes = new HashSet<>(); - for (Figure f : list) { - newSelectedNodes.addAll(f.getSource().getSourceNodesAsSet()); + if (getFirstGraph() != getSecondGraph()) { + cachedInputGraph = Difference.createDiffGraph(getFirstGraph(), getSecondGraph()); + } else { + cachedInputGraph = getFirstGraph(); } - this.setSelectedNodes(newSelectedNodes); + updateDiagram(); } void close() { @@ -524,44 +464,33 @@ public class DiagramViewModel extends RangeSliderModel implements ChangedListene } Iterable getGraphsForward() { - return new Iterable() { + return () -> new Iterator() { + int index = getFirstPosition(); @Override - public Iterator iterator() { - return new Iterator() { - int index = getFirstPosition(); + public boolean hasNext() { + return index + 1 < graphs.size(); + } - @Override - public boolean hasNext() { - return index + 1 < graphs.size(); - } - - @Override - public InputGraph next() { - return graphs.get(++index); - } - }; + @Override + public InputGraph next() { + return graphs.get(++index); } }; } Iterable getGraphsBackward() { - return new Iterable() { + return () -> new Iterator() { + int index = getFirstPosition(); + @Override - public Iterator iterator() { - return new Iterator() { - int index = getFirstPosition(); + public boolean hasNext() { + return index - 1 > 0; + } - @Override - public boolean hasNext() { - return index - 1 > 0; - } - - @Override - public InputGraph next() { - return graphs.get(--index); - } - }; + @Override + public InputGraph next() { + return graphs.get(--index); } }; } diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramViewer.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramViewer.java index e8ddc8c1ae7..cd6eb51a30c 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramViewer.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/DiagramViewer.java @@ -66,7 +66,9 @@ public interface DiagramViewer { void zoomIn(Point zoomCenter, double speed); void setZoomPercentage(int percentage); + int getZoomPercentage(); + ChangedEvent getZoomChangedEvent(); UndoRedo getUndoRedo(); diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/EditorInputGraphProvider.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/EditorInputGraphProvider.java index 7de32afd910..1f106e15e75 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/EditorInputGraphProvider.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/EditorInputGraphProvider.java @@ -50,7 +50,7 @@ public class EditorInputGraphProvider implements InputGraphProvider { @Override public InputGraph getGraph() { if (editor != null && EditorTopComponent.isOpen(editor)) { - return editor.getModel().getGraphToView(); + return editor.getModel().getGraph(); } else { return null; } diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/EditorTopComponent.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/EditorTopComponent.java index 47d797a0ca3..b73c64b858c 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/EditorTopComponent.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/EditorTopComponent.java @@ -23,9 +23,7 @@ */ package com.sun.hotspot.igv.view; -import com.sun.hotspot.igv.data.Properties; import com.sun.hotspot.igv.data.*; -import com.sun.hotspot.igv.data.Properties.PropertyMatcher; import com.sun.hotspot.igv.data.services.InputGraphProvider; import com.sun.hotspot.igv.filter.FilterChain; import com.sun.hotspot.igv.filter.FilterChainProvider; @@ -76,7 +74,8 @@ public final class EditorTopComponent extends TopComponent { private static final String SATELLITE_STRING = "satellite"; private static final String SCENE_STRING = "scene"; - public EditorTopComponent(Diagram diagram) { + + public EditorTopComponent(InputGraph graph) { initComponents(); LookupHistory.init(InputGraphProvider.class); @@ -119,16 +118,15 @@ public final class EditorTopComponent extends TopComponent { }; JPanel container = new JPanel(new BorderLayout()); + add(container, BorderLayout.NORTH); - DiagramViewModel diagramViewModel = new DiagramViewModel(diagram.getGraph().getGroup(), filterChain, sequence); - RangeSlider rangeSlider = new RangeSlider(); - rangeSlider.setModel(diagramViewModel); - if (diagram.getGraph().getGroup().getGraphsCount() == 1) { + DiagramViewModel diagramViewModel = new DiagramViewModel(graph, filterChain, sequence); + RangeSlider rangeSlider = new RangeSlider(diagramViewModel); + if (diagramViewModel.getGroup().getGraphs().size() == 1) { rangeSlider.setVisible(false); } JScrollPane pane = new JScrollPane(rangeSlider, ScrollPaneConstants.VERTICAL_SCROLLBAR_NEVER, ScrollPaneConstants.HORIZONTAL_SCROLLBAR_AS_NEEDED); container.add(BorderLayout.CENTER, pane); - add(container, BorderLayout.NORTH); scene = new DiagramScene(actions, actionsWithSelection, diagramViewModel); graphContent = new InstanceContent(); @@ -137,16 +135,13 @@ public final class EditorTopComponent extends TopComponent { content.add(diagramViewModel); associateLookup(new ProxyLookup(scene.getLookup(), new AbstractLookup(graphContent), new AbstractLookup(content))); - diagramViewModel.getDiagramChangedEvent().addListener(source -> { - setDisplayName(getDiagram().getName()); - setToolTipText(getDiagram().getGraph().getGroup().getName()); - Collection list = new ArrayList<>(); - list.add(new EditorInputGraphProvider(EditorTopComponent.this)); - graphContent.set(list, null); + diagramViewModel.getDiagramChangedEvent().addListener(model -> { + setDisplayName(model.getGraph().getName()); + setToolTipText(model.getGroup().getName()); + graphContent.set(Collections.singletonList(new EditorInputGraphProvider(this)), null); }); - diagramViewModel.selectGraph(diagram.getGraph()); - Group group = getDiagram().getGraph().getGroup(); + Group group = diagramViewModel.getGroup(); group.getChangedEvent().addListener(g -> closeOnRemovedOrEmptyGroup()); if (group.getParent() instanceof GraphDocument) { final GraphDocument doc = (GraphDocument) group.getParent(); @@ -252,7 +247,7 @@ public final class EditorTopComponent extends TopComponent { } private Diagram getDiagram() { - return getModel().getDiagramToView(); + return getModel().getDiagram(); } public void setSelectionMode(boolean enable) { @@ -328,12 +323,6 @@ public final class EditorTopComponent extends TopComponent { } } - public void setSelection(PropertyMatcher matcher) { - Properties.PropertySelector
selector = new Properties.PropertySelector<>(getDiagram().getFigures()); - List
list = selector.selectMultiple(matcher); - setSelectedFigures(list); - } - public void setSelectedFigures(List
list) { scene.setSelection(list); scene.centerFigures(list); @@ -346,11 +335,8 @@ public final class EditorTopComponent extends TopComponent { ids.add(n.getId()); } for (Figure f : getDiagram().getFigures()) { - for (InputNode n : f.getSource().getSourceNodes()) { - if (ids.contains(n.getId())) { - list.add(f); - break; - } + if (ids.contains(f.getInputNode().getId())) { + list.add(f); } } setSelectedFigures(list); @@ -359,7 +345,7 @@ public final class EditorTopComponent extends TopComponent { public void setSelectedNodes(InputBlock b) { List
list = new ArrayList<>(); for (Figure f : getDiagram().getFigures()) { - if (f.getBlock() == b) { + if (f.getBlock().getInputBlock() == b) { list.add(f); } } diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/ExtendedSatelliteComponent.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/ExtendedSatelliteComponent.java deleted file mode 100644 index 0e764bb4fff..00000000000 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/ExtendedSatelliteComponent.java +++ /dev/null @@ -1,216 +0,0 @@ -/* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ -package com.sun.hotspot.igv.view; - -import java.awt.*; -import java.awt.event.*; -import javax.swing.JComponent; -import org.netbeans.api.visual.widget.Scene; - -/** - * @author David Kaspar - * @author Thomas Wuerthinger - */ -public class ExtendedSatelliteComponent extends JComponent implements MouseListener, MouseMotionListener, Scene.SceneListener, ComponentListener { - - private DiagramScene scene; - private Image image; - private int imageWidth; - private int imageHeight; - - public ExtendedSatelliteComponent(DiagramScene scene) { - this.scene = scene; - setDoubleBuffered(true); - setPreferredSize(new Dimension(128, 128)); - addMouseListener(this); - addMouseMotionListener(this); - } - - @Override - public void addNotify() { - super.addNotify(); - scene.addSceneListener(this); - JComponent viewComponent = scene.getView(); - if (viewComponent == null) { - viewComponent = scene.createView(); - } - viewComponent.addComponentListener(this); - repaint(); - } - - @Override - public void removeNotify() { - scene.getView().removeComponentListener(this); - scene.removeSceneListener(this); - super.removeNotify(); - } - - public void update() { - this.image = null; - if (this.isVisible()) { - repaint(); - revalidate(); - validate(); - } - } - - @Override - public void paint(Graphics g) { - Graphics2D gr = (Graphics2D) g; - super.paint(g); - Rectangle bounds = scene.getBounds(); - Dimension size = getSize(); - - double sx = bounds.width > 0 ? (double) size.width / bounds.width : 0.0; - double sy = bounds.width > 0 ? (double) size.height / bounds.height : 0.0; - double scale = Math.min(sx, sy); - - int vw = (int) (scale * bounds.width); - int vh = (int) (scale * bounds.height); - int vx = (size.width - vw) / 2; - int vy = (size.height - vh) / 2; - - - if (image == null || vw != imageWidth || vh != imageHeight) { - imageWidth = vw; - imageHeight = vh; - image = this.createImage(imageWidth, imageHeight); - Graphics2D ig = (Graphics2D) image.getGraphics(); - ig.scale(scale, scale); - double oldFactor = scene.getZoomFactor(); - scene.setZoomFactor(scale); - scene.paint(ig); - scene.setZoomFactor(oldFactor); - } - - gr.drawImage(image, vx, vy, this); - - JComponent component = scene.getView(); - double zoomFactor = scene.getZoomFactor(); - Rectangle viewRectangle = component != null ? component.getVisibleRect() : null; - if (viewRectangle != null) { - Rectangle window = new Rectangle( - (int) ((double) viewRectangle.x * scale / zoomFactor), - (int) ((double) viewRectangle.y * scale / zoomFactor), - (int) ((double) viewRectangle.width * scale / zoomFactor), - (int) ((double) viewRectangle.height * scale / zoomFactor)); - window.translate(vx, vy); - gr.setColor(new Color(200, 200, 200, 128)); - gr.fill(window); - gr.setColor(Color.BLACK); - gr.drawRect(window.x, window.y, window.width - 1, window.height - 1); - } - } - - @Override - public void mouseClicked(MouseEvent e) { - } - - @Override - public void mousePressed(MouseEvent e) { - moveVisibleRect(e.getPoint()); - } - - @Override - public void mouseReleased(MouseEvent e) { - moveVisibleRect(e.getPoint()); - } - - @Override - public void mouseEntered(MouseEvent e) { - } - - @Override - public void mouseExited(MouseEvent e) { - } - - @Override - public void mouseDragged(MouseEvent e) { - moveVisibleRect(e.getPoint()); - } - - @Override - public void mouseMoved(MouseEvent e) { - } - - private void moveVisibleRect(Point center) { - JComponent component = scene.getView(); - if (component == null) { - return; - } - double zoomFactor = scene.getZoomFactor(); - Rectangle bounds = scene.getBounds(); - Dimension size = getSize(); - - double sx = bounds.width > 0 ? (double) size.width / bounds.width : 0.0; - double sy = bounds.width > 0 ? (double) size.height / bounds.height : 0.0; - double scale = Math.min(sx, sy); - - int vw = (int) (scale * bounds.width); - int vh = (int) (scale * bounds.height); - int vx = (size.width - vw) / 2; - int vy = (size.height - vh) / 2; - - int cx = (int) ((double) (center.x - vx) / scale * zoomFactor); - int cy = (int) ((double) (center.y - vy) / scale * zoomFactor); - - Rectangle visibleRect = component.getVisibleRect(); - visibleRect.x = cx - visibleRect.width / 2; - visibleRect.y = cy - visibleRect.height / 2; - component.scrollRectToVisible(visibleRect); - - this.repaint(); - } - - @Override - public void sceneRepaint() { - //repaint (); - } - - @Override - public void sceneValidating() { - } - - @Override - public void sceneValidated() { - } - - @Override - public void componentResized(ComponentEvent e) { - repaint(); - } - - @Override - public void componentMoved(ComponentEvent e) { - repaint(); - } - - @Override - public void componentShown(ComponentEvent e) { - } - - @Override - public void componentHidden(ComponentEvent e) { - } -} diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/GraphViewerImplementation.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/GraphViewerImplementation.java index 8b61d294e95..87a5c45c633 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/GraphViewerImplementation.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/GraphViewerImplementation.java @@ -63,12 +63,7 @@ public class GraphViewerImplementation implements GraphViewer { } } - Diagram diagram = Diagram.createDiagram(graph, - Settings.get().get(Settings.NODE_TEXT, Settings.NODE_TEXT_DEFAULT), - Settings.get().get(Settings.NODE_SHORT_TEXT, Settings.NODE_SHORT_TEXT_DEFAULT), - Settings.get().get(Settings.NODE_TINY_TEXT, Settings.NODE_TINY_TEXT_DEFAULT)); - EditorTopComponent tc = new EditorTopComponent(diagram); - diagram.setCFG(tc.getModel().getShowCFG()); + EditorTopComponent tc = new EditorTopComponent(graph); tc.open(); tc.requestActive(); } diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/NodeQuickSearch.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/NodeQuickSearch.java index a6c9856946a..1dc2a345998 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/NodeQuickSearch.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/NodeQuickSearch.java @@ -176,14 +176,11 @@ public class NodeQuickSearch implements SearchProvider { return matches.size() == 0 ? null : matches; } catch (Exception e) { final String msg = e.getMessage(); - response.addResult(new Runnable() { - @Override - public void run() { - Message desc = new NotifyDescriptor.Message("An exception occurred during the search, " - + "perhaps due to a malformed query string:\n" + msg, - NotifyDescriptor.WARNING_MESSAGE); - DialogDisplayer.getDefault().notify(desc); - } + response.addResult(() -> { + Message desc = new Message("An exception occurred during the search, " + + "perhaps due to a malformed query string:\n" + msg, + NotifyDescriptor.WARNING_MESSAGE); + DialogDisplayer.getDefault().notify(desc); }, "(Error during search)" ); diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/CustomSelectAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/CustomSelectAction.java index c6df60ab158..9da6768289e 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/CustomSelectAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/CustomSelectAction.java @@ -23,13 +23,11 @@ */ package com.sun.hotspot.igv.view.actions; -import org.netbeans.api.visual.widget.Widget; -import org.netbeans.api.visual.action.WidgetAction; -import org.netbeans.api.visual.action.SelectProvider; - +import java.awt.Point; import java.awt.event.MouseEvent; -import java.awt.event.KeyEvent; -import java.awt.*; +import org.netbeans.api.visual.action.SelectProvider; +import org.netbeans.api.visual.action.WidgetAction; +import org.netbeans.api.visual.widget.Widget; /** * diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/CustomizablePanAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/CustomizablePanAction.java index 8152762a575..5c11bb2028c 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/CustomizablePanAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/CustomizablePanAction.java @@ -50,10 +50,7 @@ import java.awt.Rectangle; import javax.swing.JComponent; import javax.swing.JScrollPane; import javax.swing.SwingUtilities; -import javax.swing.JScrollBar; import org.netbeans.api.visual.action.WidgetAction; -import org.netbeans.api.visual.action.WidgetAction.State; -import org.netbeans.api.visual.action.WidgetAction.WidgetMouseEvent; import org.netbeans.api.visual.widget.Scene; import org.netbeans.api.visual.widget.Widget; diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ExpandAdjacentAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ExpandAdjacentAction.java index 221992341b8..74bc8e34fc6 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ExpandAdjacentAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ExpandAdjacentAction.java @@ -40,7 +40,7 @@ abstract public class ExpandAdjacentAction extends CallableSystemAction { if (editor != null) { Set
oldSelection = editor.getModel().getSelectedFigures(); Set
figures = new HashSet<>(oldSelection); - for (Figure f : editor.getModel().getDiagramToView().getFigures()) { + for (Figure f : editor.getModel().getDiagram().getFigures()) { if (oldSelection.contains(f)) { continue; } diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ExportAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ExportAction.java index c69129d853e..024cef3f39e 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ExportAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ExportAction.java @@ -33,14 +33,8 @@ import org.openide.awt.ActionID; import org.openide.awt.ActionReference; import org.openide.awt.ActionReferences; import org.openide.awt.ActionRegistration; -import org.openide.util.HelpCtx; -import org.openide.util.ImageUtilities; -import org.openide.util.Lookup; -import org.openide.util.LookupEvent; -import org.openide.util.LookupListener; -import org.openide.util.NbBundle; +import org.openide.util.*; import org.openide.util.NbBundle.Messages; -import org.openide.util.Utilities; import org.openide.util.actions.CallableSystemAction; diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/HideAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/HideAction.java index 20e20626cf4..53e1cd05651 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/HideAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/HideAction.java @@ -69,7 +69,7 @@ public final class HideAction extends ModelAwareAction { Set selectedNodes = model.getSelectedNodes(); HashSet nodes = new HashSet<>(model.getHiddenNodes()); nodes.addAll(selectedNodes); - model.showNot(nodes); + model.setHiddenNodes(nodes); } @Override diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/HideDuplicatesAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/HideDuplicatesAction.java index 9c2bf980e72..0505e367dee 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/HideDuplicatesAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/HideDuplicatesAction.java @@ -23,12 +23,11 @@ */ package com.sun.hotspot.igv.view.actions; +import com.sun.hotspot.igv.view.EditorTopComponent; import java.awt.event.ActionEvent; import javax.swing.AbstractAction; import javax.swing.Action; import javax.swing.ImageIcon; - -import com.sun.hotspot.igv.view.EditorTopComponent; import org.openide.util.ImageUtilities; /** diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/MouseOverAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/MouseOverAction.java deleted file mode 100644 index 43dd6cd8ce6..00000000000 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/MouseOverAction.java +++ /dev/null @@ -1,59 +0,0 @@ -/* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ -package com.sun.hotspot.igv.view.actions; - -import org.netbeans.api.visual.action.HoverProvider; -import org.netbeans.api.visual.action.WidgetAction; -import org.netbeans.api.visual.action.WidgetAction.State; -import org.netbeans.api.visual.widget.Widget; - -/** - * - * @author Thomas Wuerthinger - */ -public class MouseOverAction extends WidgetAction.Adapter { - - private long eventID = Integer.MIN_VALUE; - private HoverProvider provider; - - public MouseOverAction(HoverProvider provider) { - this.provider = provider; - } - - @Override - public State mouseMoved(Widget widget, WidgetMouseEvent event) { - long id = event.getEventID(); - if (id != eventID) { - eventID = id; - provider.widgetHovered(widget); - } - return State.REJECTED; - } - - @Override - public State mouseExited(Widget widget, WidgetMouseEvent event) { - provider.widgetHovered(null); - return State.REJECTED; - } -} diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/OverviewAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/OverviewAction.java index 9fc0c4aaed5..f6783c044f4 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/OverviewAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/OverviewAction.java @@ -23,12 +23,10 @@ */ package com.sun.hotspot.igv.view.actions; -import java.awt.*; +import com.sun.hotspot.igv.view.EditorTopComponent; import java.awt.event.ActionEvent; import java.awt.event.KeyEvent; import javax.swing.*; - -import com.sun.hotspot.igv.view.EditorTopComponent; import org.openide.util.ImageUtilities; /** diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/PredSuccAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/PredSuccAction.java index 386f5ff7951..e580df537bb 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/PredSuccAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/PredSuccAction.java @@ -23,12 +23,11 @@ */ package com.sun.hotspot.igv.view.actions; +import com.sun.hotspot.igv.view.EditorTopComponent; import java.awt.event.ActionEvent; import javax.swing.AbstractAction; import javax.swing.Action; import javax.swing.ImageIcon; - -import com.sun.hotspot.igv.view.EditorTopComponent; import org.openide.util.ImageUtilities; /** diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/SelectionModeAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/SelectionModeAction.java index 762d370493b..c098d7a3056 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/SelectionModeAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/SelectionModeAction.java @@ -23,12 +23,11 @@ */ package com.sun.hotspot.igv.view.actions; +import com.sun.hotspot.igv.view.EditorTopComponent; import java.awt.event.ActionEvent; import javax.swing.AbstractAction; import javax.swing.Action; import javax.swing.ImageIcon; - -import com.sun.hotspot.igv.view.EditorTopComponent; import org.openide.util.ImageUtilities; public class SelectionModeAction extends AbstractAction { diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ShowAllAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ShowAllAction.java index 55b24b35a3f..589b34b12db 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ShowAllAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ShowAllAction.java @@ -65,7 +65,7 @@ public final class ShowAllAction extends ModelAwareAction { @Override public void performAction(DiagramViewModel model) { - model.showNot(new HashSet<>()); + model.setHiddenNodes(new HashSet<>()); } @Override diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ShowEmptyBlocksAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ShowEmptyBlocksAction.java index 9233caa6b6d..1949262f6b1 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ShowEmptyBlocksAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ShowEmptyBlocksAction.java @@ -23,14 +23,12 @@ */ package com.sun.hotspot.igv.view.actions; +import com.sun.hotspot.igv.view.EditorTopComponent; import java.awt.event.ActionEvent; import java.beans.PropertyChangeEvent; import java.beans.PropertyChangeListener; import javax.swing.AbstractAction; -import javax.swing.Action; import javax.swing.ImageIcon; - -import com.sun.hotspot.igv.view.EditorTopComponent; import org.openide.util.ImageUtilities; public class ShowEmptyBlocksAction extends AbstractAction implements PropertyChangeListener { diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ZoomLevelAction.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ZoomLevelAction.java index b56e1da60c3..865a727c3de 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ZoomLevelAction.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/actions/ZoomLevelAction.java @@ -28,7 +28,10 @@ import com.sun.hotspot.igv.view.DiagramViewer; import com.sun.hotspot.igv.view.EditorTopComponent; import java.awt.Color; import java.awt.event.ActionEvent; -import javax.swing.*; +import javax.swing.BorderFactory; +import javax.swing.DefaultComboBoxModel; +import javax.swing.JComboBox; +import javax.swing.JTextField; import javax.swing.plaf.basic.BasicComboBoxUI; public final class ZoomLevelAction extends JComboBox implements ChangedListener { diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/BlockWidget.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/BlockWidget.java index 4e8e919e8c5..b5036ada5b3 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/BlockWidget.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/BlockWidget.java @@ -25,12 +25,7 @@ package com.sun.hotspot.igv.view.widgets; import com.sun.hotspot.igv.data.InputBlock; import com.sun.hotspot.igv.graph.Diagram; -import java.awt.BasicStroke; -import java.awt.Color; -import java.awt.Font; -import java.awt.Graphics2D; -import java.awt.Rectangle; -import java.awt.Stroke; +import java.awt.*; import java.awt.geom.Rectangle2D; import org.netbeans.api.visual.widget.Scene; import org.netbeans.api.visual.widget.Widget; @@ -41,17 +36,14 @@ import org.netbeans.api.visual.widget.Widget; */ public class BlockWidget extends Widget { - public static final int BORDER = 20; public static final Color BACKGROUND_COLOR = new Color(235, 235, 255); private static final Font TITLE_FONT = new Font("Arial", Font.BOLD, 14); public static final Color TITLE_COLOR = new Color(42, 42, 171); private InputBlock blockNode; - private Diagram diagram; public BlockWidget(Scene scene, Diagram d, InputBlock blockNode) { super(scene); this.blockNode = blockNode; - this.diagram = d; this.setBackground(BACKGROUND_COLOR); this.setOpaque(true); this.setCheckClipping(true); diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/FigureWidget.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/FigureWidget.java index 75930d5f76f..5150769df3e 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/FigureWidget.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/FigureWidget.java @@ -23,9 +23,8 @@ */ package com.sun.hotspot.igv.view.widgets; -import com.sun.hotspot.igv.data.InputGraph; import com.sun.hotspot.igv.data.Properties; -import com.sun.hotspot.igv.data.services.GraphViewer; +import com.sun.hotspot.igv.graph.Diagram; import com.sun.hotspot.igv.graph.Figure; import com.sun.hotspot.igv.util.DoubleClickAction; import com.sun.hotspot.igv.util.DoubleClickHandler; @@ -33,11 +32,9 @@ import com.sun.hotspot.igv.util.PropertiesConverter; import com.sun.hotspot.igv.util.PropertiesSheet; import com.sun.hotspot.igv.view.DiagramScene; import java.awt.*; -import java.awt.event.ActionEvent; import java.util.ArrayList; import java.util.HashSet; import java.util.Set; -import javax.swing.AbstractAction; import javax.swing.Action; import javax.swing.BorderFactory; import javax.swing.JMenu; @@ -57,7 +54,6 @@ import org.openide.nodes.Children; import org.openide.nodes.Node; import org.openide.nodes.Sheet; import org.openide.util.ImageUtilities; -import org.openide.util.Lookup; /** * @@ -65,11 +61,8 @@ import org.openide.util.Lookup; */ public class FigureWidget extends Widget implements Properties.Provider, PopupMenuProvider, DoubleClickHandler { - public static final boolean VERTICAL_LAYOUT = true; private static final double LABEL_ZOOM_FACTOR = 0.3; private Figure figure; - private Widget leftWidget; - private Widget rightWidget; private Widget middleWidget; private ArrayList labelWidgets; private DiagramScene diagramScene; @@ -86,10 +79,6 @@ public class FigureWidget extends Widget implements Properties.Provider, PopupMe return boundary; } - public Node getNode() { - return node; - } - @Override public boolean isHitAt(Point localLocation) { return middleWidget.isHitAt(localLocation); @@ -144,7 +133,7 @@ public class FigureWidget extends Widget implements Properties.Provider, PopupMe labelWidgets.add(lw); textWidget.addChild(lw); lw.setLabel(displayString); - lw.setFont(figure.getDiagram().getFont()); + lw.setFont(Diagram.FONT); lw.setForeground(getTextColor()); lw.setAlignment(LabelWidget.Alignment.CENTER); lw.setVerticalAlignment(LabelWidget.VerticalAlignment.CENTER); @@ -184,22 +173,14 @@ public class FigureWidget extends Widget implements Properties.Provider, PopupMe this.setToolTipText(PropertiesConverter.convertToHTML(f.getProperties())); } - public Widget getLeftWidget() { - return leftWidget; - } - - public Widget getRightWidget() { - return rightWidget; - } - @Override protected void notifyStateChanged(ObjectState previousState, ObjectState state) { super.notifyStateChanged(previousState, state); - Font font = this.figure.getDiagram().getFont(); + Font font = Diagram.FONT; int thickness = 1; if (state.isSelected()) { - font = this.figure.getDiagram().getBoldFont(); + font = Diagram.BOLD_FONT; thickness = 2; } @@ -286,27 +267,6 @@ public class FigureWidget extends Widget implements Properties.Provider, PopupMe menu.addSeparator(); build(menu, getFigure(), this, true, diagramScene); - if (getFigure().getSubgraphs() != null) { - menu.addSeparator(); - JMenu subgraphs = new JMenu("Subgraphs"); - menu.add(subgraphs); - - final GraphViewer viewer = Lookup.getDefault().lookup(GraphViewer.class); - for (final InputGraph subgraph : getFigure().getSubgraphs()) { - Action a = new AbstractAction() { - - @Override - public void actionPerformed(ActionEvent e) { - viewer.view(subgraph, true); - } - }; - - a.setEnabled(true); - a.putValue(Action.NAME, subgraph.getName()); - subgraphs.add(a); - } - } - return menu; } @@ -383,20 +343,18 @@ public class FigureWidget extends Widget implements Properties.Provider, PopupMe @Override public void handleDoubleClick(Widget w, WidgetAction.WidgetMouseEvent e) { - if (diagramScene.isAllVisible()) { - final Set hiddenNodes = new HashSet<>(diagramScene.getModel().getGraphToView().getGroup().getAllNodes()); - hiddenNodes.removeAll(this.getFigure().getSource().getSourceNodesAsSet()); - this.diagramScene.getModel().showNot(hiddenNodes); + final Set hiddenNodes = new HashSet<>(diagramScene.getModel().getGroup().getAllNodes()); + hiddenNodes.remove(this.getFigure().getInputNode().getId()); + this.diagramScene.getModel().setHiddenNodes(hiddenNodes); } else if (isBoundary()) { - final Set hiddenNodes = new HashSet<>(diagramScene.getModel().getHiddenNodes()); - hiddenNodes.removeAll(this.getFigure().getSource().getSourceNodesAsSet()); - this.diagramScene.getModel().showNot(hiddenNodes); + hiddenNodes.remove(this.getFigure().getInputNode().getId()); + this.diagramScene.getModel().setHiddenNodes(hiddenNodes); } else { final Set hiddenNodes = new HashSet<>(diagramScene.getModel().getHiddenNodes()); - hiddenNodes.addAll(this.getFigure().getSource().getSourceNodesAsSet()); - this.diagramScene.getModel().showNot(hiddenNodes); + hiddenNodes.add(this.getFigure().getInputNode().getId()); + this.diagramScene.getModel().setHiddenNodes(hiddenNodes); } } } diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/InputSlotWidget.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/InputSlotWidget.java index 4bba96c7e01..911567001e4 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/InputSlotWidget.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/InputSlotWidget.java @@ -58,15 +58,4 @@ public class InputSlotWidget extends SlotWidget { return getFigureWidget().getFigure().getDiagram().isCFG() ? calculateClientArea().height - 1 : Figure.SLOT_START; } -/* - protected Point calculateRelativeLocation() { - if (getFigureWidget().getBounds() == null) { - return new Point(0, 0); - } - - double x = 0; - List slots = inputSlot.getFigure().getInputSlots(); - assert slots.contains(inputSlot); - return new Point((int) x, (int) (calculateRelativeY(slots.size(), slots.indexOf(inputSlot)))); - }*/ } diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/LineWidget.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/LineWidget.java index 5eeb0f84e5e..7612bd7a8bb 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/LineWidget.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/LineWidget.java @@ -23,10 +23,10 @@ */ package com.sun.hotspot.igv.view.widgets; +import com.sun.hotspot.igv.graph.Block; import com.sun.hotspot.igv.graph.Connection; import com.sun.hotspot.igv.graph.Figure; import com.sun.hotspot.igv.graph.OutputSlot; -import com.sun.hotspot.igv.graph.Block; import com.sun.hotspot.igv.util.StringUtils; import com.sun.hotspot.igv.view.DiagramScene; import java.awt.*; diff --git a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/SlotWidget.java b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/SlotWidget.java index 74b67895788..e264329db1f 100644 --- a/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/SlotWidget.java +++ b/src/utils/IdealGraphVisualizer/View/src/main/java/com/sun/hotspot/igv/view/widgets/SlotWidget.java @@ -23,18 +23,15 @@ */ package com.sun.hotspot.igv.view.widgets; +import com.sun.hotspot.igv.graph.Diagram; import com.sun.hotspot.igv.graph.Figure; import com.sun.hotspot.igv.graph.OutputSlot; import com.sun.hotspot.igv.graph.Slot; import com.sun.hotspot.igv.util.DoubleClickHandler; import com.sun.hotspot.igv.view.DiagramScene; -import java.awt.BasicStroke; -import java.awt.Color; -import java.awt.Font; -import java.awt.Graphics2D; -import java.awt.Point; -import java.awt.Rectangle; +import java.awt.*; import java.awt.geom.Rectangle2D; +import java.util.Collections; import java.util.HashSet; import java.util.Set; import org.netbeans.api.visual.action.WidgetAction; @@ -105,7 +102,7 @@ public abstract class SlotWidget extends Widget implements DoubleClickHandler { int s = h - SMALLER; int rectW = s; - Font font = this.getSlot().getFigure().getDiagram().getSlotFont(); + Font font = Diagram.SLOT_FONT; if (this.getState().isSelected()) { font = font.deriveFont(Font.BOLD); g.setStroke(new BasicStroke(1.5f)); @@ -170,21 +167,21 @@ public abstract class SlotWidget extends Widget implements DoubleClickHandler { public void handleDoubleClick(Widget w, WidgetAction.WidgetMouseEvent e) { Set hiddenNodes = new HashSet<>(diagramScene.getModel().getHiddenNodes()); if (diagramScene.isAllVisible()) { - hiddenNodes = new HashSet<>(diagramScene.getModel().getGraphToView().getGroup().getAllNodes()); + hiddenNodes = new HashSet<>(diagramScene.getModel().getGroup().getAllNodes()); } boolean progress = false; - for (Figure f : diagramScene.getModel().getDiagramToView().getFigures()) { + for (Figure f : diagramScene.getModel().getDiagram().getFigures()) { for (Slot s : f.getSlots()) { - if (DiagramScene.doesIntersect(s.getSource().getSourceNodesAsSet(), slot.getSource().getSourceNodesAsSet())) { + if (!Collections.disjoint(s.getSource().getSourceNodesAsSet(), slot.getSource().getSourceNodesAsSet())) { progress = true; - hiddenNodes.removeAll(f.getSource().getSourceNodesAsSet()); + hiddenNodes.remove(f.getInputNode().getId()); } } } if (progress) { - this.diagramScene.getModel().showNot(hiddenNodes); + this.diagramScene.getModel().setHiddenNodes(hiddenNodes); } } }