Merging from -r468106:814127 of collections_jdk5_branch - namely where this code was generified; mostly in r738956.
Also see the following revisions: ------------------------------------------------------------------------ r641231 | skestle | 2008-03-26 02:58:51 -0700 (Wed, 26 Mar 2008) | 1 line Started incorporating Edwin's patch for COLLECTIONS-253, in preparation for COLLECTIONS-290. ------------------------------------------------------------------------ git-svn-id: https://svn.apache.org/repos/asf/commons/proper/collections/trunk@815048 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
e47b5cf540
commit
b9db60ade4
|
@ -17,7 +17,6 @@
|
||||||
package org.apache.commons.collections.functors;
|
package org.apache.commons.collections.functors;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Iterator;
|
|
||||||
|
|
||||||
import org.apache.commons.collections.Closure;
|
import org.apache.commons.collections.Closure;
|
||||||
import org.apache.commons.collections.Predicate;
|
import org.apache.commons.collections.Predicate;
|
||||||
|
@ -43,15 +42,35 @@ class FunctorUtils {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clone the predicates to ensure that the internal reference can't be messed with.
|
* Clone the predicates to ensure that the internal reference can't be messed with.
|
||||||
|
* Due to the {@link Predicate#evaluate(T)} method, Predicate<? super T> is
|
||||||
|
* able to be coerced to Predicate<T> without casting issues.
|
||||||
*
|
*
|
||||||
* @param predicates the predicates to copy
|
* @param predicates the predicates to copy
|
||||||
* @return the cloned predicates
|
* @return the cloned predicates
|
||||||
*/
|
*/
|
||||||
static Predicate[] copy(Predicate[] predicates) {
|
@SuppressWarnings("unchecked")
|
||||||
|
static <T> Predicate<T>[] copy(Predicate<? super T>[] predicates) {
|
||||||
if (predicates == null) {
|
if (predicates == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return (Predicate[]) predicates.clone();
|
return (Predicate<T>[]) predicates.clone();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A very simple method that coerces Predicate<? super T> to Predicate<T>.
|
||||||
|
* Due to the {@link Predicate#evaluate(T)} method, Predicate<? super T> is
|
||||||
|
* able to be coerced to Predicate<T> without casting issues.
|
||||||
|
* <p>This method exists
|
||||||
|
* simply as centralised documentation and atomic unchecked warning
|
||||||
|
* suppression.
|
||||||
|
*
|
||||||
|
* @param <T> the type of object the returned predicate should "accept"
|
||||||
|
* @param predicate the predicate to coerce.
|
||||||
|
* @return the coerced predicate.
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
static <T> Predicate<T> coerce(Predicate<? super T> predicate){
|
||||||
|
return (Predicate<T>) predicate;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -59,7 +78,7 @@ class FunctorUtils {
|
||||||
*
|
*
|
||||||
* @param predicates the predicates to validate
|
* @param predicates the predicates to validate
|
||||||
*/
|
*/
|
||||||
static void validate(Predicate[] predicates) {
|
static void validate(Predicate<?>[] predicates) {
|
||||||
if (predicates == null) {
|
if (predicates == null) {
|
||||||
throw new IllegalArgumentException("The predicate array must not be null");
|
throw new IllegalArgumentException("The predicate array must not be null");
|
||||||
}
|
}
|
||||||
|
@ -76,15 +95,16 @@ class FunctorUtils {
|
||||||
* @param predicates the predicates to validate
|
* @param predicates the predicates to validate
|
||||||
* @return predicate array
|
* @return predicate array
|
||||||
*/
|
*/
|
||||||
static Predicate[] validate(Collection predicates) {
|
@SuppressWarnings("unchecked")
|
||||||
|
static <T> Predicate<T>[] validate(Collection<? extends Predicate<T>> predicates) {
|
||||||
if (predicates == null) {
|
if (predicates == null) {
|
||||||
throw new IllegalArgumentException("The predicate collection must not be null");
|
throw new IllegalArgumentException("The predicate collection must not be null");
|
||||||
}
|
}
|
||||||
// convert to array like this to guarantee iterator() ordering
|
// convert to array like this to guarantee iterator() ordering
|
||||||
Predicate[] preds = new Predicate[predicates.size()];
|
Predicate<T>[] preds = new Predicate[predicates.size()];
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (Iterator it = predicates.iterator(); it.hasNext();) {
|
for (Predicate<T> predicate : predicates) {
|
||||||
preds[i] = (Predicate) it.next();
|
preds[i] = predicate;
|
||||||
if (preds[i] == null) {
|
if (preds[i] == null) {
|
||||||
throw new IllegalArgumentException("The predicate collection must not contain a null predicate, index " + i + " was null");
|
throw new IllegalArgumentException("The predicate collection must not contain a null predicate, index " + i + " was null");
|
||||||
}
|
}
|
||||||
|
@ -99,11 +119,12 @@ class FunctorUtils {
|
||||||
* @param closures the closures to copy
|
* @param closures the closures to copy
|
||||||
* @return the cloned closures
|
* @return the cloned closures
|
||||||
*/
|
*/
|
||||||
static Closure[] copy(Closure[] closures) {
|
@SuppressWarnings("unchecked")
|
||||||
|
static <E> Closure<E>[] copy(Closure<? super E>[] closures) {
|
||||||
if (closures == null) {
|
if (closures == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return (Closure[]) closures.clone();
|
return (Closure<E>[]) closures.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -111,7 +132,7 @@ class FunctorUtils {
|
||||||
*
|
*
|
||||||
* @param closures the closures to validate
|
* @param closures the closures to validate
|
||||||
*/
|
*/
|
||||||
static void validate(Closure[] closures) {
|
static void validate(Closure<?>[] closures) {
|
||||||
if (closures == null) {
|
if (closures == null) {
|
||||||
throw new IllegalArgumentException("The closure array must not be null");
|
throw new IllegalArgumentException("The closure array must not be null");
|
||||||
}
|
}
|
||||||
|
@ -122,17 +143,33 @@ class FunctorUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A very simple method that coerces Closure<? super T> to Closure<T>.
|
||||||
|
* <p>This method exists
|
||||||
|
* simply as centralised documentation and atomic unchecked warning
|
||||||
|
* suppression.
|
||||||
|
*
|
||||||
|
* @param <T> the type of object the returned closure should "accept"
|
||||||
|
* @param closure the closure to coerce.
|
||||||
|
* @return the coerced closure.
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
static <T> Closure<T> coerce(Closure<? super T> closure){
|
||||||
|
return (Closure<T>) closure;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copy method
|
* Copy method
|
||||||
*
|
*
|
||||||
* @param transformers the transformers to copy
|
* @param transformers the transformers to copy
|
||||||
* @return a clone of the transformers
|
* @return a clone of the transformers
|
||||||
*/
|
*/
|
||||||
static Transformer[] copy(Transformer[] transformers) {
|
@SuppressWarnings("unchecked")
|
||||||
|
static <I, O> Transformer<I, O>[] copy(Transformer<? super I, ? extends O>[] transformers) {
|
||||||
if (transformers == null) {
|
if (transformers == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return (Transformer[]) transformers.clone();
|
return (Transformer<I, O>[]) transformers.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -140,7 +177,7 @@ class FunctorUtils {
|
||||||
*
|
*
|
||||||
* @param transformers the transformers to validate
|
* @param transformers the transformers to validate
|
||||||
*/
|
*/
|
||||||
static void validate(Transformer[] transformers) {
|
static void validate(Transformer<?, ?>[] transformers) {
|
||||||
if (transformers == null) {
|
if (transformers == null) {
|
||||||
throw new IllegalArgumentException("The transformer array must not be null");
|
throw new IllegalArgumentException("The transformer array must not be null");
|
||||||
}
|
}
|
||||||
|
@ -152,4 +189,19 @@ class FunctorUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A very simple method that coerces Transformer<? super I, ? extends O> to Transformer<I, O>.
|
||||||
|
* <p>This method exists
|
||||||
|
* simply as centralised documentation and atomic unchecked warning
|
||||||
|
* suppression.
|
||||||
|
*
|
||||||
|
* @param <T> the type of object the returned transformer should "accept"
|
||||||
|
* @param transformer the transformer to coerce.
|
||||||
|
* @return the coerced transformer.
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
static <I, O> Transformer<I, O> coerce(Transformer<? super I, ? extends O> transformer) {
|
||||||
|
return (Transformer<I, O>) transformer;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue