Class ASTInfixExpression
- All Implemented Interfaces:
net.sourceforge.pmd.lang.ast.impl.GenericNode<JavaNode>
,net.sourceforge.pmd.lang.ast.impl.javacc.JjtreeNode<JavaNode>
,net.sourceforge.pmd.lang.ast.Node
,net.sourceforge.pmd.lang.ast.TextAvailableNode
,ASTExpression
,ASTMemberValue
,ASTSwitchArrowRHS
,JavaNode
,TypeNode
,net.sourceforge.pmd.reporting.Reportable
This node is used to represent expressions of different precedences. The operator is used to differentiate those expressions.
InfixExpression ::=Expression
BinaryOp
Expression
Binary expressions are all left-associative, and are parsed left-recursively.
For example, the expression 1 * 2 * 3 % 4
parses as the following tree:
In PMD 6.0.x, it would have parsed into the tree:
-
Nested Class Summary
Nested classes/interfaces inherited from interface net.sourceforge.pmd.lang.java.ast.ASTExpression
ASTExpression.ConstResult
-
Field Summary
FieldsFields inherited from class net.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode
id
Fields inherited from interface net.sourceforge.pmd.lang.ast.Node
COORDS_COMPARATOR
-
Method Summary
Modifier and TypeMethodDescriptionfinal <P,
R> R acceptVisitor
(net.sourceforge.pmd.lang.ast.AstVisitor<? super P, ? extends R> visitor, P data) protected <P,
R> R acceptVisitor
(JavaVisitor<? super P, ? extends R> visitor, P data) protected void
addChild
(net.sourceforge.pmd.lang.java.ast.AbstractJavaNode child, int index) protected @Nullable Object
Deprecated.Since 7.12.0.protected void
enlargeLeft
(net.sourceforge.pmd.lang.ast.impl.javacc.JavaccToken child) @NonNull ASTExpression.ConstResult
Returns the result of constant folding on this expression.default @NonNull JavaNode
Returns the first child of this node, never null.getImage()
default @NonNull JavaNode
Returns the last child of this node, never null.default @NonNull ASTExpression
Returns the left-hand-side operand.@NonNull BinaryOp
Returns the operator.int
Returns the number of parenthesis levels around this expression.Returns the right-hand side operand.final @NonNull ASTCompilationUnit
getRoot()
@NonNull JSymbolTable
Returns the symbol table for the program point represented by this node.@NonNull JTypeMirror
Returns the compile-time type of this node.@NonNull JTypeMirror
getTypeMirror
(TypingContext context) Returns the type system with which this node was created.final String
protected void
insertChild
(net.sourceforge.pmd.lang.java.ast.AbstractJavaNode child, int index) void
jjtClose()
protected void
removeChildAtIndex
(int childIndex) protected void
setChild
(net.sourceforge.pmd.lang.java.ast.AbstractJavaNode child, int index) protected void
setFirstToken
(net.sourceforge.pmd.lang.ast.impl.javacc.JavaccToken token) void
protected void
setLastToken
(net.sourceforge.pmd.lang.ast.impl.javacc.JavaccToken token) Methods inherited from class net.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode
compareLocation, fitTokensToChildren, getFirstToken, getLastToken, getTextRegion, jjtOpen, toString
Methods inherited from class net.sourceforge.pmd.lang.ast.impl.AbstractNode
children, firstChild, getChild, getIndexInParent, getNumChildren, getParent, getUserMap, remove, setParent
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface net.sourceforge.pmd.lang.java.ast.ASTExpression
getConstFoldingResult, getConstValue, getConversionContext, getParenthesisDepth, isCompileTimeConstant, isExpression, isParenthesized
Methods inherited from interface net.sourceforge.pmd.lang.ast.impl.GenericNode
ancestors, ancestorsOrSelf, asStream, children, descendants, descendantsOrSelf, getChild, getNextSibling, getParent, getPreviousSibling
Methods inherited from interface net.sourceforge.pmd.lang.java.ast.JavaNode
getEnclosingType, getRoot, getSymbolTable, getTypeSystem
Methods inherited from interface net.sourceforge.pmd.lang.ast.impl.javacc.JjtreeNode
getFirstToken, getLastToken, tokens
Methods inherited from interface net.sourceforge.pmd.lang.ast.Node
acceptVisitor, ancestors, children, compareLocation, descendants, firstChild, getAstInfo, getBeginColumn, getBeginLine, getEndColumn, getEndLine, getIndexInParent, getLanguageVersion, getNumChildren, getReportLocation, getTextDocument, getUserMap, getXPathAttributesIterator, getXPathNodeName, hasImageEqualTo, isFindBoundary
Methods inherited from interface net.sourceforge.pmd.lang.ast.TextAvailableNode
getOriginalText, getText, getTextRegion
Methods inherited from interface net.sourceforge.pmd.lang.java.ast.TypeNode
getTypeMirror, getTypeMirror
-
Field Details
-
symbolTable
-
-
Method Details
-
acceptVisitor
-
getRightOperand
Returns the right-hand side operand.If this is an instanceof expression, then the right operand is a TypeExpression.
-
getOperator
Returns the operator. -
setImage
-
getImage
- Specified by:
getImage
in interfacenet.sourceforge.pmd.lang.ast.Node
- Overrides:
getImage
in classnet.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
getLeftOperand
Returns the left-hand-side operand. -
getFirstChild
Returns the first child of this node, never null.- Specified by:
getFirstChild
in interfacenet.sourceforge.pmd.lang.ast.impl.GenericNode<JavaNode>
- Specified by:
getFirstChild
in interfacenet.sourceforge.pmd.lang.ast.Node
-
getLastChild
Returns the last child of this node, never null.- Specified by:
getLastChild
in interfacenet.sourceforge.pmd.lang.ast.impl.GenericNode<JavaNode>
- Specified by:
getLastChild
in interfacenet.sourceforge.pmd.lang.ast.Node
-
getParenthesisDepth
public int getParenthesisDepth()Description copied from interface:ASTExpression
Returns the number of parenthesis levels around this expression. If this method returns 0, then no parentheses are present.E.g. the expression
(a + b)
is parsed as an AdditiveExpression whose parenthesisDepth is 1, and in((a + b))
it's 2.This is to avoid the parentheses interfering with analysis. Parentheses already influence parsing by breaking the natural precedence of operators. It would mostly hide false positives to make a ParenthesizedExpr node, because it would make semantically equivalent nodes have a very different representation.
On the other hand, when a rule explicitly cares about parentheses, then this attribute may be used to find out whether parentheses were mentioned, so no information is lost.
- Specified by:
getParenthesisDepth
in interfaceASTExpression
-
getConstFoldingResult
Description copied from interface:ASTExpression
Returns the result of constant folding on this expression. This may find a constant value for more than strict compile-time constants. SeeASTExpression.ConstResult
.- Specified by:
getConstFoldingResult
in interfaceASTExpression
-
buildConstValue
Deprecated.Since 7.12.0. Kept for binary compatibility. This method should have been package-private from the start. UseASTExpression.getConstValue()
orASTExpression.getConstFoldingResult()
instead. -
getTypeMirror
Description copied from interface:TypeNode
Returns the compile-time type of this node. For example, for a string literal, returns the type mirror forString
, for a method call, returns the return type of the call, etc.This method ignores conversions applied to the value of the node because of its context. For example, in
1 + ""
, the numeric literal will have typeint
, but it is converted toString
by the surrounding concatenation expression. Similarly, inCollections.singletonList(1)
, theASTNumericLiteral
node has typeint
, but the type of the method formal isInteger
, and boxing is applied at runtime. Possibly, an API will be added to expose this information.- Specified by:
getTypeMirror
in interfaceTypeNode
- Returns:
- The type mirror. Never returns null; if the type is unresolved, returns
TypeSystem.UNKNOWN
.
-
getTypeMirror
- Specified by:
getTypeMirror
in interfaceTypeNode
-
jjtClose
public void jjtClose()- Overrides:
jjtClose
in classnet.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
acceptVisitor
public final <P,R> R acceptVisitor(net.sourceforge.pmd.lang.ast.AstVisitor<? super P, ? extends R> visitor, P data) - Specified by:
acceptVisitor
in interfacenet.sourceforge.pmd.lang.ast.Node
-
addChild
protected void addChild(net.sourceforge.pmd.lang.java.ast.AbstractJavaNode child, int index) - Overrides:
addChild
in classnet.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
insertChild
protected void insertChild(net.sourceforge.pmd.lang.java.ast.AbstractJavaNode child, int index) - Overrides:
insertChild
in classnet.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
removeChildAtIndex
protected void removeChildAtIndex(int childIndex) - Overrides:
removeChildAtIndex
in classnet.sourceforge.pmd.lang.ast.impl.AbstractNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
setFirstToken
protected void setFirstToken(net.sourceforge.pmd.lang.ast.impl.javacc.JavaccToken token) - Overrides:
setFirstToken
in classnet.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
setLastToken
protected void setLastToken(net.sourceforge.pmd.lang.ast.impl.javacc.JavaccToken token) - Overrides:
setLastToken
in classnet.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
enlargeLeft
protected void enlargeLeft(net.sourceforge.pmd.lang.ast.impl.javacc.JavaccToken child) - Overrides:
enlargeLeft
in classnet.sourceforge.pmd.lang.ast.impl.javacc.AbstractJjtreeNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
setChild
protected void setChild(net.sourceforge.pmd.lang.java.ast.AbstractJavaNode child, int index) - Overrides:
setChild
in classnet.sourceforge.pmd.lang.ast.impl.AbstractNode<net.sourceforge.pmd.lang.java.ast.AbstractJavaNode,
JavaNode>
-
getSymbolTable
Description copied from interface:JavaNode
Returns the symbol table for the program point represented by this node.- Specified by:
getSymbolTable
in interfaceJavaNode
-
getTypeSystem
Description copied from interface:JavaNode
Returns the type system with which this node was created. This is the object responsible for representing types in the compilation unit.- Specified by:
getTypeSystem
in interfaceJavaNode
-
getRoot
-
getXPathNodeName
- Specified by:
getXPathNodeName
in interfacenet.sourceforge.pmd.lang.ast.Node
-