Simplify lambads.

Fix Javadoc.
This commit is contained in:
Gary Gregory 2020-06-11 09:55:02 -04:00
parent e968ad5a3f
commit 8f7eb6ce20
4 changed files with 19 additions and 22 deletions

View File

@ -40,8 +40,7 @@ import org.apache.commons.lang3.Streams.FailableStream;
* constructs like: * constructs like:
* *
* <pre> * <pre>
* { * {@code
* &#64;code
* Consumer<java.lang.reflect.Method> consumer = (m) -> { * Consumer<java.lang.reflect.Method> consumer = (m) -> {
* try { * try {
* m.invoke(o, args); * m.invoke(o, args);
@ -504,8 +503,7 @@ public class Functions {
* {@link Throwable} is rethrown. Example use: * {@link Throwable} is rethrown. Example use:
* *
* <pre> * <pre>
* { * {@code
* &#64;code
* final FileInputStream fis = new FileInputStream("my.file"); * final FileInputStream fis = new FileInputStream("my.file");
* Functions.tryWithResources(useInputStream(fis), null, () -> fis.close()); * Functions.tryWithResources(useInputStream(fis), null, () -> fis.close());
* }</pre> * }</pre>
@ -566,8 +564,7 @@ public class Functions {
* {@link Throwable} is rethrown. Example use: * {@link Throwable} is rethrown. Example use:
* *
* <pre> * <pre>
* { * {@code
* &#64;code
* final FileInputStream fis = new FileInputStream("my.file"); * final FileInputStream fis = new FileInputStream("my.file");
* Functions.tryWithResources(useInputStream(fis), () -> fis.close()); * Functions.tryWithResources(useInputStream(fis), () -> fis.close());
* }</pre> * }</pre>

View File

@ -178,7 +178,7 @@ class FunctionsTest {
@Test @Test
void testAsCallable() { void testAsCallable() {
FailureOnOddInvocations.invocation = 0; FailureOnOddInvocations.invocation = 0;
final FailableCallable<FailureOnOddInvocations, SomeException> failableCallable = () -> new FailureOnOddInvocations(); final FailableCallable<FailureOnOddInvocations, SomeException> failableCallable = FailureOnOddInvocations::new;
final Callable<FailureOnOddInvocations> callable = Functions.asCallable(failableCallable); final Callable<FailureOnOddInvocations> callable = Functions.asCallable(failableCallable);
final UndeclaredThrowableException e = assertThrows(UndeclaredThrowableException.class, () -> callable.call()); final UndeclaredThrowableException e = assertThrows(UndeclaredThrowableException.class, () -> callable.call());
final Throwable cause = e.getCause(); final Throwable cause = e.getCause();
@ -221,7 +221,7 @@ class FunctionsTest {
void testAsConsumer() { void testAsConsumer() {
final IllegalStateException ise = new IllegalStateException(); final IllegalStateException ise = new IllegalStateException();
final Testable testable = new Testable(ise); final Testable testable = new Testable(ise);
final Consumer<Testable> consumer = Functions.asConsumer(t -> t.test()); final Consumer<Testable> consumer = Functions.asConsumer(Testable::test);
Throwable e = assertThrows(IllegalStateException.class, () -> consumer.accept(testable)); Throwable e = assertThrows(IllegalStateException.class, () -> consumer.accept(testable));
assertSame(ise, e); assertSame(ise, e);

View File

@ -33,7 +33,7 @@ class LocksTest {
/** If our threads are running concurrently, then we expect to be faster /** If our threads are running concurrently, then we expect to be faster
* than running one after the other. * than running one after the other.
*/ */
runTest(DELAY, false, (l) -> assertTrue(l < NUMBER_OF_THREADS*DELAY)); runTest(DELAY, false, l -> assertTrue(l < NUMBER_OF_THREADS*DELAY));
} }
void testWriteLock() throws Exception { void testWriteLock() throws Exception {
@ -41,7 +41,7 @@ class LocksTest {
/** If our threads are running concurrently, then we expect to be no faster /** If our threads are running concurrently, then we expect to be no faster
* than running one after the other. * than running one after the other.
*/ */
runTest(DELAY, true, (l) -> assertTrue(l >= NUMBER_OF_THREADS*DELAY)); runTest(DELAY, true, l -> assertTrue(l >= NUMBER_OF_THREADS*DELAY));
} }
private void runTest(long delay, boolean exclusiveLock, LongConsumer runTimeCheck) throws InterruptedException { private void runTest(long delay, boolean exclusiveLock, LongConsumer runTimeCheck) throws InterruptedException {
@ -52,7 +52,7 @@ class LocksTest {
final long startTime = System.currentTimeMillis(); final long startTime = System.currentTimeMillis();
for (int i = 0; i < booleanValues.length; i++) { for (int i = 0; i < booleanValues.length; i++) {
final int index = i; final int index = i;
final FailableConsumer<boolean[], ?> consumer = (b) -> { final FailableConsumer<boolean[], ?> consumer = b -> {
b[index] = false; b[index] = false;
Thread.sleep(delay); Thread.sleep(delay);
b[index] = true; b[index] = true;

View File

@ -46,7 +46,7 @@ class StreamsTest {
@Test @Test
void testSimpleStreamMap() { void testSimpleStreamMap() {
final List<String> input = Arrays.asList("1", "2", "3", "4", "5", "6"); final List<String> input = Arrays.asList("1", "2", "3", "4", "5", "6");
final List<Integer> output = Functions.stream(input).map((s) -> Integer.valueOf(s)).collect(Collectors.toList()); final List<Integer> output = Functions.stream(input).map(s -> Integer.valueOf(s)).collect(Collectors.toList());
assertEquals(6, output.size()); assertEquals(6, output.size());
for (int i = 0; i < 6; i++) { for (int i = 0; i < 6; i++) {
assertEquals(i+1, output.get(i).intValue()); assertEquals(i+1, output.get(i).intValue());
@ -56,7 +56,7 @@ class StreamsTest {
@Test @Test
void testSimpleStreamMapFailing() { void testSimpleStreamMapFailing() {
final List<String> input = Arrays.asList("1", "2", "3", "4 ", "5", "6"); final List<String> input = Arrays.asList("1", "2", "3", "4 ", "5", "6");
final Executable testMethod = () -> Functions.stream(input).map((s) -> Integer.valueOf(s)).collect(Collectors.toList()); final Executable testMethod = () -> Functions.stream(input).map(s -> Integer.valueOf(s)).collect(Collectors.toList());
final NumberFormatException thrown = assertThrows(NumberFormatException.class, testMethod); final NumberFormatException thrown = assertThrows(NumberFormatException.class, testMethod);
assertEquals("For input string: \"4 \"", thrown.getMessage()); assertEquals("For input string: \"4 \"", thrown.getMessage());
} }
@ -65,7 +65,7 @@ class StreamsTest {
void testSimpleStreamForEach() { void testSimpleStreamForEach() {
final List<String> input = Arrays.asList("1", "2", "3", "4", "5", "6"); final List<String> input = Arrays.asList("1", "2", "3", "4", "5", "6");
final List<Integer> output = new ArrayList<>(); final List<Integer> output = new ArrayList<>();
Functions.stream(input).forEach((s) -> output.add(Integer.valueOf(s))); Functions.stream(input).forEach(s -> output.add(Integer.valueOf(s)));
assertEquals(6, output.size()); assertEquals(6, output.size());
for (int i = 0; i < 6; i++) { for (int i = 0; i < 6; i++) {
assertEquals(i+1, output.get(i).intValue()); assertEquals(i+1, output.get(i).intValue());
@ -83,7 +83,7 @@ class StreamsTest {
} }
protected <T extends Throwable> FailableConsumer<String, T> asIntConsumer(final T pThrowable) { protected <T extends Throwable> FailableConsumer<String, T> asIntConsumer(final T pThrowable) {
return (s) -> { return s -> {
final Integer i = Integer.valueOf(s); final Integer i = Integer.valueOf(s);
if (i.intValue() == 4) { if (i.intValue() == 4) {
throw pThrowable; throw pThrowable;
@ -130,8 +130,8 @@ class StreamsTest {
void testSimpleStreamFilter() { void testSimpleStreamFilter() {
final List<String> input = Arrays.asList("1", "2", "3", "4", "5", "6"); final List<String> input = Arrays.asList("1", "2", "3", "4", "5", "6");
final List<Integer> output = Functions.stream(input) final List<Integer> output = Functions.stream(input)
.map((s) -> Integer.valueOf(s)) .map(s -> Integer.valueOf(s))
.filter((i) -> { .filter(i -> {
return i.intValue() %2 == 0; return i.intValue() %2 == 0;
}) })
.collect(Collectors.toList()); .collect(Collectors.toList());
@ -146,7 +146,7 @@ class StreamsTest {
} }
protected <T extends Throwable> FailablePredicate<Integer, T> asIntPredicate(final T pThrowable) { protected <T extends Throwable> FailablePredicate<Integer, T> asIntPredicate(final T pThrowable) {
return (i) -> { return i -> {
if (i.intValue() == 5) { if (i.intValue() == 5) {
if (pThrowable != null) { if (pThrowable != null) {
throw pThrowable; throw pThrowable;
@ -160,7 +160,7 @@ class StreamsTest {
Stream<DynamicTest> simpleStreamFilterFailing() { Stream<DynamicTest> simpleStreamFilterFailing() {
final List<String> input = Arrays.asList("1", "2", "3", "4", "5", "6"); final List<String> input = Arrays.asList("1", "2", "3", "4", "5", "6");
final List<Integer> output = Functions.stream(input) final List<Integer> output = Functions.stream(input)
.map((s) -> Integer.valueOf(s)) .map(s -> Integer.valueOf(s))
.filter(asIntPredicate(null)) .filter(asIntPredicate(null))
.collect(Collectors.toList()); .collect(Collectors.toList());
assertEvenNumbers(output); assertEvenNumbers(output);
@ -170,7 +170,7 @@ class StreamsTest {
dynamicTest("IllegalArgumentException", () -> { dynamicTest("IllegalArgumentException", () -> {
final IllegalArgumentException iae = new IllegalArgumentException("Invalid argument: " + 5); final IllegalArgumentException iae = new IllegalArgumentException("Invalid argument: " + 5);
final Executable testMethod = () -> Functions.stream(input) final Executable testMethod = () -> Functions.stream(input)
.map((s) -> Integer.valueOf(s)) .map(s -> Integer.valueOf(s))
.filter(asIntPredicate(iae)) .filter(asIntPredicate(iae))
.collect(Collectors.toList()); .collect(Collectors.toList());
final IllegalArgumentException thrown = assertThrows(IllegalArgumentException.class, testMethod); final IllegalArgumentException thrown = assertThrows(IllegalArgumentException.class, testMethod);
@ -180,7 +180,7 @@ class StreamsTest {
dynamicTest("OutOfMemoryError", () -> { dynamicTest("OutOfMemoryError", () -> {
final OutOfMemoryError oome = new OutOfMemoryError(); final OutOfMemoryError oome = new OutOfMemoryError();
final Executable testMethod = () -> Functions.stream(input) final Executable testMethod = () -> Functions.stream(input)
.map((s) -> Integer.valueOf(s)) .map(s -> Integer.valueOf(s))
.filter(asIntPredicate(oome)) .filter(asIntPredicate(oome))
.collect(Collectors.toList()); .collect(Collectors.toList());
final OutOfMemoryError thrown = assertThrows(OutOfMemoryError.class, testMethod); final OutOfMemoryError thrown = assertThrows(OutOfMemoryError.class, testMethod);
@ -190,7 +190,7 @@ class StreamsTest {
dynamicTest("SAXException", () -> { dynamicTest("SAXException", () -> {
final SAXException se = new SAXException(); final SAXException se = new SAXException();
final Executable testMethod = () -> Functions.stream(input) final Executable testMethod = () -> Functions.stream(input)
.map((s) -> Integer.valueOf(s)) .map(s -> Integer.valueOf(s))
.filter(asIntPredicate(se)) .filter(asIntPredicate(se))
.collect(Collectors.toList()); .collect(Collectors.toList());
final UndeclaredThrowableException thrown = assertThrows(UndeclaredThrowableException.class, testMethod); final UndeclaredThrowableException thrown = assertThrows(UndeclaredThrowableException.class, testMethod);