summaryrefslogtreecommitdiff
path: root/BJC-Utils2/src/main/java/bjc/utils/data/internals/WrappedOption.java
diff options
context:
space:
mode:
Diffstat (limited to 'BJC-Utils2/src/main/java/bjc/utils/data/internals/WrappedOption.java')
-rw-r--r--BJC-Utils2/src/main/java/bjc/utils/data/internals/WrappedOption.java76
1 files changed, 0 insertions, 76 deletions
diff --git a/BJC-Utils2/src/main/java/bjc/utils/data/internals/WrappedOption.java b/BJC-Utils2/src/main/java/bjc/utils/data/internals/WrappedOption.java
deleted file mode 100644
index 512c699..0000000
--- a/BJC-Utils2/src/main/java/bjc/utils/data/internals/WrappedOption.java
+++ /dev/null
@@ -1,76 +0,0 @@
-package bjc.utils.data.internals;
-
-import java.util.function.Function;
-import java.util.function.UnaryOperator;
-
-import bjc.utils.data.IHolder;
-import bjc.utils.data.Option;
-
-public class WrappedOption<ContainedType> implements IHolder<ContainedType> {
- private final IHolder<IHolder<ContainedType>> held;
-
- public WrappedOption(final IHolder<ContainedType> seedValue) {
- held = new Option<>(seedValue);
- }
-
- private WrappedOption(final IHolder<IHolder<ContainedType>> toHold, final boolean dummy) {
- held = toHold;
- }
-
- @Override
- public <BoundType> IHolder<BoundType> bind(final Function<ContainedType, IHolder<BoundType>> binder) {
- final IHolder<IHolder<BoundType>> newHolder = held.map((containedHolder) -> {
- return containedHolder.bind((containedValue) -> {
- if (containedValue == null) return new Option<>(null);
-
- return binder.apply(containedValue);
- });
- });
-
- return new WrappedOption<>(newHolder, false);
- }
-
- @Override
- public <NewType> Function<ContainedType, IHolder<NewType>> lift(final Function<ContainedType, NewType> func) {
- return (val) -> {
- return new Option<>(func.apply(val));
- };
- }
-
- @Override
- public <MappedType> IHolder<MappedType> map(final Function<ContainedType, MappedType> mapper) {
- final IHolder<IHolder<MappedType>> newHolder = held.map((containedHolder) -> {
- return containedHolder.map((containedValue) -> {
- if (containedValue == null) return null;
-
- return mapper.apply(containedValue);
- });
- });
-
- return new WrappedOption<>(newHolder, false);
- }
-
- @Override
- public IHolder<ContainedType> transform(final UnaryOperator<ContainedType> transformer) {
- held.transform((containedHolder) -> {
- return containedHolder.transform((containedValue) -> {
- if (containedValue == null) return null;
-
- return transformer.apply(containedValue);
- });
- });
-
- return this;
- }
-
- @Override
- public <UnwrappedType> UnwrappedType unwrap(final Function<ContainedType, UnwrappedType> unwrapper) {
- return held.unwrap((containedHolder) -> {
- return containedHolder.unwrap((containedValue) -> {
- if (containedValue == null) return null;
-
- return unwrapper.apply(containedValue);
- });
- });
- }
-}