From c82e3b3b2de0633317ec8fc85925e91422820597 Mon Sep 17 00:00:00 2001 From: "Benjamin J. Culkin" Date: Sun, 8 Oct 2017 22:39:59 -0300 Subject: Start splitting into maven modules --- .../src/main/java/bjc/utils/data/Option.java | 93 ---------------------- 1 file changed, 93 deletions(-) delete mode 100644 BJC-Utils2/src/main/java/bjc/utils/data/Option.java (limited to 'BJC-Utils2/src/main/java/bjc/utils/data/Option.java') diff --git a/BJC-Utils2/src/main/java/bjc/utils/data/Option.java b/BJC-Utils2/src/main/java/bjc/utils/data/Option.java deleted file mode 100644 index 37e0cde..0000000 --- a/BJC-Utils2/src/main/java/bjc/utils/data/Option.java +++ /dev/null @@ -1,93 +0,0 @@ -package bjc.utils.data; - -import java.util.function.Function; -import java.util.function.UnaryOperator; - -/** - * A holder that may or may not contain a value - * - * @author ben - * - * @param - * The type of the value that may or may not be held - */ -public class Option implements IHolder { - private ContainedType held; - - /** - * Create a new optional, using the given initial value - * - * @param seed - * The initial value for the optional - */ - public Option(final ContainedType seed) { - held = seed; - } - - @Override - public IHolder bind(final Function> binder) { - if (held == null) return new Option<>(null); - - return binder.apply(held); - } - - @Override - public Function> lift(final Function func) { - return val -> { - return new Option<>(func.apply(val)); - }; - } - - @Override - public IHolder map(final Function mapper) { - if (held == null) return new Option<>(null); - - return new Option<>(mapper.apply(held)); - } - - @Override - public IHolder transform(final UnaryOperator transformer) { - if (held != null) { - held = transformer.apply(held); - } - - return this; - } - - @Override - public UnwrappedType unwrap(final Function unwrapper) { - if (held == null) return null; - - return unwrapper.apply(held); - } - - @Override - public String toString() { - return String.format("Option [held='%s']", held); - } - - @Override - public int hashCode() { - final int prime = 31; - - int result = 1; - result = prime * result + (held == null ? 0 : held.hashCode()); - - return result; - } - - @Override - public boolean equals(final Object obj) { - if (this == obj) return true; - if (obj == null) return false; - if (!(obj instanceof Option)) return false; - - final Option other = (Option) obj; - - if (held == null) { - if (other.held != null) return false; - } else if (!held.equals(other.held)) return false; - - return true; - } -} -- cgit v1.2.3