public final class Predicates
extends java.lang.Object
Modifier and Type | Method and Description |
---|---|
static <T> java.util.function.Predicate<T> |
alwaysFalse()
Returns a predicate that always evaluates to
false . |
static <T> java.util.function.Predicate<T> |
alwaysTrue()
Returns a predicate that always evaluates to
true . |
static <T> java.util.function.Predicate<T> |
and(java.lang.Iterable<? extends java.util.function.Predicate<? super T>> components)
Returns a predicate that evaluates to
true if each of its
components evaluates to true . |
static <T> java.util.function.Predicate<T> |
and(java.util.function.Predicate<? super T>... components)
Returns a predicate that evaluates to
true if each of its
components evaluates to true . |
static <T> java.util.function.Predicate<T> |
and(java.util.function.Predicate<? super T> first,
java.util.function.Predicate<? super T> second)
Returns a predicate that evaluates to
true if both of its
components evaluate to true . |
static java.util.function.Predicate<java.lang.Class<?>> |
assignableFrom(java.lang.Class<?> clazz)
Returns a predicate that evaluates to
true if the class being
tested is assignable from the given class. |
static <A,B> java.util.function.Predicate<A> |
compose(java.util.function.Predicate<B> predicate,
java.util.function.Function<A,? extends B> function)
Returns the composition of a function and a predicate.
|
static java.util.function.Predicate<java.lang.CharSequence> |
contains(java.util.regex.Pattern pattern)
Returns a predicate that evaluates to
true if the
CharSequence being tested contains any match for the given
regular expression pattern. |
static java.util.function.Predicate<java.lang.CharSequence> |
containsPattern(java.lang.String pattern)
Returns a predicate that evaluates to
true if the
CharSequence being tested contains any match for the given
regular expression pattern. |
static <T> java.util.function.Predicate<T> |
equalTo(T target)
Returns a predicate that evaluates to
true if the object being
tested equals() the given target or both are null. |
static <T> java.util.function.Predicate<T> |
in(java.util.Collection<? extends T> target)
Returns a predicate that evaluates to
true if the object reference
being tested is a member of the given collection. |
static java.util.function.Predicate<java.lang.Object> |
instanceOf(java.lang.Class<?> clazz)
Returns a predicate that evaluates to
true if the object being
tested is an instance of the given class. |
static <T> java.util.function.Predicate<T> |
isNull()
Returns a predicate that evaluates to
true if the object reference
being tested is null. |
static <T> java.util.function.Predicate<T> |
not(java.util.function.Predicate<T> predicate)
Returns a predicate that evaluates to
true if the given predicate
evaluates to false . |
static <T> java.util.function.Predicate<T> |
notNull()
Returns a predicate that evaluates to
true if the object reference
being tested is not null. |
static <T> java.util.function.Predicate<T> |
or(java.lang.Iterable<? extends java.util.function.Predicate<? super T>> components)
Returns a predicate that evaluates to
true if any one of its
components evaluates to true . |
static <T> java.util.function.Predicate<T> |
or(java.util.function.Predicate<? super T>... components)
Returns a predicate that evaluates to
true if any one of its
components evaluates to true . |
static <T> java.util.function.Predicate<T> |
or(java.util.function.Predicate<? super T> first,
java.util.function.Predicate<? super T> second)
Returns a predicate that evaluates to
true if either of its
components evaluates to true . |
public static <T> java.util.function.Predicate<T> alwaysTrue()
true
.public static <T> java.util.function.Predicate<T> alwaysFalse()
false
.public static <T> java.util.function.Predicate<T> isNull()
true
if the object reference
being tested is null.public static <T> java.util.function.Predicate<T> notNull()
true
if the object reference
being tested is not null.public static <T> java.util.function.Predicate<T> not(java.util.function.Predicate<T> predicate)
true
if the given predicate
evaluates to false
.public static <T> java.util.function.Predicate<T> and(java.lang.Iterable<? extends java.util.function.Predicate<? super T>> components)
true
if each of its
components evaluates to true
. The components are evaluated in
order, and evaluation will be "short-circuited" as soon as a false
predicate is found. It defensively copies the iterable passed in, so future
changes to it won't alter the behavior of this predicate. If components
is empty, the returned predicate will always evaluate to true
.@SafeVarargs public static <T> java.util.function.Predicate<T> and(java.util.function.Predicate<? super T>... components)
true
if each of its
components evaluates to true
. The components are evaluated in
order, and evaluation will be "short-circuited" as soon as a false
predicate is found. It defensively copies the array passed in, so future
changes to it won't alter the behavior of this predicate. If components
is empty, the returned predicate will always evaluate to true
.public static <T> java.util.function.Predicate<T> and(java.util.function.Predicate<? super T> first, java.util.function.Predicate<? super T> second)
true
if both of its
components evaluate to true
. The components are evaluated in
order, and evaluation will be "short-circuited" as soon as a false
predicate is found.public static <T> java.util.function.Predicate<T> or(java.lang.Iterable<? extends java.util.function.Predicate<? super T>> components)
true
if any one of its
components evaluates to true
. The components are evaluated in
order, and evaluation will be "short-circuited" as soon as a
true predicate is found. It defensively copies the iterable passed in, so
future changes to it won't alter the behavior of this predicate. If components
is empty, the returned predicate will always evaluate to false
.@SafeVarargs public static <T> java.util.function.Predicate<T> or(java.util.function.Predicate<? super T>... components)
true
if any one of its
components evaluates to true
. The components are evaluated in
order, and evaluation will be "short-circuited" as soon as a
true predicate is found. It defensively copies the array passed in, so
future changes to it won't alter the behavior of this predicate. If components
is empty, the returned predicate will always evaluate to false
.public static <T> java.util.function.Predicate<T> or(java.util.function.Predicate<? super T> first, java.util.function.Predicate<? super T> second)
true
if either of its
components evaluates to true
. The components are evaluated in
order, and evaluation will be "short-circuited" as soon as a
true predicate is found.public static <T> java.util.function.Predicate<T> equalTo(@Nullable T target)
true
if the object being
tested equals()
the given target or both are null.public static java.util.function.Predicate<java.lang.Object> instanceOf(java.lang.Class<?> clazz)
true
if the object being
tested is an instance of the given class. If the object being tested
is null
this predicate evaluates to false
.public static java.util.function.Predicate<java.lang.Class<?>> assignableFrom(java.lang.Class<?> clazz)
true
if the class being
tested is assignable from the given class. The returned predicate
does not allow null inputs.public static <T> java.util.function.Predicate<T> in(java.util.Collection<? extends T> target)
true
if the object reference
being tested is a member of the given collection. It does not defensively
copy the collection passed in, so future changes to it will alter the
behavior of the predicate.
This method can technically accept any Collection<?>
, but using
a typed collection helps prevent bugs. This approach doesn't block any
potential users since it is always possible to use Predicates.<Object>in()
.
target
- the collection that may contain the function inputpublic static <A,B> java.util.function.Predicate<A> compose(java.util.function.Predicate<B> predicate, java.util.function.Function<A,? extends B> function)
x
,
the generated predicate returns predicate(function(x))
.public static java.util.function.Predicate<java.lang.CharSequence> containsPattern(java.lang.String pattern)
true
if the
CharSequence
being tested contains any match for the given
regular expression pattern. The test used is equivalent to
Pattern.compile(pattern).matcher(arg).find()
java.util.regex.PatternSyntaxException
- if the pattern is invalidpublic static java.util.function.Predicate<java.lang.CharSequence> contains(java.util.regex.Pattern pattern)
true
if the
CharSequence
being tested contains any match for the given
regular expression pattern. The test used is equivalent to
pattern.matcher(arg).find()