package Analysis.SSJava;
+import java.util.HashSet;
+import java.util.Iterator;
import java.util.Set;
import IR.Descriptor;
+import IR.FieldDescriptor;
+import IR.VarDescriptor;
public class FlowNode {
// this set contains fields of the base type
private Set<FlowNode> fieldNodeSet;
- public FlowNode(Descriptor desc) {
- this(null, desc);
- }
+ // set true if this node is driven from a paramter
+ private boolean isParameter;
+
+ // set true if this node stores a return value
+ private boolean isReturn;
- public FlowNode(NTuple<Descriptor> base) {
- this(base, null);
+ public Set<FlowNode> getFieldNodeSet() {
+ return fieldNodeSet;
}
- public FlowNode(NTuple<Descriptor> base, Descriptor desc) {
+ private Set<FlowEdge> outEdgeSet;
+
+ public FlowNode(NTuple<Descriptor> tuple, boolean isParam) {
+
+ this.isParameter = isParam;
+
+ NTuple<Descriptor> base = null;
+ Descriptor desc = null;
+ if (tuple.size() > 1) {
+ base = tuple.subList(0, tuple.size() - 1);
+ desc = tuple.get(tuple.size() - 1);
+ } else {
+ base = tuple;
+ }
+ fieldNodeSet = new HashSet<FlowNode>();
descTuple = new NTuple<Descriptor>();
if (base != null) {
descTuple.addAll(base);
if (desc != null) {
descTuple.add(desc);
}
+ outEdgeSet = new HashSet<FlowEdge>();
+ }
+
+ public void addFieldNode(FlowNode node) {
+ fieldNodeSet.add(node);
+ }
+
+ public boolean isParameter() {
+ return isParameter;
}
public NTuple<Descriptor> getDescTuple() {
return descTuple.get(descTuple.size() - 1);
}
+ public boolean isReturn() {
+ return isReturn;
+ }
+
+ public void setReturn(boolean isReturn) {
+ this.isReturn = isReturn;
+ }
+
+ public boolean isPrimitiveType() {
+ Descriptor desc = descTuple.get(descTuple.size() - 1);
+ if (desc instanceof VarDescriptor) {
+ return ((VarDescriptor) desc).getType().isPrimitive();
+ } else if (desc instanceof FieldDescriptor) {
+ return ((FieldDescriptor) desc).getType().isPrimitive();
+ }
+ return false;
+ }
+
public String toString() {
- return "[FlowNode]::" + descTuple;
+ String rtr = "[FlowNode]:";
+ if (isParameter()) {
+ rtr += "param:";
+ }
+ rtr += ":" + descTuple;
+ return rtr;
}
+ public Iterator<FlowEdge> iteratorOfOutEdges() {
+ return outEdgeSet.iterator();
+ }
+
+ public void addOutEdge(FlowEdge out) {
+ outEdgeSet.add(out);
+ }
+
+ public Set<FlowEdge> getOutEdgeSet() {
+ return outEdgeSet;
+ }
+
+ public int hashCode() {
+ return 7 + descTuple.hashCode();
+ }
+
+ public boolean equals(Object obj) {
+
+ if (obj instanceof FlowNode) {
+ FlowNode in = (FlowNode) obj;
+ if (descTuple.equals(in.getDescTuple())) {
+ return true;
+ }
+ }
+
+ return false;
+
+ }
+
+ public String getID() {
+ String id = "";
+ for (int i = 0; i < descTuple.size(); i++) {
+ id += descTuple.get(i).getSymbol();
+ }
+ return id;
+ }
+
+ public String getPrettyID() {
+ String id = "<";
+ for (int i = 0; i < descTuple.size(); i++) {
+ if (i != 0) {
+ id += ",";
+ }
+ id += descTuple.get(i).getSymbol();
+ }
+ id += ">";
+ return id;
+ }
}