All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.common.base.Predicate Maven / Gradle / Ivy

/*
 * Copyright (C) 2007 Google Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.google.common.base;

/**
 * Determines a true or false value for any input of its parameterized type. For
 * example, a {@code RegexPredicate} might implement {@code Predicate},
 * and return true for any String that matches its given regular expression.
 *
 * 

Implementations which may cause side effects upon evaluation are strongly * encouraged to state this fact clearly in their API documentation. * *

NOTE: This interface could technically extend * {@link Function}, since a predicate is just a special case of a function (one * that returns a boolean). However, since implementing this would entail * changing the signature of the {@link #apply} method to return a * {@link Boolean} instead of a {@code boolean}, which would in turn allow * people to return null from their predicate, which would in turn enable code * that looks like {@code if (myPredicate.apply(myObject)) ... } to throw a * {@link NullPointerException}, it was decided not to make this change. * * @author Kevin Bourrillion */ public interface Predicate { /** * Applies this predicate to the given object. * * @return the value of this predicate when applied to the input {@code t} */ boolean apply(@Nullable T t); /** * Indicates whether some other object is equal to this {@code Predicate}. * This method can return {@code true} only if the specified object * is also a {@code Predicate} and, for every input object {@code o}, it * returns exactly the same value. Thus, * {@code predicate1.equals(predicate2)} implies that either * {@code predicate1.apply(o)} and {@code predicate2.apply(o)} are both * {@code true}, or both {@code false}. * *

Note that it is always safe not to override * {@code Object.equals(Object)}. */ boolean equals(Object obj); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy