io.activej.async.function.AsyncPredicates Maven / Gradle / Ivy
Show all versions of activej-promise Show documentation
/*
* Copyright (C) 2020 ActiveJ LLC.
*
* 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 io.activej.async.function;
import io.activej.async.AsyncAccumulator;
import io.activej.async.process.AsyncExecutor;
import io.activej.async.process.AsyncExecutors;
import io.activej.common.ref.RefBoolean;
import org.jetbrains.annotations.Contract;
import java.util.Collection;
import java.util.List;
import java.util.function.Predicate;
public final class AsyncPredicates {
@Contract(pure = true)
public static AsyncPredicate buffer(AsyncPredicate actual) {
return buffer(1, Integer.MAX_VALUE, actual);
}
@Contract(pure = true)
public static AsyncPredicate buffer(int maxParallelCalls, int maxBufferedCalls, AsyncPredicate predicate) {
return ofExecutor(AsyncExecutors.buffered(maxParallelCalls, maxBufferedCalls), predicate);
}
@Contract(pure = true)
public static AsyncPredicate ofExecutor(AsyncExecutor executor, AsyncPredicate predicate) {
return t -> executor.execute(() -> predicate.test(t));
}
/**
* Returns a composed {@link AsyncPredicate} that represents a logical AND of all predicates
* in a given collection
*
* Unlike Java's {@link Predicate#and(Predicate)} this method does not provide short-circuit.
* If either predicate returns an exceptionally completed promise,
* the combined asynchronous predicate also returns an exceptionally completed promise
*
* @param predicates a collection of {@link AsyncPredicate}s that will be logically ANDed
* @return a composed {@link AsyncPredicate} that represents a logical AND of asynchronous predicates
* in a given collection
*/
public static AsyncPredicate and(Collection> predicates) {
return t -> {
AsyncAccumulator accumulator = AsyncAccumulator.create(new RefBoolean(true));
for (AsyncPredicate super T> predicate : predicates) {
accumulator.addPromise(predicate.test(t), (ref, result) -> ref.set(ref.get() && result));
}
return accumulator.run().map(RefBoolean::get);
};
}
/**
* Returns an {@link AsyncPredicate} that always returns promise of {@code true}
*
* @see #and(Collection)
*/
public static AsyncPredicate and() {
return AsyncPredicate.alwaysTrue();
}
/**
* Returns a given asynchronous predicate
*
* A shortcut for {@link #and(AsyncPredicate[])}
*
* @see #and(Collection)
* @see #and(AsyncPredicate[])
*/
public static AsyncPredicate and(AsyncPredicate super T> predicate1) {
//noinspection unchecked
return (AsyncPredicate) predicate1;
}
/**
* An optimization for {@link #and(AsyncPredicate[])}
*
* @see #and(Collection)
* @see #and(AsyncPredicate[])
*/
public static AsyncPredicate and(AsyncPredicate super T> predicate1, AsyncPredicate super T> predicate2) {
//noinspection unchecked
return ((AsyncPredicate) predicate1).and(predicate2);
}
/**
* Returns a composed {@link AsyncPredicate} that represents a logical AND of all predicates
* in a given array
*
* @see #and(Collection)
*/
@SafeVarargs
public static AsyncPredicate and(AsyncPredicate super T>... predicates) {
//noinspection RedundantCast
return and(((List>) List.of(predicates)));
}
/**
* Returns a composed {@link AsyncPredicate} that represents a logical OR of all predicates
* in a given collection
*
* Unlike Java's {@link Predicate#or(Predicate)} this method does not provide short-circuit.
* If either predicate returns an exceptionally completed promise,
* the combined asynchronous predicate also returns an exceptionally completed promise
*
* @param predicates a collection of {@link AsyncPredicate}s that will be logically ORed
* @return a composed {@link AsyncPredicate} that represents a logical OR of asynchronous predicates
* in a given collection
*/
public static AsyncPredicate or(Collection> predicates) {
return t -> {
AsyncAccumulator accumulator = AsyncAccumulator.create(new RefBoolean(false));
for (AsyncPredicate super T> predicate : predicates) {
accumulator.addPromise(predicate.test(t), (ref, result) -> ref.set(ref.get() || result));
}
return accumulator.run().map(RefBoolean::get);
};
}
/**
* @return an {@link AsyncPredicate} that always returns promise of {@code false}
* @see #or(Collection)
*/
public static AsyncPredicate or() {
return AsyncPredicate.alwaysFalse();
}
/**
* Returns a given asynchronous predicate
*
* A shortcut for {@link #or(AsyncPredicate[])}
*
* @see #or(Collection)
* @see #or(AsyncPredicate[])
*/
public static AsyncPredicate or(AsyncPredicate super T> predicate1) {
//noinspection unchecked
return (AsyncPredicate) predicate1;
}
/**
* An optimization for {@link #or(AsyncPredicate[])}
*
* @see #or(Collection)
* @see #or(AsyncPredicate[])
*/
public static AsyncPredicate or(AsyncPredicate super T> predicate1, AsyncPredicate super T> predicate2) {
//noinspection unchecked
return ((AsyncPredicate) predicate1).or(predicate2);
}
/**
* Returns a composed {@link AsyncPredicate} that represents a logical OR of all predicates
* in a given array
*
* @see #or(Collection)
*/
@SafeVarargs
public static AsyncPredicate or(AsyncPredicate super T>... predicates) {
//noinspection RedundantCast
return or(((List>) List.of(predicates)));
}
}