public class PredicatedSet<E> extends PredicatedCollection<E> implements Set<E>
Set
to validate that all additions
match a specified predicate.
This set exists to provide validation for the decorated set. It is normally created to decorate an empty set. If an object cannot be added to the set, an IllegalArgumentException is thrown.
One usage would be to ensure that no null entries are added to the set.
Set set = PredicatedSet.decorate(new HashSet(), NotNullPredicate.INSTANCE);
This class is Serializable from Commons Collections 3.1.
predicate
Modifier | Constructor and Description |
---|---|
protected |
PredicatedSet(Set<E> set,
Predicate<? super E> predicate)
Constructor that wraps (not copies).
|
Modifier and Type | Method and Description |
---|---|
protected Set<E> |
decorated()
Gets the set being decorated.
|
static <E> PredicatedSet<E> |
predicatedSet(Set<E> set,
Predicate<? super E> predicate)
Factory method to create a predicated (validating) set.
|
add, addAll, predicatedCollection, validate
clear, contains, containsAll, equals, hashCode, isEmpty, iterator, remove, removeAll, retainAll, setCollection, size, toArray, toArray, toString
protected PredicatedSet(Set<E> set, Predicate<? super E> predicate)
If there are any elements already in the set being decorated, they are validated.
set
- the set to decorate, must not be nullpredicate
- the predicate to use for validation, must not be nullIllegalArgumentException
- if set or predicate is nullIllegalArgumentException
- if the set contains invalid elementspublic static <E> PredicatedSet<E> predicatedSet(Set<E> set, Predicate<? super E> predicate)
If there are any elements already in the set being decorated, they are validated.
E
- the element typeset
- the set to decorate, must not be nullpredicate
- the predicate to use for validation, must not be nullIllegalArgumentException
- if set or predicate is nullIllegalArgumentException
- if the set contains invalid elementsCopyright © 2001–2013 The Apache Software Foundation. All rights reserved.