From 87ae1dfc8d8cb7b51d7bda4750ce841bbe691cfc Mon Sep 17 00:00:00 2001 From: bculkin2442 Date: Sat, 7 May 2016 12:51:23 -0400 Subject: General changes --- .../src/main/java/bjc/utils/data/Option.java | 74 ++++++++++++++++++++++ 1 file changed, 74 insertions(+) create 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 new file mode 100644 index 0000000..9f6d448 --- /dev/null +++ b/BJC-Utils2/src/main/java/bjc/utils/data/Option.java @@ -0,0 +1,74 @@ +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 seedValue + * The initial value for the optional + */ + public Option(ContainedType seedValue) { + held = seedValue; + } + + @Override + public IHolder bind( + Function> binder) { + if (held == null) { + return new Option<>(null); + } + + return binder.apply(held); + } + + @Override + public IHolder map( + Function mapper) { + if (held == null) { + return new Option<>(null); + } + + return new Option<>(mapper.apply(held)); + } + + @Override + public IHolder transform( + UnaryOperator transformer) { + if (held != null) { + held = transformer.apply(held); + } + + return this; + } + + @Override + public UnwrappedType unwrap( + Function unwrapper) { + if (held == null) { + return null; + } + + return unwrapper.apply(held); + } + + @Override + public Function> lift( + Function func) { + return (val) -> { + return new Option<>(func.apply(val)); + }; + } +} -- cgit v1.2.3