main.java.soot.util.dot.DotGraphEdge Maven / Gradle / Ivy
/* Soot - a J*va Optimization Framework
* Copyright (C) 2002 Sable Research Group
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
* Boston, MA 02111-1307, USA.
*/
/*
* Modified by the Sable Research Group and others 1997-1999.
* See the 'credits' file distributed with Soot for the complete list of
* contributors. (Soot is distributed at http://www.sable.mcgill.ca/soot)
*/
package soot.util.dot;
import java.io.*;
import java.util.*;
/* Graph edges are the major elements of a graph
* @author Feng Qian
*/
public class DotGraphEdge implements Renderable {
private boolean isDirected;
private DotGraphNode start, end;
private List attributes;
/**
* Draws a directed edge.
* @param src, the source node
* @param dst, the end node
*/
public DotGraphEdge(DotGraphNode src, DotGraphNode dst){
this.start = src;
this.end = dst;
this.isDirected = true;
}
/**
* Draws a graph edge by specifying directed or undirected.
* @param src, the source node
* @param dst, the end node
* @param directed, the edge is directed or not
*/
public DotGraphEdge(DotGraphNode src, DotGraphNode dst, boolean directed){
this.start = src;
this.end = dst;
this.isDirected = directed;
}
/**
* Sets the label for the edge.
* @param label, a label string
*/
public void setLabel(String label){
label = DotGraphUtility.replaceQuotes(label);
label = DotGraphUtility.replaceReturns(label);
this.setAttribute("label", "\""+label+"\"");
}
/**
* Sets the edge style.
* @param style, a style of edge
* @see DotGraphConstants
*/
public void setStyle(String style){
this.setAttribute("style", style);
}
/**
* Sets an edge attribute.
* @param id, the attribute id to be set
* @param value, the attribute value
*/
public void setAttribute(String id, String value) {
this.setAttribute(new DotGraphAttribute(id, value));
}
/**
* Sets an edge attribute.
* @param attr, a {@link DotGraphAttribute} specifying the
* attribute name and value.
*/
public void setAttribute(DotGraphAttribute attr) {
if (this.attributes == null) {
this.attributes = new LinkedList();
}
this.attributes.add(attr);
}
public void render(OutputStream out, int indent) throws IOException {
StringBuffer line = new StringBuffer(start.getName());
line.append((this.isDirected)?"->":"--");
line.append(end.getName());
if (this.attributes != null) {
line.append(" [");
Iterator attrIt = this.attributes.iterator();
while (attrIt.hasNext()) {
DotGraphAttribute attr = attrIt.next();
line.append(attr.toString());
line.append(",");
}
line.append("]");
}
line.append(";");
DotGraphUtility.renderLine(out, new String(line), indent);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy