diff --git a/src/test/java/lambda/part3/exercise/Mapping.java b/src/test/java/lambda/part3/exercise/Mapping.java index c0a814a..fe2863b 100644 --- a/src/test/java/lambda/part3/exercise/Mapping.java +++ b/src/test/java/lambda/part3/exercise/Mapping.java @@ -9,8 +9,6 @@ import java.util.Arrays; import java.util.Collections; import java.util.List; -import java.util.function.BiConsumer; -import java.util.function.Consumer; import java.util.function.Function; import java.util.function.Predicate; @@ -32,8 +30,10 @@ public List getList() { // [T] -> (T -> R) -> [R] // [T1, T2, T3] -> (T -> R) -> [R1, R2, R3] public MapHelper map(Function f) { - // TODO - throw new UnsupportedOperationException(); + final List result = new ArrayList(); + list.forEach((T t) -> result.add(f.apply(t))); + + return new MapHelper(result); } // [T] -> (T -> [R]) -> [R] @@ -76,12 +76,10 @@ public void mapping() { final List mappedEmployees = new MapHelper<>(employees) - /* - .map(TODO) // change name to John .map(e -> e.withPerson(e.getPerson().withFirstName("John"))) - .map(TODO) // add 1 year to experience duration .map(e -> e.withJobHistory(addOneYear(e.getJobHistory()))) - .map(TODO) // replace qa with QA - * */ - .getList(); + .map(e -> e.withPerson(e.getPerson().withFirstName("John"))) + .map(e -> e.withJobHistory(addOneYear(e.getJobHistory()))) + .map(e -> e.withJobHistory(changePosition(e.getJobHistory()))) + .getList(); final List expectedResult = Arrays.asList( @@ -108,10 +106,27 @@ public void mapping() { assertEquals(mappedEmployees, expectedResult); } + private List changePosition(List jobHistory) { + return new MapHelper<>(jobHistory) + .map(jobEntry -> + jobEntry.getPosition().equals("qa") ? jobEntry.withPosition("QA") : jobEntry) + .getList(); + } + + private List addOneYear(List jobHistory) { + return new MapHelper<>(jobHistory) + .map(jh -> jh.withDuration(jh.getDuration() + 1)) + .getList(); + } + private static class LazyMapHelper { + private final List list; + private final Function function; public LazyMapHelper(List list, Function function) { + this.list = list; + this.function = function; } public static LazyMapHelper from(List list) { @@ -119,52 +134,78 @@ public static LazyMapHelper from(List list) { } public List force() { - // TODO - throw new UnsupportedOperationException(); + final List result = new ArrayList(); + list.forEach(t -> result.add(function.apply(t))); + + return result; } public LazyMapHelper map(Function f) { - // TODO - throw new UnsupportedOperationException(); + final Function combinedFunction = combine(this.function, f); + return new LazyMapHelper<>(this.list, combinedFunction); + } + + private Function combine(Function function, Function f) { + if (f == null) + return (Function) function; + return function.andThen(f); } } + private static class LazyFlatMapHelper { + private final List list; + private final Function> function; public LazyFlatMapHelper(List list, Function> function) { + this.list = list; + this.function = function; } public static LazyFlatMapHelper from(List list) { - throw new UnsupportedOperationException(); + return new LazyFlatMapHelper<>(list, Collections::singletonList); } public List force() { - // TODO - throw new UnsupportedOperationException(); + final List result = new ArrayList<>(); + list.forEach(t -> function.apply(t).forEach(result::add)); + + return result; } - // TODO filter + // (T -> boolean) -> (T -> [T]) // filter: [T1, T2] -> (T -> boolean) -> [T2] // flatMap": [T1, T2] -> (T -> [T]) -> [T2] + public LazyFlatMapHelper filter(Predicate p) { + final List result = new ArrayList<>(); - public LazyFlatMapHelper map(Function f) { - final Function> listFunction = rR2TorListR2(f); + list.forEach(t -> { + if (p.test(t)) + result.add(t); + }); + + return LazyFlatMapHelper.from(result); + } + + + public LazyFlatMapHelper map(Function f) { + final Function> listFunction = rR2TorListR2(f); return flatMap(listFunction); } // (R -> R2) -> (R -> [R2]) - private Function> rR2TorListR2(Function f) { - throw new UnsupportedOperationException(); + private Function> rR2TorListR2(Function f) { + return r -> Collections.singletonList(f.apply(r)); } // TODO * - public LazyFlatMapHelper flatMap(Function> f) { - throw new UnsupportedOperationException(); + public LazyFlatMapHelper flatMap(Function> f) { + return new LazyFlatMapHelper(list, f); } - } + } @Test @@ -193,12 +234,10 @@ public void lazy_mapping() { final List mappedEmployees = LazyMapHelper.from(employees) - /* - .map(TODO) // change name to John - .map(TODO) // add 1 year to experience duration - .map(TODO) // replace qa with QA - * */ - .force(); + .map(e -> e.withPerson(e.getPerson().withFirstName("John"))) + .map(e -> e.withJobHistory(addOneYear(e.getJobHistory()))) + .map(e -> e.withJobHistory(changePosition(e.getJobHistory()))) + .force(); final List expectedResult = Arrays.asList(