diff --git a/pmd/etc/changelog.txt b/pmd/etc/changelog.txt index 59bd496044..53aa90c17b 100644 --- a/pmd/etc/changelog.txt +++ b/pmd/etc/changelog.txt @@ -13,6 +13,7 @@ Fixed bug 2002722 - false + in UseStringBufferForStringAppends Fixed bug 2056318 - False positive for AvoidInstantiatingObjectsInLoops Fixed bug 1977438 - False positive for UselessStringValueOf Fixed bug 2050064 - False + SuspiciousOctalEscape with backslash literal +Fixed bug 1556594 - Wonky detection of NullAssignment Optimizations and false positive fixes in PreserveStackTrace @SuppressWarnings("all") disables all warnings All comment types are now stored in ASTCompilationUnit, not just formal ones diff --git a/pmd/regress/test/net/sourceforge/pmd/rules/controversial/xml/NullAssignment.xml b/pmd/regress/test/net/sourceforge/pmd/rules/controversial/xml/NullAssignment.xml index 5094ec04a9..7e6c02975b 100644 --- a/pmd/regress/test/net/sourceforge/pmd/rules/controversial/xml/NullAssignment.xml +++ b/pmd/regress/test/net/sourceforge/pmd/rules/controversial/xml/NullAssignment.xml @@ -113,4 +113,17 @@ public class Foo { } ]]> - \ No newline at end of file + + + 0 + + + diff --git a/pmd/src/net/sourceforge/pmd/rules/design/NullAssignmentRule.java b/pmd/src/net/sourceforge/pmd/rules/design/NullAssignmentRule.java index 55c1f67056..e9e0cd6514 100644 --- a/pmd/src/net/sourceforge/pmd/rules/design/NullAssignmentRule.java +++ b/pmd/src/net/sourceforge/pmd/rules/design/NullAssignmentRule.java @@ -7,6 +7,7 @@ import net.sourceforge.pmd.AbstractRule; import net.sourceforge.pmd.ast.ASTAssignmentOperator; import net.sourceforge.pmd.ast.ASTConditionalExpression; import net.sourceforge.pmd.ast.ASTEqualityExpression; +import net.sourceforge.pmd.ast.ASTExpression; import net.sourceforge.pmd.ast.ASTName; import net.sourceforge.pmd.ast.ASTNullLiteral; import net.sourceforge.pmd.ast.ASTStatementExpression; @@ -30,10 +31,12 @@ public class NullAssignmentRule extends AbstractRule { addViolation(data, node); } } else if (node.getNthParent(4) instanceof ASTConditionalExpression) { + // "false" expression of ternary if (isBadTernary((ASTConditionalExpression)node.getNthParent(4))) { addViolation(data, node); } - } else if (node.getNthParent(5) instanceof ASTConditionalExpression) { + } else if (node.getNthParent(5) instanceof ASTConditionalExpression && node.getNthParent(4) instanceof ASTExpression) { + // "true" expression of ternary if (isBadTernary((ASTConditionalExpression)node.getNthParent(5))) { addViolation(data, node); }