From 72cecec95b39ff4ece21618d2c6172819033d0d9 Mon Sep 17 00:00:00 2001 From: Evgeny Mandrikov Date: Tue, 13 Dec 2011 20:58:33 +0400 Subject: SONAR-2018 Improve rule for detection of commented-out code JSNI methods (GWT) should not be considered as commented-out code. --- .../java/ast/check/CommentedOutCodeLineCheck.java | 21 +++++++++++++++++++-- .../ast/check/CommentedOutCodeLineCheckTest.java | 2 +- 2 files changed, 20 insertions(+), 3 deletions(-) (limited to 'plugins/sonar-squid-java-plugin/src') 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 index d4d42781297..da7e1160aa2 100644 --- 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 @@ -23,6 +23,7 @@ import java.util.Arrays; import java.util.List; import java.util.Set; +import org.apache.commons.lang.StringUtils; import org.sonar.check.Priority; import org.sonar.check.Rule; import org.sonar.java.ast.visitor.AstUtils; @@ -78,9 +79,11 @@ public class CommentedOutCodeLineCheck extends JavaAstVisitor { } for (List listOfComments : getFileContents().getCComments().values()) { - // This list contains not only comments in C style, but also Javadocs + // This list contains not only comments in C style, but also Javadocs and JSNI comments for (TextBlock comment : listOfComments) { - comments.add(comment); + if (!isJSNI(comment)) { + comments.add(comment); + } } } } @@ -123,4 +126,18 @@ public class CommentedOutCodeLineCheck extends JavaAstVisitor { comments = null; } + private static final String START_JSNI = "/*-{"; + private static final String END_JSNI = "}-*/"; + + /** + * From GWT documentation: + * A JSNI comment block begins with the exact token {@link #START_JSNI} and ends with the exact token {@link #END_JSNI}. + */ + private boolean isJSNI(TextBlock comment) { + String[] lines = comment.getText(); + String firstLine = lines[0]; + String lastLine = lines[lines.length - 1]; + return StringUtils.startsWith(firstLine, START_JSNI) && StringUtils.endsWith(lastLine, END_JSNI); + } + } diff --git a/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/ast/check/CommentedOutCodeLineCheckTest.java b/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/ast/check/CommentedOutCodeLineCheckTest.java index b231567b3b8..2322b1bbdf5 100644 --- a/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/ast/check/CommentedOutCodeLineCheckTest.java +++ b/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/java/ast/check/CommentedOutCodeLineCheckTest.java @@ -49,7 +49,7 @@ public class CommentedOutCodeLineCheckTest { public void testDetection() { CheckMessages checkMessages = new CheckMessages((SourceFile) squid.search("CommentedCode.java")); - checkMessages.assertNext().atLine(26); + checkMessages.assertNext().atLine(26).withMessage("It's better to remove commented-out line of code."); checkMessages.assertNext().atLine(27); checkMessages.assertNext().atLine(28); -- cgit v1.2.3