From 843329de434bb334d90927c4d22345373a388530 Mon Sep 17 00:00:00 2001 From: bculkin2442 Date: Tue, 2 Jul 2019 18:05:22 -0400 Subject: Rename package root The package root is now bjc, not io.github.bculkin2442. --- src/main/java/bjc/data/Identity.java | 112 +++++++++++++++++++++++++++++++++++ 1 file changed, 112 insertions(+) create mode 100644 src/main/java/bjc/data/Identity.java (limited to 'src/main/java/bjc/data/Identity.java') diff --git a/src/main/java/bjc/data/Identity.java b/src/main/java/bjc/data/Identity.java new file mode 100644 index 0000000..8645c4c --- /dev/null +++ b/src/main/java/bjc/data/Identity.java @@ -0,0 +1,112 @@ +package bjc.data; + +import java.util.function.Function; +import java.util.function.UnaryOperator; + +/** + * Simple implementation of IHolder that has no hidden behavior. + * + * @author ben + * + * @param + * The type contained in the holder. + */ +public class Identity implements IHolder { + /* The held value. */ + private ContainedType heldValue; + + /** Create a holder holding null */ + public Identity() { + heldValue = null; + } + + /** + * Create a holder holding the specified value. + * + * @param value + * The value to hold. + */ + public Identity(final ContainedType value) { + heldValue = value; + } + + @Override + public IHolder bind(final Function> binder) { + return binder.apply(heldValue); + } + + @Override + public int hashCode() { + final int prime = 31; + int result = 1; + + result = prime * result + (heldValue == null ? 0 : heldValue.hashCode()); + + return result; + } + + @Override + public boolean equals(final Object obj) { + if(this == obj) return true; + if(obj == null) return false; + if(!(obj instanceof Identity)) return false; + + final Identity other = (Identity) obj; + + if(heldValue == null) { + if(other.heldValue != null) return false; + } else if(!heldValue.equals(other.heldValue)) return false; + + return true; + } + + @Override + public Function> lift(final Function func) { + return (val) -> { + return new Identity<>(func.apply(val)); + }; + } + + @Override + public IHolder map(final Function mapper) { + return new Identity<>(mapper.apply(heldValue)); + } + + @Override + public String toString() { + return String.format("Identity [heldValue=%s]", heldValue); + } + + @Override + public IHolder transform(final UnaryOperator transformer) { + heldValue = transformer.apply(heldValue); + + return this; + } + + @Override + public UnwrappedType unwrap(final Function unwrapper) { + return unwrapper.apply(heldValue); + } + + /** + * Create a new identity container. + * + * @param val + * The contained value. + * + * @return A new identity container. + */ + public static Identity id(final ContainedType val) { + return new Identity<>(val); + } + + /** + * Create a new empty identity container. + * + * @return A new empty identity container. + */ + public static Identity id() { + return new Identity<>(); + } +} -- cgit v1.2.3