Skip to content

Commit

Permalink
Support inlining TypeArguments of UMethodInvocations in `@AfterTempla…
Browse files Browse the repository at this point in the history
…te`s
  • Loading branch information
rickie authored and Stephan202 committed Dec 10, 2021
1 parent 96f6854 commit ca193c0
Show file tree
Hide file tree
Showing 7 changed files with 107 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,14 +34,28 @@
*/
@AutoValue
public abstract class UMethodInvocation extends UExpression implements MethodInvocationTree {
public static UMethodInvocation create(UExpression methodSelect, List<UExpression> arguments) {
return new AutoValue_UMethodInvocation(methodSelect, ImmutableList.copyOf(arguments));
public static UMethodInvocation create(
List<? extends UExpression> typeArguments,
UExpression methodSelect,
List<UExpression> arguments) {
return new AutoValue_UMethodInvocation(
ImmutableList.copyOf(typeArguments), methodSelect, ImmutableList.copyOf(arguments));
}

public static UMethodInvocation create(
List<? extends UExpression> typeArguments,
UExpression methodSelect,
UExpression... arguments) {
return create(typeArguments, methodSelect, ImmutableList.copyOf(arguments));
}

public static UMethodInvocation create(UExpression methodSelect, UExpression... arguments) {
return create(methodSelect, ImmutableList.copyOf(arguments));
return create(ImmutableList.of(), methodSelect, ImmutableList.copyOf(arguments));
}

@Override
public abstract ImmutableList<UExpression> getTypeArguments();

@Override
public abstract UExpression getMethodSelect();

Expand Down Expand Up @@ -69,17 +83,12 @@ public Kind getKind() {
return Kind.METHOD_INVOCATION;
}

@Override
public List<UTree<?>> getTypeArguments() {
return ImmutableList.of();
}

@Override
public JCMethodInvocation inline(Inliner inliner) throws CouldNotResolveImportException {
return inliner
.maker()
.Apply(
com.sun.tools.javac.util.List.<JCExpression>nil(),
inliner.<JCExpression>inlineList(getTypeArguments()),
getMethodSelect().inline(inliner),
inliner.<JCExpression>inlineList(getArguments()));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -464,7 +464,9 @@ public UExpression visitMethodInvocation(MethodInvocationTree tree, Void v) {
templateExpressions(tree.getArguments()));
} else {
return UMethodInvocation.create(
template(tree.getMethodSelect()), templateExpressions(tree.getArguments()));
templateTypeExpressions(tree.getTypeArguments()),
template(tree.getMethodSelect()),
templateExpressions(tree.getArguments()));
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -365,4 +365,9 @@ public void staticImportClassToken() throws IOException {
public void suppressWarnings() throws IOException {
runTest("SuppressWarningsTemplate");
}

@Test
public void typeArgumentsMethodInvocation() throws IOException {
runTest("TypeArgumentsMethodInvocationTemplate");
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,8 @@ public void match() {
ULiteral oneLit = ULiteral.intLit(1);
ULiteral barLit = ULiteral.stringLit("bar");
UMethodInvocation invocation =
UMethodInvocation.create(fooIdent, ImmutableList.<UExpression>of(oneLit, barLit));
UMethodInvocation.create(
ImmutableList.of(), fooIdent, ImmutableList.<UExpression>of(oneLit, barLit));
assertUnifies("foo(1, \"bar\")", invocation);
}

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
/*
* Copyright 2021 The Error Prone Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/

package com.google.errorprone.refaster.testdata;

/** Test data for {@code TypeArgumentsMethodInvocationTemplate}. */
public class TypeArgumentsMethodInvocationTemplateExample {
public boolean example() {
String s = "";
return s.isEmpty();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
/*
* Copyright 2021 The Error Prone Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/

package com.google.errorprone.refaster.testdata;

/** Test data for {@code TypeArgumentsMethodInvocationTemplate}. */
public class TypeArgumentsMethodInvocationTemplateExample {
public boolean example() {
String s = "";
return s.<String>isEmpty();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
/*
* Copyright 2021 The Error Prone Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package com.google.errorprone.refaster.testdata.template;

import com.google.errorprone.refaster.annotation.AfterTemplate;
import com.google.errorprone.refaster.annotation.BeforeTemplate;

/** Sample template for introducing type arguments on a method invocation in an @AfterTemplate. */
public class TypeArgumentsMethodInvocationTemplate {
@BeforeTemplate
boolean before(String string) {
return string.isEmpty();
}

@AfterTemplate
boolean after(String string) {
return string.<String>isEmpty();
}
}

0 comments on commit ca193c0

Please sign in to comment.