From 849ccd87201bce3736945083674a61fa827d80ef Mon Sep 17 00:00:00 2001 From: Tim te Beek Date: Wed, 12 Oct 2022 12:19:35 +0200 Subject: [PATCH] JDeprScan release 17 --- .../java/migrate/AddJDeprScanPlugin.java | 27 +++++++++++-------- .../META-INF/rewrite/java-version-17.yml | 2 ++ 2 files changed, 18 insertions(+), 11 deletions(-) diff --git a/src/main/java/org/openrewrite/java/migrate/AddJDeprScanPlugin.java b/src/main/java/org/openrewrite/java/migrate/AddJDeprScanPlugin.java index aeddb2c060..cec6e6d5a5 100644 --- a/src/main/java/org/openrewrite/java/migrate/AddJDeprScanPlugin.java +++ b/src/main/java/org/openrewrite/java/migrate/AddJDeprScanPlugin.java @@ -15,11 +15,12 @@ */ package org.openrewrite.java.migrate; -import org.openrewrite.ExecutionContext; -import org.openrewrite.Incubating; -import org.openrewrite.Recipe; -import org.openrewrite.SourceFile; +import lombok.Getter; +import lombok.RequiredArgsConstructor; + +import org.openrewrite.*; import org.openrewrite.internal.ListUtils; +import org.openrewrite.internal.StringUtils; import org.openrewrite.maven.AddPlugin; import org.openrewrite.maven.MavenVisitor; import org.openrewrite.maven.tree.MavenResolutionResult; @@ -29,12 +30,17 @@ import java.util.List; /** - * This imperative recipe will add the jdeprsacn plugin to a maven project. In the case of a multi-module project, + * This imperative recipe will add the jdeprscan plugin to a maven project. In the case of a multi-module project, * this recipe will attempt to add the plugin to only the top level project. */ @Incubating(since = "0.2.0") +@RequiredArgsConstructor +@Getter public class AddJDeprScanPlugin extends Recipe { + @Option(displayName = "release", description = "Specifies the Java SE release that provides the set of deprecated APIs for scanning.", required = false, example = "11") + private final String release; + @Override public String getDisplayName() { return "Add JDeprScan Maven Plug-in"; @@ -53,14 +59,15 @@ public Duration getEstimatedEffortPerOccurrence() { @Override protected List visit(List before, ExecutionContext ctx) { return ListUtils.map(before, s -> { - if ("pom.xml".equals(s.getSourcePath().toString()) && s.getMarkers().findFirst(MavenResolutionResult.class).isPresent()) { + if ("pom.xml".equals(s.getSourcePath().toString()) + && s.getMarkers().findFirst(MavenResolutionResult.class).isPresent()) { return (SourceFile) new AddJDeprScanPluginVisitor().visit(s, ctx); } return s; }); } - private static class AddJDeprScanPluginVisitor extends MavenVisitor { + private class AddJDeprScanPluginVisitor extends MavenVisitor { @Override public Xml visitDocument(Xml.Document document, ExecutionContext o) { @@ -68,10 +75,8 @@ public Xml visitDocument(Xml.Document document, ExecutionContext o) { "org.apache.maven.plugins", "maven-jdeprscan-plugin", "3.0.0-alpha-1", - "" + - "\n" + - " 11\n" + - "", + String.format("\n %s\n", + StringUtils.isNullOrEmpty(getRelease()) ? "11" : getRelease()), null, null)); return document; diff --git a/src/main/resources/META-INF/rewrite/java-version-17.yml b/src/main/resources/META-INF/rewrite/java-version-17.yml index 0020e665d3..4e0202f417 100644 --- a/src/main/resources/META-INF/rewrite/java-version-17.yml +++ b/src/main/resources/META-INF/rewrite/java-version-17.yml @@ -32,3 +32,5 @@ recipeList: newValue: 17 addIfMissing: false - org.openrewrite.java.migrate.lang.StringFormatted + - org.openrewrite.java.migrate.AddJDeprScanPlugin: + release: 17