summaryrefslogtreecommitdiff
path: root/BJC-Utils2/src/main/java/bjc/utils/data/lazy/LazyPair.java
diff options
context:
space:
mode:
Diffstat (limited to 'BJC-Utils2/src/main/java/bjc/utils/data/lazy/LazyPair.java')
-rw-r--r--BJC-Utils2/src/main/java/bjc/utils/data/lazy/LazyPair.java19
1 files changed, 16 insertions, 3 deletions
diff --git a/BJC-Utils2/src/main/java/bjc/utils/data/lazy/LazyPair.java b/BJC-Utils2/src/main/java/bjc/utils/data/lazy/LazyPair.java
index e08c8fb..7ba7ee7 100644
--- a/BJC-Utils2/src/main/java/bjc/utils/data/lazy/LazyPair.java
+++ b/BJC-Utils2/src/main/java/bjc/utils/data/lazy/LazyPair.java
@@ -98,9 +98,9 @@ public class LazyPair<L, R> implements IPair<L, R>, ILazy {
throw new NullPointerException("Transforms must be non-null");
}
- IHolder<IPair<L2, R2>> newPair =
- delegatePair.map((currentPair) -> currentPair
- .apply(leftTransform, rightTransform));
+ IHolder<IPair<L2, R2>> newPair = delegatePair
+ .map((currentPair) -> currentPair.apply(leftTransform,
+ rightTransform));
return new LazyPair<>(newPair, materialized, true);
}
@@ -169,4 +169,17 @@ public class LazyPair<L, R> implements IPair<L, R>, ILazy {
materialized = true;
pendingActions = false;
}
+
+ @Override
+ public <L2, R2> IPair<L2, R2> bind(
+ BiFunction<L, R, IPair<L2, R2>> binder) {
+ // TODO Auto-generated method stub
+ IHolder<IPair<L2, R2>> newDelegate = delegatePair
+ .map((pairVal) -> {
+ return pairVal.bind(binder);
+ });
+
+ return new LazyPair<>(newDelegate, isMaterialized(),
+ hasPendingActions());
+ }
} \ No newline at end of file