package org.checkerframework.dataflow.cfg.node; import java.util.Collection; import java.util.LinkedList; import org.checkerframework.dataflow.util.HashCodeUtils; import org.checkerframework.javacutil.InternalUtils; import com.sun.source.tree.Tree; import com.sun.source.tree.Tree.Kind; /** * A node for the less than comparison: * * <pre> * <em>expression</em> < <em>expression</em> * </pre> * * We allow less than nodes without corresponding AST {@link Tree}s. * * @author Stefan Heule * @author Charlie Garrett * */ public class LessThanNode extends Node { protected Tree tree; protected Node left; protected Node right; public LessThanNode(Tree tree, Node left, Node right) { super(InternalUtils.typeOf(tree)); assert tree.getKind() == Kind.LESS_THAN; this.tree = tree; this.left = left; this.right = right; } public Node getLeftOperand() { return left; } public Node getRightOperand() { return right; } @Override public Tree getTree() { return tree; } @Override public <R, P> R accept(NodeVisitor<R, P> visitor, P p) { return visitor.visitLessThan(this, p); } @Override public String toString() { return "(" + getLeftOperand() + " < " + getRightOperand() + ")"; } @Override public boolean equals(Object obj) { if (obj == null || !(obj instanceof LessThanNode)) { return false; } LessThanNode other = (LessThanNode) obj; return getLeftOperand().equals(other.getLeftOperand()) && getRightOperand().equals(other.getRightOperand()); } @Override public int hashCode() { return HashCodeUtils.hash(getLeftOperand(), getRightOperand()); } @Override public Collection<Node> getOperands() { LinkedList<Node> list = new LinkedList<Node>(); list.add(getLeftOperand()); list.add(getRightOperand()); return list; } }