diff options
author | Reinier Zwitserloot <reinier@zwitserloot.com> | 2020-09-17 22:18:11 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-17 22:18:11 +0200 |
commit | 60d86fab3c0d7716cf78ce6cfc62193395f7b3c3 (patch) | |
tree | 9310fdfb808d7045f524de131fde7c0d08118800 /test/transform/resource/before/ExtensionMethodFunctional.java | |
parent | 9148294f78a8e646ee131ca182a9b692bc028fdb (diff) | |
parent | f7f26a9c5671e9498ba56277bba5c3a5b63155fd (diff) | |
download | lombok-60d86fab3c0d7716cf78ce6cfc62193395f7b3c3.tar.gz lombok-60d86fab3c0d7716cf78ce6cfc62193395f7b3c3.tar.bz2 lombok-60d86fab3c0d7716cf78ce6cfc62193395f7b3c3.zip |
Merge pull request #2413 from Rawi01/extensionmethod
Improve ExtensionMethod support in Eclipse
Diffstat (limited to 'test/transform/resource/before/ExtensionMethodFunctional.java')
-rw-r--r-- | test/transform/resource/before/ExtensionMethodFunctional.java | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/test/transform/resource/before/ExtensionMethodFunctional.java b/test/transform/resource/before/ExtensionMethodFunctional.java new file mode 100644 index 00000000..19983258 --- /dev/null +++ b/test/transform/resource/before/ExtensionMethodFunctional.java @@ -0,0 +1,33 @@ +// version 8: +import java.util.function.Function; +import java.util.function.Consumer; + +import lombok.experimental.ExtensionMethod; + +@ExtensionMethod(ExtensionMethodFunctional.Extensions.class) +class ExtensionMethodFunctional { + public void test() { + String test = "test"; + test = test.map(s -> s.reverse()); + + test.consume(s -> System.out.println("1: " + s), s -> System.out.println("2: " + s)); + test.consume(System.out::println, System.out::println); + } + + static class Extensions { + public static <T, R> R map(T value, Function<T, R> mapper) { + return mapper.apply(value); + } + + public static String reverse(String string) { + return new StringBuilder(string).reverse().toString(); + } + + @SafeVarargs + public static <T> void consume(T o, Consumer<T>... consumer) { + for (int i = 0; i < consumer.length; i++) { + consumer[i].accept(o); + } + } + } +} |