annotate src/share/tools/IdealGraphVisualizer/Layout/src/com/sun/hotspot/igv/layout/LayoutGraph.java @ 21146:33ff6b03fad1

add support for control flow window and basic block view on graphs Contributed-by: Michael Haupt <michael.haupt@oracle.com> Contributed-by: Peter Hofer <peter.hofer@jku.at> Contributed-by: Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
author Michael Haupt <michael.haupt@oracle.com>
date Wed, 29 Apr 2015 08:31:28 +0200
parents 2b2ac41e70dd
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
1 /*
21146
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
2 * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved.
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
4 *
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
7 * published by the Free Software Foundation.
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
8 *
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
13 * accompanied this code).
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
14 *
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 417
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 417
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 417
diff changeset
21 * questions.
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
22 *
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
23 */
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
24 package com.sun.hotspot.igv.layout;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
25
4391
2b2ac41e70dd Organize imports in IGV.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents: 4390
diff changeset
26 import java.util.*;
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
27
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
28 /**
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
29 *
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
30 * @author Thomas Wuerthinger
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
31 */
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
32 public class LayoutGraph {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
33
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
34 private Set<? extends Link> links;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
35 private SortedSet<Vertex> vertices;
417
f4fe12e429a4 6764622: IdealGraphVisualizer fixes
never
parents: 220
diff changeset
36 private HashMap<Vertex, Set<Port>> inputPorts;
f4fe12e429a4 6764622: IdealGraphVisualizer fixes
never
parents: 220
diff changeset
37 private HashMap<Vertex, Set<Port>> outputPorts;
f4fe12e429a4 6764622: IdealGraphVisualizer fixes
never
parents: 220
diff changeset
38 private HashMap<Port, Set<Link>> portLinks;
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
39
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
40 public LayoutGraph(Set<? extends Link> links) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
41 this(links, new HashSet<Vertex>());
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
42 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
43
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
44 public LayoutGraph(Set<? extends Link> links, Set<? extends Vertex> additionalVertices) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
45 this.links = links;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
46 assert verify();
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
47
4382
f22dc0a63f03 Removed old hierarchical layout manager; start removing cluster layout. apply diamond operator to whole source.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents: 2898
diff changeset
48 vertices = new TreeSet<>();
f22dc0a63f03 Removed old hierarchical layout manager; start removing cluster layout. apply diamond operator to whole source.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents: 2898
diff changeset
49 portLinks = new HashMap<>(links.size());
f22dc0a63f03 Removed old hierarchical layout manager; start removing cluster layout. apply diamond operator to whole source.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents: 2898
diff changeset
50 inputPorts = new HashMap<>(links.size());
f22dc0a63f03 Removed old hierarchical layout manager; start removing cluster layout. apply diamond operator to whole source.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents: 2898
diff changeset
51 outputPorts = new HashMap<>(links.size());
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
52
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
53 for (Link l : links) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
54 Port p = l.getFrom();
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
55 Port p2 = l.getTo();
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
56 Vertex v1 = p.getVertex();
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
57 Vertex v2 = p2.getVertex();
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
58
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
59 if (!vertices.contains(v1)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
60
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
61 outputPorts.put(v1, new HashSet<Port>(1));
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
62 inputPorts.put(v1, new HashSet<Port>(3));
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
63 vertices.add(v1);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
64 assert vertices.contains(v1);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
65 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
66
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
67 if (!vertices.contains(v2)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
68 vertices.add(v2);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
69 assert vertices.contains(v2);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
70 outputPorts.put(v2, new HashSet<Port>(1));
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
71 inputPorts.put(v2, new HashSet<Port>(3));
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
72 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
73
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
74 if (!portLinks.containsKey(p)) {
4382
f22dc0a63f03 Removed old hierarchical layout manager; start removing cluster layout. apply diamond operator to whole source.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents: 2898
diff changeset
75 HashSet<Link> hashSet = new HashSet<>(3);
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
76 portLinks.put(p, hashSet);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
77 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
78
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
79 if (!portLinks.containsKey(p2)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
80 portLinks.put(p2, new HashSet<Link>(3));
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
81 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
82
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
83 outputPorts.get(v1).add(p);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
84 inputPorts.get(v2).add(p2);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
85
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
86 portLinks.get(p).add(l);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
87 portLinks.get(p2).add(l);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
88 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
89
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
90 for (Vertex v : additionalVertices) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
91 if (!vertices.contains(v)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
92 outputPorts.put(v, new HashSet<Port>(1));
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
93 inputPorts.put(v, new HashSet<Port>(3));
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
94 vertices.add(v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
95 vertices.contains(v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
96 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
97 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
98 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
99
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
100 public Set<Port> getInputPorts(Vertex v) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
101 return this.inputPorts.get(v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
102 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
103
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
104 public Set<Port> getOutputPorts(Vertex v) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
105 return this.outputPorts.get(v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
106 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
107
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
108 public Set<Link> getPortLinks(Port p) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
109 return portLinks.get(p);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
110 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
111
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
112 public Set<? extends Link> getLinks() {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
113 return links;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
114 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
115
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
116 public boolean verify() {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
117 return true;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
118 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
119
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
120 public SortedSet<Vertex> getVertices() {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
121 return vertices;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
122 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
123
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
124 private void markNotRoot(Set<Vertex> notRootSet, Vertex v, Vertex startingVertex) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
125
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
126 if (notRootSet.contains(v)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
127 return;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
128 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
129 if (v != startingVertex) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
130 notRootSet.add(v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
131 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
132 Set<Port> outPorts = getOutputPorts(v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
133 for (Port p : outPorts) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
134 Set<Link> portLinks = getPortLinks(p);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
135 for (Link l : portLinks) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
136 Port other = l.getTo();
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
137 Vertex otherVertex = other.getVertex();
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
138 if (otherVertex != startingVertex) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
139 markNotRoot(notRootSet, otherVertex, startingVertex);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
140 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
141 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
142 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
143 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
144
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
145 // Returns a set of vertices with the following properties:
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
146 // - All Vertices in the set startingRoots are elements of the set.
2898
53ddfe305645 IdealGraphVisualizer: merge changes from the IGV project on Kenai and add Oracle copyright notices where necessary
Peter Hofer <peter.hofer@jku.at>
parents: 1552
diff changeset
147 // - When starting a DFS at every vertex in the set, every vertex of the
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
148 // whole graph is visited.
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
149 public Set<Vertex> findRootVertices(Set<Vertex> startingRoots) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
150
4382
f22dc0a63f03 Removed old hierarchical layout manager; start removing cluster layout. apply diamond operator to whole source.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents: 2898
diff changeset
151 Set<Vertex> notRootSet = new HashSet<>();
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
152 for (Vertex v : startingRoots) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
153 if (!notRootSet.contains(v)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
154 markNotRoot(notRootSet, v, v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
155 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
156 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
157
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
158 Set<Vertex> tmpVertices = getVertices();
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
159 for (Vertex v : tmpVertices) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
160 if (!notRootSet.contains(v)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
161 if (this.getInputPorts(v).size() == 0) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
162 markNotRoot(notRootSet, v, v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
163 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
164 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
165 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
166
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
167 for (Vertex v : tmpVertices) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
168 if (!notRootSet.contains(v)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
169 markNotRoot(notRootSet, v, v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
170 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
171 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
172
4382
f22dc0a63f03 Removed old hierarchical layout manager; start removing cluster layout. apply diamond operator to whole source.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents: 2898
diff changeset
173 Set<Vertex> result = new HashSet<>();
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
174 for (Vertex v : tmpVertices) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
175 if (!notRootSet.contains(v)) {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
176 result.add(v);
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
177 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
178 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
179 assert tmpVertices.size() == 0 || result.size() > 0;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
180 return result;
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
181 }
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
182
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
183 public Set<Vertex> findRootVertices() {
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
184 return findRootVertices(new HashSet<Vertex>());
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
185 }
21146
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
186
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
187 public SortedSet<Cluster> getClusters() {
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
188
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
189 SortedSet<Cluster> clusters = new TreeSet<Cluster>();
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
190 for (Vertex v : getVertices()) {
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
191 if (v.getCluster() != null) {
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
192 clusters.add(v.getCluster());
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
193 }
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
194 }
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
195
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
196 return clusters;
33ff6b03fad1 add support for control flow window and basic block view on graphs
Michael Haupt <michael.haupt@oracle.com>
parents: 4391
diff changeset
197 }
220
30369db7f5d2 6604014: add support for ideal graph visualizer
never
parents:
diff changeset
198 }