io.codemodder.codemods.RemoveUnusedImportCodemod Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of core-codemods Show documentation
Show all versions of core-codemods Show documentation
Codemods for fixing common errors across many Java projects
package io.codemodder.codemods;
import com.github.javaparser.ast.CompilationUnit;
import com.github.javaparser.ast.ImportDeclaration;
import io.codemodder.Codemod;
import io.codemodder.CodemodExecutionPriority;
import io.codemodder.CodemodInvocationContext;
import io.codemodder.Importance;
import io.codemodder.NodeCollector;
import io.codemodder.RegionNodeMatcher;
import io.codemodder.ReviewGuidance;
import io.codemodder.codetf.DetectorRule;
import io.codemodder.javaparser.ChangesResult;
import io.codemodder.providers.sonar.ProvidedSonarScan;
import io.codemodder.providers.sonar.RuleIssue;
import io.codemodder.providers.sonar.SonarPluginJavaParserChanger;
import io.codemodder.sonar.model.Issue;
import javax.inject.Inject;
@Codemod(
id = "sonar:java/remove-unused-import-s1128",
reviewGuidance = ReviewGuidance.MERGE_WITHOUT_REVIEW,
importance = Importance.LOW,
executionPriority = CodemodExecutionPriority.HIGH)
public final class RemoveUnusedImportCodemod
extends SonarPluginJavaParserChanger {
@Inject
public RemoveUnusedImportCodemod(
@ProvidedSonarScan(ruleId = "java:S1128") final RuleIssue issues) {
super(
issues,
ImportDeclaration.class,
/*
* This codemod uses a less strict RegionNodeMatcher because the import declaration technically starts on column
* 1 according to java parser but sonar reports the unused import starting from the import keyword, on column 8,
* which is where the unused name is actually located. Neither are technically incorrect, but we can be less
* strict with matching here given how relatively simple the import declaration is.
*/
RegionNodeMatcher.MATCHES_LINE,
NodeCollector.ALL_FROM_TYPE);
}
@Override
public ChangesResult onFindingFound(
CodemodInvocationContext context, CompilationUnit cu, ImportDeclaration node, Issue issue) {
if (issue.getMessage().contains(node.getNameAsString())) {
return cu.remove(node) ? ChangesResult.changesApplied : ChangesResult.noChanges;
} else {
return ChangesResult.noChanges;
}
}
@Override
public DetectorRule detectorRule() {
return new DetectorRule(
"java:S1128",
"Unnecessary imports should be removed",
"https://rules.sonarsource.com/java/RSPEC-1128");
}
}