T1
- type of the first possible valueT2
- type of the second possible valuepublic abstract class Union<T1,T2> extends UnionBase<T1,T2>
This is sometimes useful to transport errors from one part to the other, when
throwing them is no option. This is a type-safe implementation of a 2-member union
structure as defined in the C programming language.
This class allows no overriding to guarantee the following invariances:
u.has1() ^ u.has2()
is always true
There is exactly one way to construct a union of either type:
t1(Object)
will construct a union which contains a value of type T1
t2(Object)
will construct a union which contains a value of type T2
This implementation does not allow null
values.
Any consumers can safely assume that the values they achieve are non-null
.
See NullableUnion
if support for null
is required.
Modifier and Type | Method and Description |
---|---|
abstract T1 |
get1()
Get the value if it is of type
T1 . |
abstract T2 |
get2()
Get the value if it is of type
T2 . |
abstract java.lang.Object |
getValue()
Get the value contained in this union.
|
abstract void |
handle(java.util.function.Consumer<? super T1> handler1,
java.util.function.Consumer<? super T2> handler2)
Call the appropriate handler depending on this unions' value.
|
abstract Union<T1,T2> |
handle1(java.util.function.Consumer<? super T1> handler)
Call the given handler if this union contains a value of type
T1 . |
abstract Union<T1,T2> |
handle2(java.util.function.Consumer<? super T2> handler)
Call the given handler if this union contains a value of type
T2 . |
abstract <E extends java.lang.Exception> |
handleFragile1(FragileProcedure1<E,? super T1> handler)
Call the given handler if this union contains a value of type
T1 . |
abstract <E extends java.lang.Exception> |
handleFragile2(FragileProcedure1<E,? super T2> handler)
Call the given handler if this union contains a value of type
T2 . |
abstract boolean |
has1()
Does this union contain a value of type
T1 ? |
abstract boolean |
has2()
Does this union contain a value of type
T2 ? |
static <V1,V2> Union<V1,V2> |
t1(V1 v1)
Create a union containing a value of type V1.
|
static <V1,V2> Union<V1,V2> |
t2(V2 v2)
Create a union containing a value of type V2.
|
public abstract boolean has1()
T1
?public abstract boolean has2()
T2
?@NotNull public abstract T1 get1() throws java.lang.IllegalStateException
T1
.
Throw an exception otherwise.@NotNull public abstract T2 get2() throws java.lang.IllegalStateException
T2
.
Throw an exception otherwise.@NotNull public abstract java.lang.Object getValue()
public abstract void handle(@NotNull java.util.function.Consumer<? super T1> handler1, @NotNull java.util.function.Consumer<? super T2> handler2)
@NotNull public abstract Union<T1,T2> handle1(@NotNull java.util.function.Consumer<? super T1> handler)
T1
.@NotNull public abstract Union<T1,T2> handle2(@NotNull java.util.function.Consumer<? super T2> handler)
T2
.@NotNull public abstract <E extends java.lang.Exception> Union<T1,T2> handleFragile1(@NotNull FragileProcedure1<E,? super T1> handler) throws E extends java.lang.Exception
T1
.
Allows for a handler which might throw a checked exception.handleFragile1
in class UnionBase<T1,T2>
E
- exception the handler might throwhandler
- called with the value of this union if the contained type is T1
, not called otherwiseE
- if handler
throws itE extends java.lang.Exception
@NotNull public abstract <E extends java.lang.Exception> Union<T1,T2> handleFragile2(@NotNull FragileProcedure1<E,? super T2> handler) throws E extends java.lang.Exception
T2
.
Allows for a handler which might throw a checked exception.handleFragile2
in class UnionBase<T1,T2>
E
- exception the handler might throwhandler
- called with the value of this union if the contained type is T2
, not called otherwiseE
- if handler
throws itE extends java.lang.Exception
@NotNull public static <V1,V2> Union<V1,V2> t1(@NotNull V1 v1)
V1
- value type of contained valueV2
- implicitv1
- value contained in this unionv1