package org.checkerframework.dataflow.cfg.node; import com.sun.source.tree.BinaryTree; import com.sun.source.tree.Tree.Kind; import org.checkerframework.dataflow.util.HashCodeUtils; /** * A node for bitwise right shift operations with sign extension: * * <pre> * <em>expression</em> >> <em>expression</em> * </pre> * * @author Stefan Heule * @author Charlie Garrett */ public class SignedRightShiftNode extends BinaryOperationNode { public SignedRightShiftNode(BinaryTree tree, Node left, Node right) { super(tree, left, right); assert tree.getKind() == Kind.RIGHT_SHIFT; } @Override public <R, P> R accept(NodeVisitor<R, P> visitor, P p) { return visitor.visitSignedRightShift(this, p); } @Override public String toString() { return "(" + getLeftOperand() + " >> " + getRightOperand() + ")"; } @Override public boolean equals(Object obj) { if (obj == null || !(obj instanceof SignedRightShiftNode)) { return false; } SignedRightShiftNode other = (SignedRightShiftNode) obj; return getLeftOperand().equals(other.getLeftOperand()) && getRightOperand().equals(other.getRightOperand()); } @Override public int hashCode() { return HashCodeUtils.hash(getLeftOperand(), getRightOperand()); } }