From 6eb9732fac3d321cc4813fd2e3b29c0f64097419 Mon Sep 17 00:00:00 2001 From: Knut Wannheden Date: Fri, 23 Feb 2024 11:29:00 +0100 Subject: [PATCH] Add `UsesMethod.MethodMatch` marker --- .../java/search/HasJavaVersionTest.java | 10 ++--- .../org/openrewrite/java/MethodMatcher.java | 9 ++++ .../org/openrewrite/java/UseStaticImport.java | 3 +- .../openrewrite/java/search/FindMethods.java | 3 +- .../openrewrite/java/search/UsesMethod.java | 43 +++++++++++++++---- 5 files changed, 52 insertions(+), 16 deletions(-) diff --git a/rewrite-java-test/src/test/java/org/openrewrite/java/search/HasJavaVersionTest.java b/rewrite-java-test/src/test/java/org/openrewrite/java/search/HasJavaVersionTest.java index 1e98ecfa381..2974f59d191 100644 --- a/rewrite-java-test/src/test/java/org/openrewrite/java/search/HasJavaVersionTest.java +++ b/rewrite-java-test/src/test/java/org/openrewrite/java/search/HasJavaVersionTest.java @@ -18,7 +18,6 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.provider.ValueSource; -import org.junitpioneer.jupiter.ExpectedToFail; import org.openrewrite.test.RewriteTest; import static org.openrewrite.java.Assertions.java; @@ -97,7 +96,6 @@ void declarativePreconditionMatch() { ); } - @ExpectedToFail @Test void combinedWithFindMethod() { rewriteRun( @@ -111,7 +109,8 @@ void combinedWithFindMethod() { - org.openrewrite.java.search.FindMethods: methodPattern: java.util.List add(..) """, "org.openrewrite.CombinedWithFindMethod"), - java(""" + java( + """ import java.util.List; import java.util.ArrayList; class Test { @@ -121,7 +120,6 @@ void test() { } } """, - """ /*~~>*/import java.util.List; import java.util.ArrayList; @@ -149,7 +147,8 @@ void combinedWithFindMethodFirst() { version: 11 """, "org.openrewrite.CombinedWithFindMethod"), - java(""" + java( + """ import java.util.List; import java.util.ArrayList; class Test { @@ -159,7 +158,6 @@ void test() { } } """, - """ /*~~>*/import java.util.List; import java.util.ArrayList; diff --git a/rewrite-java/src/main/java/org/openrewrite/java/MethodMatcher.java b/rewrite-java/src/main/java/org/openrewrite/java/MethodMatcher.java index a50e00a136e..525a062683c 100644 --- a/rewrite-java/src/main/java/org/openrewrite/java/MethodMatcher.java +++ b/rewrite-java/src/main/java/org/openrewrite/java/MethodMatcher.java @@ -379,6 +379,15 @@ public static String methodPattern(JavaType.Method method) { return typePattern(method.getDeclaringType()) + " " + method.getName() + "(" + parameters + ")"; } + + @Override + public String toString() { + //noinspection DataFlowIssue + return (targetType != null ? targetType : targetTypePattern.pattern()) + + ' ' + + (methodName != null ? methodName : methodNamePattern.pattern()) + + '(' + argumentPattern.pattern() + ')'; + } } class TypeVisitor extends MethodSignatureParserBaseVisitor { diff --git a/rewrite-java/src/main/java/org/openrewrite/java/UseStaticImport.java b/rewrite-java/src/main/java/org/openrewrite/java/UseStaticImport.java index 95153a14cdb..5f07d36e95b 100644 --- a/rewrite-java/src/main/java/org/openrewrite/java/UseStaticImport.java +++ b/rewrite-java/src/main/java/org/openrewrite/java/UseStaticImport.java @@ -65,9 +65,10 @@ public TreeVisitor getVisitor() { } private class UseStaticImportVisitor extends JavaIsoVisitor { + final MethodMatcher methodMatcher = new MethodMatcher(methodPattern); + @Override public J.MethodInvocation visitMethodInvocation(J.MethodInvocation method, ExecutionContext ctx) { - MethodMatcher methodMatcher = new MethodMatcher(methodPattern); J.MethodInvocation m = super.visitMethodInvocation(method, ctx); if (methodMatcher.matches(m)) { if (m.getTypeParameters() != null && !m.getTypeParameters().isEmpty()) { diff --git a/rewrite-java/src/main/java/org/openrewrite/java/search/FindMethods.java b/rewrite-java/src/main/java/org/openrewrite/java/search/FindMethods.java index 46e8feb5099..50456f04b19 100644 --- a/rewrite-java/src/main/java/org/openrewrite/java/search/FindMethods.java +++ b/rewrite-java/src/main/java/org/openrewrite/java/search/FindMethods.java @@ -67,8 +67,9 @@ public String getDescription() { @Override @SuppressWarnings("ConstantConditions") public TreeVisitor getVisitor() { - MethodMatcher methodMatcher = new MethodMatcher(methodPattern, matchOverrides); return Preconditions.check(new UsesMethod<>(methodPattern, matchOverrides), new JavaIsoVisitor() { + final MethodMatcher methodMatcher = new MethodMatcher(methodPattern, matchOverrides); + @Override public J.MethodInvocation visitMethodInvocation(J.MethodInvocation method, ExecutionContext ctx) { J.MethodInvocation m = super.visitMethodInvocation(method, ctx); diff --git a/rewrite-java/src/main/java/org/openrewrite/java/search/UsesMethod.java b/rewrite-java/src/main/java/org/openrewrite/java/search/UsesMethod.java index 48ae2153d84..77d7f54c0f9 100644 --- a/rewrite-java/src/main/java/org/openrewrite/java/search/UsesMethod.java +++ b/rewrite-java/src/main/java/org/openrewrite/java/search/UsesMethod.java @@ -15,6 +15,9 @@ */ package org.openrewrite.java.search; +import lombok.EqualsAndHashCode; +import lombok.Value; +import lombok.With; import org.openrewrite.Tree; import org.openrewrite.internal.lang.Nullable; import org.openrewrite.java.JavaIsoVisitor; @@ -22,25 +25,35 @@ import org.openrewrite.java.tree.J; import org.openrewrite.java.tree.JavaSourceFile; import org.openrewrite.java.tree.JavaType; -import org.openrewrite.marker.SearchResult; +import org.openrewrite.marker.Marker; + +import java.util.UUID; + +import static org.openrewrite.Tree.randomId; public class UsesMethod

extends JavaIsoVisitor

{ + private final String methodPattern; private final MethodMatcher methodMatcher; public UsesMethod(String methodPattern) { - this(new MethodMatcher(methodPattern)); + this(new MethodMatcher(methodPattern), methodPattern); } public UsesMethod(String methodPattern, boolean matchOverrides) { - this(new MethodMatcher(methodPattern, matchOverrides)); + this(new MethodMatcher(methodPattern, matchOverrides), methodPattern); } public UsesMethod(String methodPattern, @Nullable Boolean matchOverrides) { - this(new MethodMatcher(methodPattern, Boolean.TRUE.equals(matchOverrides))); + this(new MethodMatcher(methodPattern, Boolean.TRUE.equals(matchOverrides)), methodPattern); } public UsesMethod(MethodMatcher methodMatcher) { + this(methodMatcher, methodMatcher.toString()); + } + + private UsesMethod(MethodMatcher methodMatcher, String methodPattern) { this.methodMatcher = methodMatcher; + this.methodPattern = methodPattern; } @Override @@ -49,7 +62,7 @@ public J visit(@Nullable Tree tree, P p) { JavaSourceFile cu = (JavaSourceFile) tree; for (JavaType.Method type : cu.getTypesInUse().getUsedMethods()) { if (methodMatcher.matches(type)) { - return SearchResult.found(cu); + return found(cu); } } return (J) tree; @@ -57,10 +70,15 @@ public J visit(@Nullable Tree tree, P p) { return super.visit(tree, p); } + private J2 found(J2 j) { + return j.withMarkers(j.getMarkers() + .compute(new MethodMatch(randomId(), methodPattern), (s1, s2) -> s1 == null ? s2 : s1)); + } + @Override public J.MethodInvocation visitMethodInvocation(J.MethodInvocation method, P p) { if (methodMatcher.matches(method)) { - return SearchResult.found(method); + return found(method); } return super.visitMethodInvocation(method, p); } @@ -68,7 +86,7 @@ public J.MethodInvocation visitMethodInvocation(J.MethodInvocation method, P p) @Override public J.MemberReference visitMemberReference(J.MemberReference memberRef, P p) { if (methodMatcher.matches(memberRef)) { - return SearchResult.found(memberRef); + return found(memberRef); } return super.visitMemberReference(memberRef, p); } @@ -76,8 +94,17 @@ public J.MemberReference visitMemberReference(J.MemberReference memberRef, P p) @Override public J.NewClass visitNewClass(J.NewClass newClass, P p) { if (methodMatcher.matches(newClass)) { - return SearchResult.found(newClass); + return found(newClass); } return super.visitNewClass(newClass, p); } + + @Value + @With + @EqualsAndHashCode(onlyExplicitlyIncluded = true) + static class MethodMatch implements Marker { + UUID id; + @EqualsAndHashCode.Include + String methodMatcher; + } }