castFrom<S, T> method
Adapts source
to be a Set<T>
.
If newSet
is provided, it is used to create the new sets returned
by toSet, union, and is also used for intersection and difference.
If newSet
is omitted, it defaults to creating a new set using the
default Set constructor, and intersection and difference
returns an adapted version of calling the same method on the source.
Any time the set would produce an element that is not a T
,
the element access will throw.
Any time a T
value is attempted added into the adapted set,
the store will throw unless the value is also an instance of S
.
If all accessed elements of source
are actually instances of T
,
and if all elements added to the returned set are actually instance
of S
,
then the returned set can be used as a Set<T>
.
Implementation
static Set<T> castFrom<S, T>(Set<S> source, {Set<R> Function<R>() newSet}) =>
new CastSet<S, T>(source, newSet);