diff options
Diffstat (limited to 'test/transform/resource/after-delombok')
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 + ")"; + } +} |