From ba903437c097c6d5e9344bc19c9b4c87cf652cbe Mon Sep 17 00:00:00 2001 From: Andreas Dangel Date: Tue, 21 Dec 2021 19:04:59 +0100 Subject: [PATCH] [apex] ApexDoc - handle properties via "reportProperty". --- .../apex/rule/documentation/ApexDocRule.java | 34 +++++++++++-------- .../resources/category/apex/documentation.xml | 4 ++- .../apex/rule/documentation/xml/ApexDoc.xml | 23 +++++++++++-- 3 files changed, 43 insertions(+), 18 deletions(-) diff --git a/pmd-apex/src/main/java/net/sourceforge/pmd/lang/apex/rule/documentation/ApexDocRule.java b/pmd-apex/src/main/java/net/sourceforge/pmd/lang/apex/rule/documentation/ApexDocRule.java index 5af37e9b76..be33bc1c04 100644 --- a/pmd-apex/src/main/java/net/sourceforge/pmd/lang/apex/rule/documentation/ApexDocRule.java +++ b/pmd-apex/src/main/java/net/sourceforge/pmd/lang/apex/rule/documentation/ApexDocRule.java @@ -38,25 +38,25 @@ public class ApexDocRule extends AbstractApexRule { private static final PropertyDescriptor REPORT_PRIVATE_DESCRIPTOR = booleanProperty("reportPrivate") - .desc("Report private classes and methods").defaultValue(false).build(); + .desc("Report private classes, methods and properties").defaultValue(false).build(); private static final PropertyDescriptor REPORT_PROTECTED_DESCRIPTOR = booleanProperty("reportProtected") - .desc("Report protected methods").defaultValue(false).build(); + .desc("Report protected classes, methods and properties").defaultValue(false).build(); private static final PropertyDescriptor REPORT_MISSING_DESCRIPTION_DESCRIPTOR = booleanProperty("reportMissingDescription") .desc("Report missing @description").defaultValue(true).build(); - private static final PropertyDescriptor REPORT_MISSING_PROPERTY_DESCRIPTOR = - booleanProperty("reportMissingProperty") - .desc("Report missing properties").defaultValue(true).build(); + private static final PropertyDescriptor REPORT_PROPERTY_DESCRIPTOR = + booleanProperty("reportProperty") + .desc("Report properties without comments").defaultValue(true).build(); public ApexDocRule() { definePropertyDescriptor(REPORT_PRIVATE_DESCRIPTOR); definePropertyDescriptor(REPORT_PROTECTED_DESCRIPTOR); definePropertyDescriptor(REPORT_MISSING_DESCRIPTION_DESCRIPTOR); - definePropertyDescriptor(REPORT_MISSING_PROPERTY_DESCRIPTOR); + definePropertyDescriptor(REPORT_PROPERTY_DESCRIPTOR); addRuleChainVisit(ASTUserClass.class); addRuleChainVisit(ASTUserInterface.class); @@ -119,15 +119,13 @@ public class ApexDocRule extends AbstractApexRule { public Object visit(ASTProperty node, Object data) { ApexDocComment comment = getApexDocComment(node); - if (getProperty(REPORT_MISSING_PROPERTY_DESCRIPTOR)) { - if (comment == null) { - if (shouldHaveApexDocs(node)) { - addViolationWithMessage(data, node, MISSING_COMMENT_MESSAGE); - } - } else { - if (getProperty(REPORT_MISSING_DESCRIPTION_DESCRIPTOR) && !comment.hasDescription) { - addViolationWithMessage(data, node, MISSING_DESCRIPTION_MESSAGE); - } + if (comment == null) { + if (shouldHaveApexDocs(node)) { + addViolationWithMessage(data, node, MISSING_COMMENT_MESSAGE); + } + } else { + if (getProperty(REPORT_MISSING_DESCRIPTION_DESCRIPTOR) && !comment.hasDescription) { + addViolationWithMessage(data, node, MISSING_DESCRIPTION_MESSAGE); } } @@ -159,12 +157,18 @@ public class ApexDocRule extends AbstractApexRule { } } + // is it a property? + if (node instanceof ASTProperty && !getProperty(REPORT_PROPERTY_DESCRIPTOR)) { + return false; + } + ASTModifierNode modifier = node.getFirstChildOfType(ASTModifierNode.class); if (modifier != null) { boolean flagPrivate = getProperty(REPORT_PRIVATE_DESCRIPTOR) && modifier.isPrivate(); boolean flagProtected = getProperty(REPORT_PROTECTED_DESCRIPTOR) && modifier.isProtected(); return (modifier.isPublic() || modifier.isGlobal() || flagPrivate || flagProtected) && !modifier.isOverride(); } + return false; } diff --git a/pmd-apex/src/main/resources/category/apex/documentation.xml b/pmd-apex/src/main/resources/category/apex/documentation.xml index de9ffc875a..bbe588d08f 100644 --- a/pmd-apex/src/main/resources/category/apex/documentation.xml +++ b/pmd-apex/src/main/resources/category/apex/documentation.xml @@ -22,11 +22,13 @@ This rule validates that: overrides and test classes (as well as the contents of test classes). * ApexDoc comments are present for classes, methods, and properties that are protected or private, depending on the properties `reportPrivate` and `reportProtected`. -* ApexDoc comments should contain @description depending on the property 'reportMissingDescription'. +* ApexDoc comments should contain @description depending on the property `reportMissingDescription`. * ApexDoc comments on non-void, non-constructor methods should contain @return. * ApexDoc comments on void or constructor methods should not contain @return. * ApexDoc comments on methods with parameters should contain @param for each parameter, in the same order as the method signature. +* ApexDoc comments are present on properties is only validated, if the property `reportProperty` is enabled. + By setting `reportProperty` to false, you can ignore missing comments on properties. Method overrides and tests are both exempted from having ApexDoc. diff --git a/pmd-apex/src/test/resources/net/sourceforge/pmd/lang/apex/rule/documentation/xml/ApexDoc.xml b/pmd-apex/src/test/resources/net/sourceforge/pmd/lang/apex/rule/documentation/xml/ApexDoc.xml index 1b221deccc..3f0bc23b07 100644 --- a/pmd-apex/src/test/resources/net/sourceforge/pmd/lang/apex/rule/documentation/xml/ApexDoc.xml +++ b/pmd-apex/src/test/resources/net/sourceforge/pmd/lang/apex/rule/documentation/xml/ApexDoc.xml @@ -634,8 +634,9 @@ public class Foo { property should have comment - true + true 1 + 5 + + property with missing description + false + 1 + 8 + + + property does not need comment - false + false 0