All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.checkerframework.dataflow.cfg.node.ConditionalAndNode Maven / Gradle / Ivy

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 a conditional and expression:
 *
 * 
 *   expression && expression
 * 
* * @author Stefan Heule * @author Charlie Garrett */ public class ConditionalAndNode extends BinaryOperationNode { public ConditionalAndNode(BinaryTree tree, Node left, Node right) { super(tree, left, right); assert tree.getKind().equals(Kind.CONDITIONAL_AND); } @Override public R accept(NodeVisitor visitor, P p) { return visitor.visitConditionalAnd(this, p); } @Override public String toString() { return "(" + getLeftOperand() + " && " + getRightOperand() + ")"; } @Override public boolean equals(Object obj) { if (obj == null || !(obj instanceof ConditionalAndNode)) { return false; } ConditionalAndNode other = (ConditionalAndNode) obj; return getLeftOperand().equals(other.getLeftOperand()) && getRightOperand().equals(other.getRightOperand()); } @Override public int hashCode() { return HashCodeUtils.hash(getLeftOperand(), getRightOperand()); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy