aboutsummaryrefslogtreecommitdiff
path: root/test/transform/resource/after-delombok
diff options
context:
space:
mode:
Diffstat (limited to 'test/transform/resource/after-delombok')
-rw-r--r--test/transform/resource/after-delombok/BuilderDefaultsTargetTyping.java60
-rw-r--r--test/transform/resource/after-delombok/CheckerFrameworkBasic.java4
-rw-r--r--test/transform/resource/after-delombok/CheckerFrameworkBuilder.java19
-rw-r--r--test/transform/resource/after-delombok/CheckerFrameworkSuperBuilder.java37
-rw-r--r--test/transform/resource/after-delombok/OnXJava7Style.java30
-rw-r--r--test/transform/resource/after-delombok/OnXJava8Style.java31
-rw-r--r--test/transform/resource/after-delombok/SuperBuilderSingularToBuilderGuava.java252
-rw-r--r--test/transform/resource/after-delombok/SuperBuilderWithDefaultsAndTargetTyping.java155
-rw-r--r--test/transform/resource/after-delombok/ToStringExplicitIncludeConf.java9
9 files changed, 558 insertions, 39 deletions
diff --git a/test/transform/resource/after-delombok/BuilderDefaultsTargetTyping.java b/test/transform/resource/after-delombok/BuilderDefaultsTargetTyping.java
new file mode 100644
index 00000000..d9907ce8
--- /dev/null
+++ b/test/transform/resource/after-delombok/BuilderDefaultsTargetTyping.java
@@ -0,0 +1,60 @@
+import java.util.Arrays;
+
+public class BuilderDefaultsTargetTyping {
+ String foo;
+
+ static String doSth(java.util.List<Integer> i, java.util.List<Character> c) {
+ return null;
+ }
+
+ @java.lang.SuppressWarnings("all")
+ private static String $default$foo() {
+ return doSth(Arrays.asList(1), Arrays.asList('a'));
+ }
+
+ @java.lang.SuppressWarnings("all")
+ BuilderDefaultsTargetTyping(final String foo) {
+ this.foo = foo;
+ }
+
+
+ @java.lang.SuppressWarnings("all")
+ public static class BuilderDefaultsTargetTypingBuilder {
+ @java.lang.SuppressWarnings("all")
+ private boolean foo$set;
+ @java.lang.SuppressWarnings("all")
+ private String foo$value;
+
+ @java.lang.SuppressWarnings("all")
+ BuilderDefaultsTargetTypingBuilder() {
+ }
+
+ /**
+ * @return {@code this}.
+ */
+ @java.lang.SuppressWarnings("all")
+ public BuilderDefaultsTargetTyping.BuilderDefaultsTargetTypingBuilder foo(final String foo) {
+ this.foo$value = foo;
+ foo$set = true;
+ return this;
+ }
+
+ @java.lang.SuppressWarnings("all")
+ public BuilderDefaultsTargetTyping build() {
+ String foo$value = this.foo$value;
+ if (!this.foo$set) foo$value = BuilderDefaultsTargetTyping.$default$foo();
+ return new BuilderDefaultsTargetTyping(foo$value);
+ }
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public java.lang.String toString() {
+ return "BuilderDefaultsTargetTyping.BuilderDefaultsTargetTypingBuilder(foo$value=" + this.foo$value + ")";
+ }
+ }
+
+ @java.lang.SuppressWarnings("all")
+ public static BuilderDefaultsTargetTyping.BuilderDefaultsTargetTypingBuilder builder() {
+ return new BuilderDefaultsTargetTyping.BuilderDefaultsTargetTypingBuilder();
+ }
+}
diff --git a/test/transform/resource/after-delombok/CheckerFrameworkBasic.java b/test/transform/resource/after-delombok/CheckerFrameworkBasic.java
index 2beafc4c..bdd7921a 100644
--- a/test/transform/resource/after-delombok/CheckerFrameworkBasic.java
+++ b/test/transform/resource/after-delombok/CheckerFrameworkBasic.java
@@ -1,3 +1,4 @@
+// skip-idempotent
//version 8:
class CheckerFrameworkBasic {
private final int x;
@@ -21,9 +22,8 @@ class CheckerFrameworkBasic {
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public CheckerFrameworkBasic setZ(final int z) {
+ public @org.checkerframework.common.returnsreceiver.qual.This CheckerFrameworkBasic setZ(final int z) {
this.z = z;
return this;
}
diff --git a/test/transform/resource/after-delombok/CheckerFrameworkBuilder.java b/test/transform/resource/after-delombok/CheckerFrameworkBuilder.java
index 99272bd5..99245e11 100644
--- a/test/transform/resource/after-delombok/CheckerFrameworkBuilder.java
+++ b/test/transform/resource/after-delombok/CheckerFrameworkBuilder.java
@@ -1,4 +1,3 @@
-// skip-idempotent
import java.util.List;
class CheckerFrameworkBuilder {
int x;
@@ -34,9 +33,8 @@ class CheckerFrameworkBuilder {
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public CheckerFrameworkBuilder.CheckerFrameworkBuilderBuilder x(CheckerFrameworkBuilder.@org.checkerframework.checker.calledmethods.qual.NotCalledMethods("x") CheckerFrameworkBuilderBuilder this, final int x) {
+ public CheckerFrameworkBuilder.@org.checkerframework.common.returnsreceiver.qual.This CheckerFrameworkBuilderBuilder x(final int x) {
this.x$value = x;
x$set = true;
return this;
@@ -44,31 +42,27 @@ class CheckerFrameworkBuilder {
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public CheckerFrameworkBuilder.CheckerFrameworkBuilderBuilder y(CheckerFrameworkBuilder.@org.checkerframework.checker.calledmethods.qual.NotCalledMethods("y") CheckerFrameworkBuilderBuilder this, final int y) {
+ public CheckerFrameworkBuilder.@org.checkerframework.common.returnsreceiver.qual.This CheckerFrameworkBuilderBuilder y(final int y) {
this.y = y;
return this;
}
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public CheckerFrameworkBuilder.CheckerFrameworkBuilderBuilder z(CheckerFrameworkBuilder.@org.checkerframework.checker.calledmethods.qual.NotCalledMethods("z") CheckerFrameworkBuilderBuilder this, final int z) {
+ public CheckerFrameworkBuilder.@org.checkerframework.common.returnsreceiver.qual.This CheckerFrameworkBuilderBuilder z(final int z) {
this.z = z;
return this;
}
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public CheckerFrameworkBuilder.CheckerFrameworkBuilderBuilder name(final String name) {
+ public CheckerFrameworkBuilder.@org.checkerframework.common.returnsreceiver.qual.This CheckerFrameworkBuilderBuilder name(final String name) {
if (this.names == null) this.names = new java.util.ArrayList<String>();
this.names.add(name);
return this;
}
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public CheckerFrameworkBuilder.CheckerFrameworkBuilderBuilder names(final java.util.Collection<? extends String> names) {
+ public CheckerFrameworkBuilder.@org.checkerframework.common.returnsreceiver.qual.This CheckerFrameworkBuilderBuilder names(final java.util.Collection<? extends String> names) {
if (names == null) {
throw new java.lang.NullPointerException("names cannot be null");
}
@@ -76,9 +70,8 @@ class CheckerFrameworkBuilder {
this.names.addAll(names);
return this;
}
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public CheckerFrameworkBuilder.CheckerFrameworkBuilderBuilder clearNames() {
+ public CheckerFrameworkBuilder.@org.checkerframework.common.returnsreceiver.qual.This CheckerFrameworkBuilderBuilder clearNames() {
if (this.names != null) this.names.clear();
return this;
}
diff --git a/test/transform/resource/after-delombok/CheckerFrameworkSuperBuilder.java b/test/transform/resource/after-delombok/CheckerFrameworkSuperBuilder.java
index 8dcdaf10..cab11f3c 100644
--- a/test/transform/resource/after-delombok/CheckerFrameworkSuperBuilder.java
+++ b/test/transform/resource/after-delombok/CheckerFrameworkSuperBuilder.java
@@ -1,3 +1,4 @@
+// skip-idempotent
//version 8:
import java.util.List;
class CheckerFrameworkSuperBuilder {
@@ -22,19 +23,17 @@ class CheckerFrameworkSuperBuilder {
private int z;
@java.lang.SuppressWarnings("all")
private java.util.ArrayList<String> names;
- @org.checkerframework.common.returnsreceiver.qual.This
@org.checkerframework.dataflow.qual.Pure
@java.lang.SuppressWarnings("all")
- protected abstract B self();
+ protected abstract @org.checkerframework.common.returnsreceiver.qual.This B self();
@org.checkerframework.dataflow.qual.SideEffectFree
@java.lang.SuppressWarnings("all")
public abstract C build(CheckerFrameworkSuperBuilder.Parent.@org.checkerframework.checker.calledmethods.qual.CalledMethods({"y", "z"}) ParentBuilder<C, B> this);
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public B x(CheckerFrameworkSuperBuilder.Parent.@org.checkerframework.checker.calledmethods.qual.NotCalledMethods("x") ParentBuilder<C, B> this, final int x) {
+ public @org.checkerframework.common.returnsreceiver.qual.This B x(final int x) {
this.x$value = x;
x$set = true;
return self();
@@ -42,31 +41,27 @@ class CheckerFrameworkSuperBuilder {
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public B y(CheckerFrameworkSuperBuilder.Parent.@org.checkerframework.checker.calledmethods.qual.NotCalledMethods("y") ParentBuilder<C, B> this, final int y) {
+ public @org.checkerframework.common.returnsreceiver.qual.This B y(final int y) {
this.y = y;
return self();
}
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public B z(CheckerFrameworkSuperBuilder.Parent.@org.checkerframework.checker.calledmethods.qual.NotCalledMethods("z") ParentBuilder<C, B> this, final int z) {
+ public @org.checkerframework.common.returnsreceiver.qual.This B z(final int z) {
this.z = z;
return self();
}
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public B name(final String name) {
+ public @org.checkerframework.common.returnsreceiver.qual.This B name(final String name) {
if (this.names == null) this.names = new java.util.ArrayList<String>();
this.names.add(name);
return self();
}
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public B names(final java.util.Collection<? extends String> names) {
+ public @org.checkerframework.common.returnsreceiver.qual.This B names(final java.util.Collection<? extends String> names) {
if (names == null) {
throw new java.lang.NullPointerException("names cannot be null");
}
@@ -74,9 +69,8 @@ class CheckerFrameworkSuperBuilder {
this.names.addAll(names);
return self();
}
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public B clearNames() {
+ public @org.checkerframework.common.returnsreceiver.qual.This B clearNames() {
if (this.names != null) this.names.clear();
return self();
}
@@ -93,10 +87,9 @@ class CheckerFrameworkSuperBuilder {
private ParentBuilderImpl() {
}
@java.lang.Override
- @org.checkerframework.common.returnsreceiver.qual.This
@org.checkerframework.dataflow.qual.Pure
@java.lang.SuppressWarnings("all")
- protected CheckerFrameworkSuperBuilder.Parent.ParentBuilderImpl self() {
+ protected CheckerFrameworkSuperBuilder.Parent.@org.checkerframework.common.returnsreceiver.qual.This ParentBuilderImpl self() {
return this;
}
@org.checkerframework.dataflow.qual.SideEffectFree
@@ -148,10 +141,9 @@ class CheckerFrameworkSuperBuilder {
@java.lang.SuppressWarnings("all")
private int b;
@java.lang.Override
- @org.checkerframework.common.returnsreceiver.qual.This
@org.checkerframework.dataflow.qual.Pure
@java.lang.SuppressWarnings("all")
- protected abstract B self();
+ protected abstract @org.checkerframework.common.returnsreceiver.qual.This B self();
@org.checkerframework.dataflow.qual.SideEffectFree
@java.lang.Override
@java.lang.SuppressWarnings("all")
@@ -159,9 +151,8 @@ class CheckerFrameworkSuperBuilder {
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public B a(CheckerFrameworkSuperBuilder.ZChild.@org.checkerframework.checker.calledmethods.qual.NotCalledMethods("a") ZChildBuilder<C, B> this, final int a) {
+ public @org.checkerframework.common.returnsreceiver.qual.This B a(final int a) {
this.a$value = a;
a$set = true;
return self();
@@ -169,9 +160,8 @@ class CheckerFrameworkSuperBuilder {
/**
* @return {@code this}.
*/
- @org.checkerframework.common.returnsreceiver.qual.This
@java.lang.SuppressWarnings("all")
- public B b(CheckerFrameworkSuperBuilder.ZChild.@org.checkerframework.checker.calledmethods.qual.NotCalledMethods("b") ZChildBuilder<C, B> this, final int b) {
+ public @org.checkerframework.common.returnsreceiver.qual.This B b(final int b) {
this.b = b;
return self();
}
@@ -188,10 +178,9 @@ class CheckerFrameworkSuperBuilder {
private ZChildBuilderImpl() {
}
@java.lang.Override
- @org.checkerframework.common.returnsreceiver.qual.This
@org.checkerframework.dataflow.qual.Pure
@java.lang.SuppressWarnings("all")
- protected CheckerFrameworkSuperBuilder.ZChild.ZChildBuilderImpl self() {
+ protected CheckerFrameworkSuperBuilder.ZChild.@org.checkerframework.common.returnsreceiver.qual.This ZChildBuilderImpl self() {
return this;
}
@org.checkerframework.dataflow.qual.SideEffectFree
diff --git a/test/transform/resource/after-delombok/OnXJava7Style.java b/test/transform/resource/after-delombok/OnXJava7Style.java
index 7ebf65a3..67f8c8c8 100644
--- a/test/transform/resource/after-delombok/OnXJava7Style.java
+++ b/test/transform/resource/after-delombok/OnXJava7Style.java
@@ -6,11 +6,18 @@ public class OnXJava7Style {
@interface Bar {
String stuff() default "";
}
+ @interface Array {
+ String[] value() default {};
+ }
String a;
String b;
String c;
String d;
String e;
+ String f;
+ String g;
+ String h;
+ String i;
@Foo
@java.lang.SuppressWarnings("all")
public String getA() {
@@ -35,4 +42,27 @@ public class OnXJava7Style {
public String getE() {
return this.e;
}
+ @Array
+ @java.lang.SuppressWarnings("all")
+ public String getF() {
+ return this.f;
+ }
+
+ @Array
+ @java.lang.SuppressWarnings("all")
+ public String getG() {
+ return this.g;
+ }
+
+ @Array({})
+ @java.lang.SuppressWarnings("all")
+ public String getH() {
+ return this.h;
+ }
+
+ @Array({"a", "b"})
+ @java.lang.SuppressWarnings("all")
+ public String getI() {
+ return this.i;
+ }
}
diff --git a/test/transform/resource/after-delombok/OnXJava8Style.java b/test/transform/resource/after-delombok/OnXJava8Style.java
index d2f76e10..18fc6686 100644
--- a/test/transform/resource/after-delombok/OnXJava8Style.java
+++ b/test/transform/resource/after-delombok/OnXJava8Style.java
@@ -6,11 +6,19 @@ public class OnXJava8Style {
@interface Bar {
String stuff() default "";
}
+
+ @interface Array {
+ String[] value() default {};
+ }
String a;
String b;
String c;
String d;
String e;
+ String f;
+ String g;
+ String h;
+ String i;
@Foo
@java.lang.SuppressWarnings("all")
public String getA() {
@@ -35,4 +43,27 @@ public class OnXJava8Style {
public String getE() {
return this.e;
}
+ @Array
+ @java.lang.SuppressWarnings("all")
+ public String getF() {
+ return this.f;
+ }
+
+ @Array
+ @java.lang.SuppressWarnings("all")
+ public String getG() {
+ return this.g;
+ }
+
+ @Array({})
+ @java.lang.SuppressWarnings("all")
+ public String getH() {
+ return this.h;
+ }
+
+ @Array({"a", "b"})
+ @java.lang.SuppressWarnings("all")
+ public String getI() {
+ return this.i;
+ }
}
diff --git a/test/transform/resource/after-delombok/SuperBuilderSingularToBuilderGuava.java b/test/transform/resource/after-delombok/SuperBuilderSingularToBuilderGuava.java
new file mode 100644
index 00000000..ec716fdd
--- /dev/null
+++ b/test/transform/resource/after-delombok/SuperBuilderSingularToBuilderGuava.java
@@ -0,0 +1,252 @@
+public class SuperBuilderSingularToBuilderGuava {
+ public static class Parent<T> {
+ private com.google.common.collect.ImmutableList<T> cards;
+ private com.google.common.collect.ImmutableCollection<? extends Number> frogs;
+ @SuppressWarnings("all")
+ private com.google.common.collect.ImmutableSet rawSet;
+ private com.google.common.collect.ImmutableSortedSet<String> passes;
+ private com.google.common.collect.ImmutableTable<? extends Number, ? extends Number, String> users;
+ @java.lang.SuppressWarnings("all")
+ public static abstract class ParentBuilder<T, C extends SuperBuilderSingularToBuilderGuava.Parent<T>, B extends SuperBuilderSingularToBuilderGuava.Parent.ParentBuilder<T, C, B>> {
+ @java.lang.SuppressWarnings("all")
+ private com.google.common.collect.ImmutableList.Builder<T> cards;
+ @java.lang.SuppressWarnings("all")
+ private com.google.common.collect.ImmutableList.Builder<Number> frogs;
+ @java.lang.SuppressWarnings("all")
+ private com.google.common.collect.ImmutableSet.Builder<java.lang.Object> rawSet;
+ @java.lang.SuppressWarnings("all")
+ private com.google.common.collect.ImmutableSortedSet.Builder<String> passes;
+ @java.lang.SuppressWarnings("all")
+ private com.google.common.collect.ImmutableTable.Builder<Number, Number, String> users;
+ @java.lang.SuppressWarnings("all")
+ protected B $fillValuesFrom(final C instance) {
+ SuperBuilderSingularToBuilderGuava.Parent.ParentBuilder.$fillValuesFromInstanceIntoBuilder(instance, this);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ private static <T> void $fillValuesFromInstanceIntoBuilder(final SuperBuilderSingularToBuilderGuava.Parent<T> instance, final SuperBuilderSingularToBuilderGuava.Parent.ParentBuilder<T, ?, ?> b) {
+ b.cards(instance.cards == null ? com.google.common.collect.ImmutableList.<T>of() : instance.cards);
+ b.frogs(instance.frogs == null ? com.google.common.collect.ImmutableList.<Number>of() : instance.frogs);
+ b.rawSet(instance.rawSet == null ? com.google.common.collect.ImmutableSet.<java.lang.Object>of() : instance.rawSet);
+ b.passes(instance.passes == null ? com.google.common.collect.ImmutableSortedSet.<String>of() : instance.passes);
+ b.users(instance.users == null ? com.google.common.collect.ImmutableTable.<Number, Number, String>of() : instance.users);
+ }
+ @java.lang.SuppressWarnings("all")
+ protected abstract B self();
+ @java.lang.SuppressWarnings("all")
+ public abstract C build();
+ @java.lang.SuppressWarnings("all")
+ public B card(final T card) {
+ if (this.cards == null) this.cards = com.google.common.collect.ImmutableList.builder();
+ this.cards.add(card);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B cards(final java.lang.Iterable<? extends T> cards) {
+ if (cards == null) {
+ throw new java.lang.NullPointerException("cards cannot be null");
+ }
+ if (this.cards == null) this.cards = com.google.common.collect.ImmutableList.builder();
+ this.cards.addAll(cards);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B clearCards() {
+ this.cards = null;
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B frog(final Number frog) {
+ if (this.frogs == null) this.frogs = com.google.common.collect.ImmutableList.builder();
+ this.frogs.add(frog);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B frogs(final java.lang.Iterable<? extends Number> frogs) {
+ if (frogs == null) {
+ throw new java.lang.NullPointerException("frogs cannot be null");
+ }
+ if (this.frogs == null) this.frogs = com.google.common.collect.ImmutableList.builder();
+ this.frogs.addAll(frogs);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B clearFrogs() {
+ this.frogs = null;
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B rawSet(final java.lang.Object rawSet) {
+ if (this.rawSet == null) this.rawSet = com.google.common.collect.ImmutableSet.builder();
+ this.rawSet.add(rawSet);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B rawSet(final java.lang.Iterable<?> rawSet) {
+ if (rawSet == null) {
+ throw new java.lang.NullPointerException("rawSet cannot be null");
+ }
+ if (this.rawSet == null) this.rawSet = com.google.common.collect.ImmutableSet.builder();
+ this.rawSet.addAll(rawSet);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B clearRawSet() {
+ this.rawSet = null;
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B pass(final String pass) {
+ if (this.passes == null) this.passes = com.google.common.collect.ImmutableSortedSet.naturalOrder();
+ this.passes.add(pass);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B passes(final java.lang.Iterable<? extends String> passes) {
+ if (passes == null) {
+ throw new java.lang.NullPointerException("passes cannot be null");
+ }
+ if (this.passes == null) this.passes = com.google.common.collect.ImmutableSortedSet.naturalOrder();
+ this.passes.addAll(passes);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B clearPasses() {
+ this.passes = null;
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B user(final Number rowKey, final Number columnKey, final String value) {
+ if (this.users == null) this.users = com.google.common.collect.ImmutableTable.builder();
+ this.users.put(rowKey, columnKey, value);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B users(final com.google.common.collect.Table<? extends Number, ? extends Number, ? extends String> users) {
+ if (users == null) {
+ throw new java.lang.NullPointerException("users cannot be null");
+ }
+ if (this.users == null) this.users = com.google.common.collect.ImmutableTable.builder();
+ this.users.putAll(users);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ public B clearUsers() {
+ this.users = null;
+ return self();
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public java.lang.String toString() {
+ return "SuperBuilderSingularToBuilderGuava.Parent.ParentBuilder(cards=" + this.cards + ", frogs=" + this.frogs + ", rawSet=" + this.rawSet + ", passes=" + this.passes + ", users=" + this.users + ")";
+ }
+ }
+ @java.lang.SuppressWarnings("all")
+ private static final class ParentBuilderImpl<T> extends SuperBuilderSingularToBuilderGuava.Parent.ParentBuilder<T, SuperBuilderSingularToBuilderGuava.Parent<T>, SuperBuilderSingularToBuilderGuava.Parent.ParentBuilderImpl<T>> {
+ @java.lang.SuppressWarnings("all")
+ private ParentBuilderImpl() {
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ protected SuperBuilderSingularToBuilderGuava.Parent.ParentBuilderImpl<T> self() {
+ return this;
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public SuperBuilderSingularToBuilderGuava.Parent<T> build() {
+ return new SuperBuilderSingularToBuilderGuava.Parent<T>(this);
+ }
+ }
+ @java.lang.SuppressWarnings("all")
+ protected Parent(final SuperBuilderSingularToBuilderGuava.Parent.ParentBuilder<T, ?, ?> b) {
+ com.google.common.collect.ImmutableList<T> cards = b.cards == null ? com.google.common.collect.ImmutableList.<T>of() : b.cards.build();
+ this.cards = cards;
+ com.google.common.collect.ImmutableCollection<Number> frogs = b.frogs == null ? com.google.common.collect.ImmutableList.<Number>of() : b.frogs.build();
+ this.frogs = frogs;
+ com.google.common.collect.ImmutableSet<java.lang.Object> rawSet = b.rawSet == null ? com.google.common.collect.ImmutableSet.<java.lang.Object>of() : b.rawSet.build();
+ this.rawSet = rawSet;
+ com.google.common.collect.ImmutableSortedSet<String> passes = b.passes == null ? com.google.common.collect.ImmutableSortedSet.<String>of() : b.passes.build();
+ this.passes = passes;
+ com.google.common.collect.ImmutableTable<Number, Number, String> users = b.users == null ? com.google.common.collect.ImmutableTable.<Number, Number, String>of() : b.users.build();
+ this.users = users;
+ }
+ @java.lang.SuppressWarnings("all")
+ public static <T> SuperBuilderSingularToBuilderGuava.Parent.ParentBuilder<T, ?, ?> builder() {
+ return new SuperBuilderSingularToBuilderGuava.Parent.ParentBuilderImpl<T>();
+ }
+ @java.lang.SuppressWarnings("all")
+ public SuperBuilderSingularToBuilderGuava.Parent.ParentBuilder<T, ?, ?> toBuilder() {
+ return new SuperBuilderSingularToBuilderGuava.Parent.ParentBuilderImpl<T>().$fillValuesFrom(this);
+ }
+ }
+ public static class Child<T> extends Parent<T> {
+ private double field3;
+ @java.lang.SuppressWarnings("all")
+ public static abstract class ChildBuilder<T, C extends SuperBuilderSingularToBuilderGuava.Child<T>, B extends SuperBuilderSingularToBuilderGuava.Child.ChildBuilder<T, C, B>> extends Parent.ParentBuilder<T, C, B> {
+ @java.lang.SuppressWarnings("all")
+ private double field3;
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ protected B $fillValuesFrom(final C instance) {
+ super.$fillValuesFrom(instance);
+ SuperBuilderSingularToBuilderGuava.Child.ChildBuilder.$fillValuesFromInstanceIntoBuilder(instance, this);
+ return self();
+ }
+ @java.lang.SuppressWarnings("all")
+ private static <T> void $fillValuesFromInstanceIntoBuilder(final SuperBuilderSingularToBuilderGuava.Child<T> instance, final SuperBuilderSingularToBuilderGuava.Child.ChildBuilder<T, ?, ?> b) {
+ b.field3(instance.field3);
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ protected abstract B self();
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public abstract C build();
+ /**
+ * @return {@code this}.
+ */
+ @java.lang.SuppressWarnings("all")
+ public B field3(final double field3) {
+ this.field3 = field3;
+ return self();
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public java.lang.String toString() {
+ return "SuperBuilderSingularToBuilderGuava.Child.ChildBuilder(super=" + super.toString() + ", field3=" + this.field3 + ")";
+ }
+ }
+ @java.lang.SuppressWarnings("all")
+ private static final class ChildBuilderImpl<T> extends SuperBuilderSingularToBuilderGuava.Child.ChildBuilder<T, SuperBuilderSingularToBuilderGuava.Child<T>, SuperBuilderSingularToBuilderGuava.Child.ChildBuilderImpl<T>> {
+ @java.lang.SuppressWarnings("all")
+ private ChildBuilderImpl() {
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ protected SuperBuilderSingularToBuilderGuava.Child.ChildBuilderImpl<T> self() {
+ return this;
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public SuperBuilderSingularToBuilderGuava.Child<T> build() {
+ return new SuperBuilderSingularToBuilderGuava.Child<T>(this);
+ }
+ }
+ @java.lang.SuppressWarnings("all")
+ protected Child(final SuperBuilderSingularToBuilderGuava.Child.ChildBuilder<T, ?, ?> b) {
+ super(b);
+ this.field3 = b.field3;
+ }
+ @java.lang.SuppressWarnings("all")
+ public static <T> SuperBuilderSingularToBuilderGuava.Child.ChildBuilder<T, ?, ?> builder() {
+ return new SuperBuilderSingularToBuilderGuava.Child.ChildBuilderImpl<T>();
+ }
+ @java.lang.SuppressWarnings("all")
+ public SuperBuilderSingularToBuilderGuava.Child.ChildBuilder<T, ?, ?> toBuilder() {
+ return new SuperBuilderSingularToBuilderGuava.Child.ChildBuilderImpl<T>().$fillValuesFrom(this);
+ }
+ }
+ public static void test() {
+ Child<Integer> x = Child.<Integer>builder().card(1).build().toBuilder().build();
+ }
+} \ No newline at end of file
diff --git a/test/transform/resource/after-delombok/SuperBuilderWithDefaultsAndTargetTyping.java b/test/transform/resource/after-delombok/SuperBuilderWithDefaultsAndTargetTyping.java
new file mode 100644
index 00000000..c3fc4ce8
--- /dev/null
+++ b/test/transform/resource/after-delombok/SuperBuilderWithDefaultsAndTargetTyping.java
@@ -0,0 +1,155 @@
+import java.util.Arrays;
+import lombok.Builder;
+
+public class SuperBuilderWithDefaultsAndTargetTyping {
+
+ public static class Parent {
+ private String foo;
+
+ @java.lang.SuppressWarnings("all")
+ private static String $default$foo() {
+ return doSth(Arrays.asList(1), Arrays.asList('a'));
+ }
+
+
+ @java.lang.SuppressWarnings("all")
+ public static abstract class ParentBuilder<C extends SuperBuilderWithDefaultsAndTargetTyping.Parent, B extends SuperBuilderWithDefaultsAndTargetTyping.Parent.ParentBuilder<C, B>> {
+ @java.lang.SuppressWarnings("all")
+ private boolean foo$set;
+ @java.lang.SuppressWarnings("all")
+ private String foo$value;
+
+ @java.lang.SuppressWarnings("all")
+ protected abstract B self();
+
+ @java.lang.SuppressWarnings("all")
+ public abstract C build();
+
+ /**
+ * @return {@code this}.
+ */
+ @java.lang.SuppressWarnings("all")
+ public B foo(final String foo) {
+ this.foo$value = foo;
+ foo$set = true;
+ return self();
+ }
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public java.lang.String toString() {
+ return "SuperBuilderWithDefaultsAndTargetTyping.Parent.ParentBuilder(foo$value=" + this.foo$value + ")";
+ }
+ }
+
+
+ @java.lang.SuppressWarnings("all")
+ private static final class ParentBuilderImpl extends SuperBuilderWithDefaultsAndTargetTyping.Parent.ParentBuilder<SuperBuilderWithDefaultsAndTargetTyping.Parent, SuperBuilderWithDefaultsAndTargetTyping.Parent.ParentBuilderImpl> {
+ @java.lang.SuppressWarnings("all")
+ private ParentBuilderImpl() {
+ }
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ protected SuperBuilderWithDefaultsAndTargetTyping.Parent.ParentBuilderImpl self() {
+ return this;
+ }
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public SuperBuilderWithDefaultsAndTargetTyping.Parent build() {
+ return new SuperBuilderWithDefaultsAndTargetTyping.Parent(this);
+ }
+ }
+
+ @java.lang.SuppressWarnings("all")
+ protected Parent(final SuperBuilderWithDefaultsAndTargetTyping.Parent.ParentBuilder<?, ?> b) {
+ if (b.foo$set) this.foo = b.foo$value;
+ else this.foo = SuperBuilderWithDefaultsAndTargetTyping.Parent.$default$foo();
+ }
+
+ @java.lang.SuppressWarnings("all")
+ public static SuperBuilderWithDefaultsAndTargetTyping.Parent.ParentBuilder<?, ?> builder() {
+ return new SuperBuilderWithDefaultsAndTargetTyping.Parent.ParentBuilderImpl();
+ }
+ }
+
+
+ public static class Child extends Parent {
+ private String foo;
+
+ @java.lang.SuppressWarnings("all")
+ private static String $default$foo() {
+ return doSth(Arrays.asList(1), Arrays.asList('a'));
+ }
+
+
+ @java.lang.SuppressWarnings("all")
+ public static abstract class ChildBuilder<C extends SuperBuilderWithDefaultsAndTargetTyping.Child, B extends SuperBuilderWithDefaultsAndTargetTyping.Child.ChildBuilder<C, B>> extends Parent.ParentBuilder<C, B> {
+ @java.lang.SuppressWarnings("all")
+ private boolean foo$set;
+ @java.lang.SuppressWarnings("all")
+ private String foo$value;
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ protected abstract B self();
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public abstract C build();
+
+ /**
+ * @return {@code this}.
+ */
+ @java.lang.SuppressWarnings("all")
+ public B foo(final String foo) {
+ this.foo$value = foo;
+ foo$set = true;
+ return self();
+ }
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public java.lang.String toString() {
+ return "SuperBuilderWithDefaultsAndTargetTyping.Child.ChildBuilder(super=" + super.toString() + ", foo$value=" + this.foo$value + ")";
+ }
+ }
+
+
+ @java.lang.SuppressWarnings("all")
+ private static final class ChildBuilderImpl extends SuperBuilderWithDefaultsAndTargetTyping.Child.ChildBuilder<SuperBuilderWithDefaultsAndTargetTyping.Child, SuperBuilderWithDefaultsAndTargetTyping.Child.ChildBuilderImpl> {
+ @java.lang.SuppressWarnings("all")
+ private ChildBuilderImpl() {
+ }
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ protected SuperBuilderWithDefaultsAndTargetTyping.Child.ChildBuilderImpl self() {
+ return this;
+ }
+
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public SuperBuilderWithDefaultsAndTargetTyping.Child build() {
+ return new SuperBuilderWithDefaultsAndTargetTyping.Child(this);
+ }
+ }
+
+ @java.lang.SuppressWarnings("all")
+ protected Child(final SuperBuilderWithDefaultsAndTargetTyping.Child.ChildBuilder<?, ?> b) {
+ super(b);
+ if (b.foo$set) this.foo = b.foo$value;
+ else this.foo = SuperBuilderWithDefaultsAndTargetTyping.Child.$default$foo();
+ }
+
+ @java.lang.SuppressWarnings("all")
+ public static SuperBuilderWithDefaultsAndTargetTyping.Child.ChildBuilder<?, ?> builder() {
+ return new SuperBuilderWithDefaultsAndTargetTyping.Child.ChildBuilderImpl();
+ }
+ }
+
+ static String doSth(java.util.List<Integer> i, java.util.List<Character> c) {
+ return null;
+ }
+}
diff --git a/test/transform/resource/after-delombok/ToStringExplicitIncludeConf.java b/test/transform/resource/after-delombok/ToStringExplicitIncludeConf.java
new file mode 100644
index 00000000..c4962ed8
--- /dev/null
+++ b/test/transform/resource/after-delombok/ToStringExplicitIncludeConf.java
@@ -0,0 +1,9 @@
+class ToStringExplicitIncludeConf {
+ int x;
+ int y;
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public java.lang.String toString() {
+ return "ToStringExplicitIncludeConf(y=" + this.y + ")";
+ }
+}