Mercurial > hg > graal-compiler
view src/share/tools/IdealGraphVisualizer/Graph/src/com/sun/hotspot/igv/graph/Source.java @ 1552:c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
Summary: Change all the Sun copyrights to Oracle copyright
Reviewed-by: ohair
author | trims |
---|---|
date | Thu, 27 May 2010 19:08:38 -0700 |
parents | 30369db7f5d2 |
children |
line wrap: on
line source
/* * Copyright (c) 2008, 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.graph; import com.sun.hotspot.igv.data.InputBlock; import com.sun.hotspot.igv.data.InputGraph; import com.sun.hotspot.igv.data.InputNode; import java.util.ArrayList; import java.util.Collections; import java.util.HashSet; import java.util.List; import java.util.Set; /** * * @author Thomas Wuerthinger */ public class Source { private List<InputNode> sourceNodes; private Set<Integer> set; public Source() { sourceNodes = new ArrayList<InputNode>(1); } public List<InputNode> getSourceNodes() { return Collections.unmodifiableList(sourceNodes); } public Set<Integer> getSourceNodesAsSet() { if (set == null) { set = new HashSet<Integer>(); for (InputNode n : sourceNodes) { int id = n.getId(); //if(id < 0) id = -id; set.add(id); } } return set; } public void addSourceNode(InputNode n) { sourceNodes.add(n); set = null; } public void removeSourceNode(InputNode n) { sourceNodes.remove(n); set = null; } public interface Provider { public Source getSource(); } public void setSourceNodes(List<InputNode> sourceNodes) { this.sourceNodes = sourceNodes; set = null; } public void addSourceNodes(Source s) { for (InputNode n : s.getSourceNodes()) { sourceNodes.add(n); } set = null; } public boolean isInBlock(InputGraph g, InputBlock blockNode) { for (InputNode n : this.getSourceNodes()) { if (g.getBlock(n) == blockNode) { return true; } } return false; } }