diff options
author | Evgeny Mandrikov <mandrikov@gmail.com> | 2011-12-13 18:10:57 +0400 |
---|---|---|
committer | Evgeny Mandrikov <mandrikov@gmail.com> | 2011-12-13 19:54:07 +0400 |
commit | 81cffc0f9e4ba50a873f72de195345216c66559b (patch) | |
tree | bb46fd9f3c73731f09c5e5df7bf4484c4cc0662f | |
parent | 65cb425e561a1789beee8baa12e6b1aace140c15 (diff) | |
download | sonarqube-81cffc0f9e4ba50a873f72de195345216c66559b.tar.gz sonarqube-81cffc0f9e4ba50a873f72de195345216c66559b.zip |
SONAR-2018 Improve rule for detection of commented-out code
* Only one violation in one block of comment.
* Proper recognition of Javadocs.
-rw-r--r-- | plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/check/CommentedOutCodeLineCheck.java | 126 | ||||
-rw-r--r-- | plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/visitor/CommentVisitor.java | 1 | ||||
-rw-r--r-- | plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/squid/check/CommentedOutCodeLineCheck.java | 39 | ||||
-rw-r--r-- | plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/SquidRuleRepository.java | 1 | ||||
-rw-r--r-- | plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/ast/check/CommentedOutCodeLineCheckTest.java (renamed from plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/squid/check/CommentedOutCodeLineCheckTest.java) | 19 | ||||
-rw-r--r-- | plugins/sonar-squid-java-plugin/test-resources/rules/CommentedCode.java | 62 | ||||
-rw-r--r-- | sonar-squid/src/main/java/org/sonar/squid/api/SourceFile.java | 14 | ||||
-rw-r--r-- | sonar-squid/src/main/java/org/sonar/squid/text/Source.java | 9 |
8 files changed, 191 insertions, 80 deletions
diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/check/CommentedOutCodeLineCheck.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/check/CommentedOutCodeLineCheck.java new file mode 100644 index 00000000000..d4d42781297 --- /dev/null +++ b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/check/CommentedOutCodeLineCheck.java @@ -0,0 +1,126 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2008-2011 SonarSource + * mailto:contact AT sonarsource DOT com + * + * Sonar is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * Sonar is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with Sonar; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 + */ +package org.sonar.java.ast.check; + +import java.util.Arrays; +import java.util.List; +import java.util.Set; + +import org.sonar.check.Priority; +import org.sonar.check.Rule; +import org.sonar.java.ast.visitor.AstUtils; +import org.sonar.java.ast.visitor.JavaAstVisitor; +import org.sonar.java.recognizer.JavaFootprint; +import org.sonar.squid.api.CheckMessage; +import org.sonar.squid.api.SourceFile; +import org.sonar.squid.recognizer.CodeRecognizer; + +import com.google.common.collect.Sets; +import com.puppycrawl.tools.checkstyle.api.DetailAST; +import com.puppycrawl.tools.checkstyle.api.TextBlock; +import com.puppycrawl.tools.checkstyle.api.TokenTypes; + +@Rule(key = "CommentedOutCodeLine", priority = Priority.MAJOR) +public class CommentedOutCodeLineCheck extends JavaAstVisitor { + + private static final double THRESHOLD = 0.9; + + /** + * This list was taken from com.puppycrawl.tools.checkstyle.checks.javadoc.JavadocStyleCheck + */ + private static final List<Integer> WANTED_TOKENS = Arrays.asList( + TokenTypes.INTERFACE_DEF, + TokenTypes.CLASS_DEF, + TokenTypes.ANNOTATION_DEF, + TokenTypes.ENUM_DEF, + TokenTypes.METHOD_DEF, + TokenTypes.CTOR_DEF, + TokenTypes.VARIABLE_DEF, + TokenTypes.ENUM_CONSTANT_DEF, + TokenTypes.ANNOTATION_FIELD_DEF, + TokenTypes.PACKAGE_DEF); + + private final CodeRecognizer codeRecognizer; + private Set<TextBlock> comments; + + public CommentedOutCodeLineCheck() { + codeRecognizer = new CodeRecognizer(THRESHOLD, new JavaFootprint()); + } + + @Override + public List<Integer> getWantedTokens() { + return WANTED_TOKENS; + } + + @Override + public void visitFile(DetailAST ast) { + comments = Sets.newHashSet(); + + for (TextBlock comment : getFileContents().getCppComments().values()) { + comments.add(comment); + } + + for (List<TextBlock> listOfComments : getFileContents().getCComments().values()) { + // This list contains not only comments in C style, but also Javadocs + for (TextBlock comment : listOfComments) { + comments.add(comment); + } + } + } + + /** + * Documentation comments should be recognized only when placed + * immediately before class, interface, constructor, method, or field declarations. + */ + @Override + public void visitToken(DetailAST ast) { + if (shouldHandle(ast)) { + TextBlock javadoc = getFileContents().getJavadocBefore(ast.getLineNo()); + if (javadoc != null) { + comments.remove(javadoc); + } + } + } + + private static boolean shouldHandle(DetailAST ast) { + if (AstUtils.isType(ast, TokenTypes.VARIABLE_DEF)) { + return AstUtils.isClassVariable(ast); + } + return true; + } + + @Override + public void leaveFile(DetailAST ast) { + SourceFile sourceFile = (SourceFile) peekSourceCode(); + for (TextBlock comment : comments) { + String[] lines = comment.getText(); + for (int i = 0; i < lines.length; i++) { + if (codeRecognizer.isLineOfCode(lines[i])) { + CheckMessage message = new CheckMessage(this, "It's better to remove commented-out line of code."); + message.setLine(comment.getStartLineNo() + i); + sourceFile.log(message); + break; + } + } + } + comments = null; + } + +} diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/visitor/CommentVisitor.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/visitor/CommentVisitor.java index 1be27168475..5fd989083c0 100644 --- a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/visitor/CommentVisitor.java +++ b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/ast/visitor/CommentVisitor.java @@ -51,7 +51,6 @@ public class CommentVisitor extends JavaAstVisitor { public void visitFile(DetailAST ast) { SourceFile file = (SourceFile) peekSourceCode(); file.addNoSonarTagLines(getSource().getNoSonarTagLines()); - file.addCommentedOutCodeLines(getSource().getCommentedOutCodeLines()); file.setMeasure(Metric.HEADER_COMMENT_LINES, getSource().getMeasure(Metric.HEADER_COMMENT_LINES)); file.setMeasure(Metric.COMMENTED_OUT_CODE_LINES, getSource().getMeasure(Metric.COMMENTED_OUT_CODE_LINES)); file.setMeasure(Metric.COMMENT_LINES, getSource().getMeasure(Metric.COMMENT_LINES)); diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/squid/check/CommentedOutCodeLineCheck.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/squid/check/CommentedOutCodeLineCheck.java deleted file mode 100644 index 1e65f01c51b..00000000000 --- a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/java/squid/check/CommentedOutCodeLineCheck.java +++ /dev/null @@ -1,39 +0,0 @@ -/* - * Sonar, open source software quality management tool. - * Copyright (C) 2008-2011 SonarSource - * mailto:contact AT sonarsource DOT com - * - * Sonar is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or (at your option) any later version. - * - * Sonar is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with Sonar; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 - */ -package org.sonar.java.squid.check; - -import org.sonar.check.Priority; -import org.sonar.check.Rule; -import org.sonar.squid.api.CheckMessage; -import org.sonar.squid.api.SourceFile; - -@Rule(key = "CommentedOutCodeLine", priority = Priority.MAJOR) -public class CommentedOutCodeLineCheck extends SquidCheck { - - @Override - public void visitFile(SourceFile sourceFile) { - for (Integer line : sourceFile.getCommentedOutCodeLines()) { - CheckMessage message = new CheckMessage(this, "It's better to remove commented-out line of code."); - message.setLine(line); - sourceFile.log(message); - } - } - -} diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/SquidRuleRepository.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/SquidRuleRepository.java index f2a93a76dbe..017ae33a215 100644 --- a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/SquidRuleRepository.java +++ b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/SquidRuleRepository.java @@ -28,6 +28,7 @@ import org.sonar.api.rules.AnnotationRuleParser; import org.sonar.api.rules.Rule; import org.sonar.api.rules.RuleRepository; import org.sonar.java.ast.check.BreakCheck; +import org.sonar.java.ast.check.CommentedOutCodeLineCheck; import org.sonar.java.ast.check.ContinueCheck; import org.sonar.java.ast.check.UndocumentedApiCheck; import org.sonar.java.bytecode.check.ArchitectureCheck; diff --git a/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/squid/check/CommentedOutCodeLineCheckTest.java b/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/ast/check/CommentedOutCodeLineCheckTest.java index a479d3a409c..b231567b3b8 100644 --- a/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/squid/check/CommentedOutCodeLineCheckTest.java +++ b/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/ast/check/CommentedOutCodeLineCheckTest.java @@ -17,7 +17,7 @@ * License along with Sonar; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 */ -package org.sonar.java.squid.check; +package org.sonar.java.ast.check; import org.junit.Before; import org.junit.Test; @@ -48,10 +48,19 @@ public class CommentedOutCodeLineCheckTest { @Test public void testDetection() { CheckMessages checkMessages = new CheckMessages((SourceFile) squid.search("CommentedCode.java")); - checkMessages.assertNext().atLine(4); - checkMessages.assertNext().atLine(17); - checkMessages.assertNext().atLine(18); - checkMessages.assertNext().atLine(19); + + checkMessages.assertNext().atLine(26); + checkMessages.assertNext().atLine(27); + checkMessages.assertNext().atLine(28); + + checkMessages.assertNext().atLine(32); + + checkMessages.assertNext().atLine(38); + checkMessages.assertNext().atLine(39); + checkMessages.assertNext().atLine(40); + + checkMessages.assertNext().atLine(44); + checkMessages.assertNoMore(); } diff --git a/plugins/sonar-squid-java-plugin/test-resources/rules/CommentedCode.java b/plugins/sonar-squid-java-plugin/test-resources/rules/CommentedCode.java index 0a44bc77d2a..c7aa40ba06e 100644 --- a/plugins/sonar-squid-java-plugin/test-resources/rules/CommentedCode.java +++ b/plugins/sonar-squid-java-plugin/test-resources/rules/CommentedCode.java @@ -1,22 +1,60 @@ +/** + * No detection of commented-out code in Javadoc for class + * for (Visitor visitor : visitors) { + * continue; + * } + */ public class CommentedCode { - public CommentedCode() { - //This is a comment - //if (true) { - int i = 2; - } /** - * No detection of commented code line in Javadoc bloc - * - * public void main(){ - * + * No detection of commented-out code in Javadoc for field + * for (Visitor visitor : visitors) { + * continue; * } */ - public void analyse() { + private int field; + + /** + * No detection of commented-out code in Javadoc for constructor + * for (Visitor visitor : visitors) { + * continue; + * } + */ + public CommentedCode(int field) { + this.field = field; + // This is a comment, but next line is a commented-out code + // for (Visitor visitor : visitors) { + // continue; + // } + /* - for(Visitor visitor : visitors){ - visitor.scan(line); + This is a comment, but next line is a commented-out code + for (Visitor visitor : visitors) { + continue; } */ + + /* This is a comment, but next line is a commented-out code */ + /* for (Visitor visitor : visitors) { */ + /* continue; */ + /* } */ + + /** + * This is not Javadoc, even if it looks like Javadoc and before declaration of variable + * for (Visitor visitor : visitors) { + * continue; + * } + */ + int a; + } + + /** + * No detection of commented-out code in Javadoc for method + * for (Visitor visitor : visitors) { + * continue; + * } + */ + public int getField() { + return field; } } diff --git a/sonar-squid/src/main/java/org/sonar/squid/api/SourceFile.java b/sonar-squid/src/main/java/org/sonar/squid/api/SourceFile.java index 922c5ca26b1..27d06e6f652 100644 --- a/sonar-squid/src/main/java/org/sonar/squid/api/SourceFile.java +++ b/sonar-squid/src/main/java/org/sonar/squid/api/SourceFile.java @@ -26,7 +26,6 @@ import java.util.Set; public class SourceFile extends SourceCode { private Set<Integer> noSonarTagLines = new HashSet<Integer>(); - private Set<Integer> commentedOutCodeLines = new HashSet<Integer>(); public SourceFile(String key) { super(key); @@ -54,17 +53,4 @@ public class SourceFile extends SourceCode { noSonarTagLines.add(line); } - /** - * @since 2.13 - */ - public Set<Integer> getCommentedOutCodeLines() { - return commentedOutCodeLines; - } - - /** - * @since 2.13 - */ - public void addCommentedOutCodeLines(Set<Integer> commentedOutCodeLines) { - this.commentedOutCodeLines.addAll(commentedOutCodeLines); - } } diff --git a/sonar-squid/src/main/java/org/sonar/squid/text/Source.java b/sonar-squid/src/main/java/org/sonar/squid/text/Source.java index 7d4510f8db1..8e6b51b4714 100644 --- a/sonar-squid/src/main/java/org/sonar/squid/text/Source.java +++ b/sonar-squid/src/main/java/org/sonar/squid/text/Source.java @@ -33,7 +33,6 @@ public class Source { private List<Line> lines = new ArrayList<Line>(); private CodeRecognizer codeRecognizer; private Set<Integer> noSonarTagLines = new HashSet<Integer>(); - private Set<Integer> commentedOutCodeLines = new HashSet<Integer>(); public Source(Reader reader, CodeRecognizer codeRecognizer, String... additionalSingleLineCommentFlag) { this.codeRecognizer = codeRecognizer; @@ -88,7 +87,6 @@ public class Source { line.setMeasure(Metric.COMMENT_LINES, 1); } else { line.setMeasure(Metric.COMMENTED_OUT_CODE_LINES, 1); - commentedOutCodeLines.add(line.getLineIndex()); } } } @@ -127,11 +125,4 @@ public class Source { public Set<Integer> getNoSonarTagLines() { return noSonarTagLines; } - - /** - * @since 2.13 - */ - public Set<Integer> getCommentedOutCodeLines() { - return commentedOutCodeLines; - } } |