blob: 1193c8de334b13b24081d6cfdd34f1b1059e4019 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
package bjc.data.internals;
import java.util.function.Function;
import java.util.function.UnaryOperator;
import bjc.data.IHolder;
import bjc.data.ListHolder;
import bjc.funcdata.IList;
/**
* Holds a list, converted into a holder.
*
* @author Ben Culkin
*/
@SuppressWarnings("javadoc")
public class BoundListHolder<ContainedType> implements IHolder<ContainedType> {
/* The list of contained holders. */
private final IList<IHolder<ContainedType>> heldHolders;
/**
* Create a new list of holders.
*
* @param toHold
* The list of holders to, well, hold.
*/
public BoundListHolder(final IList<IHolder<ContainedType>> toHold) {
heldHolders = toHold;
}
@Override
public <BoundType> IHolder<BoundType>
bind(final Function<ContainedType, IHolder<BoundType>> binder) {
if (binder == null)
throw new NullPointerException("Binder must not be null");
final IList<IHolder<BoundType>> boundHolders
= heldHolders.map(containedHolder -> {
return containedHolder.bind(binder);
});
return new BoundListHolder<>(boundHolders);
}
@Override
public <NewType> Function<ContainedType, IHolder<NewType>>
lift(final Function<ContainedType, NewType> func) {
if (func == null)
throw new NullPointerException("Function to lift must not be null");
return val -> {
return new ListHolder<>(func.apply(val));
};
}
@Override
public <MappedType> IHolder<MappedType>
map(final Function<ContainedType, MappedType> mapper) {
if (mapper == null)
throw new NullPointerException("Mapper must not be null");
final IList<IHolder<MappedType>> mappedHolders
= heldHolders.map(containedHolder -> {
return containedHolder.map(mapper);
});
return new BoundListHolder<>(mappedHolders);
}
@Override
public IHolder<ContainedType>
transform(final UnaryOperator<ContainedType> transformer) {
if (transformer == null)
throw new NullPointerException("Transformer must not be null");
heldHolders.forEach(containedHolder -> {
containedHolder.transform(transformer);
});
return this;
}
@Override
public <UnwrappedType> UnwrappedType
unwrap(final Function<ContainedType, UnwrappedType> unwrapper) {
if (unwrapper == null)
throw new NullPointerException("Unwrapper must not be null");
/*
* @NOTE Is there another way we could want to do this?
*/
return heldHolders.randItem().unwrap(unwrapper);
}
}
|