Add filter() and transform()
Add lots of javadoc Deprecate empty iterator git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/collections/trunk@130796 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
844eb0adcc
commit
41be9cbfa9
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* $Header: /home/jerenkrantz/tmp/commons/commons-convert/cvs/home/cvs/jakarta-commons//collections/src/java/org/apache/commons/collections/CollectionUtils.java,v 1.13 2002/08/17 21:10:46 pjack Exp $
|
* $Header: /home/jerenkrantz/tmp/commons/commons-convert/cvs/home/cvs/jakarta-commons//collections/src/java/org/apache/commons/collections/CollectionUtils.java,v 1.14 2002/08/18 15:26:20 scolebourne Exp $
|
||||||
* $Revision: 1.13 $
|
* $Revision: 1.14 $
|
||||||
* $Date: 2002/08/17 21:10:46 $
|
* $Date: 2002/08/18 15:26:20 $
|
||||||
*
|
*
|
||||||
* ====================================================================
|
* ====================================================================
|
||||||
*
|
*
|
||||||
|
@ -68,6 +68,7 @@ import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.ListIterator;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.NoSuchElementException;
|
import java.util.NoSuchElementException;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
@ -78,39 +79,22 @@ import org.apache.commons.collections.iterators.EnumerationIterator;
|
||||||
/**
|
/**
|
||||||
* A set of {@link Collection} related utility methods.
|
* A set of {@link Collection} related utility methods.
|
||||||
*
|
*
|
||||||
* @author Rodney Waldhoff
|
|
||||||
*
|
|
||||||
* @since 1.0
|
* @since 1.0
|
||||||
* @version $Id: CollectionUtils.java,v 1.13 2002/08/17 21:10:46 pjack Exp $
|
* @author Rodney Waldhoff
|
||||||
|
* @author Paul Jack
|
||||||
|
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
|
||||||
|
* @version $Id: CollectionUtils.java,v 1.14 2002/08/18 15:26:20 scolebourne Exp $
|
||||||
*/
|
*/
|
||||||
public class CollectionUtils {
|
public class CollectionUtils {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The empty iterator (immutable).
|
* The empty iterator (immutable).
|
||||||
|
* @deprecated use IteratorUtils.EMPTY_ITERATOR
|
||||||
*/
|
*/
|
||||||
public static final Iterator EMPTY_ITERATOR = new EmptyIterator();
|
public static final Iterator EMPTY_ITERATOR = IteratorUtils.EMPTY_ITERATOR;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 'Hidden' class which acts as an EmptyIterator.
|
* Please don't ever instantiate a <code>CollectionUtils</code>.
|
||||||
* An alternative is to use: Collections.EMPTY_LIST.iterator();
|
|
||||||
* however that will create a new iterator object each time.
|
|
||||||
*/
|
|
||||||
private static class EmptyIterator implements Iterator {
|
|
||||||
public boolean hasNext() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Object next() {
|
|
||||||
throw new NoSuchElementException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void remove() {
|
|
||||||
throw new UnsupportedOperationException();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Please don't ever instantiate a <Code>CollectionUtils</Code>.
|
|
||||||
*/
|
*/
|
||||||
public CollectionUtils() {
|
public CollectionUtils() {
|
||||||
}
|
}
|
||||||
|
@ -320,11 +304,13 @@ public class CollectionUtils {
|
||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Finds the first element in the given collection which matches the given predicate.
|
||||||
|
* <p>
|
||||||
/** Finds the first element in the given collection which matches the given predicate
|
* If the input collection or predicate is null, null is returned.
|
||||||
*
|
*
|
||||||
|
* @param collection the collection to search, may be null
|
||||||
|
* @param predicate the predicate to use, may be null
|
||||||
* @return the first element of the collection which matches the predicate or null if none could be found
|
* @return the first element of the collection which matches the predicate or null if none could be found
|
||||||
*/
|
*/
|
||||||
public static Object find(Collection collection, Predicate predicate) {
|
public static Object find(Collection collection, Predicate predicate) {
|
||||||
|
@ -339,7 +325,14 @@ public class CollectionUtils {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Executes the given closure on each element in the colleciton
|
/**
|
||||||
|
* Executes the given closure on each element in the collection.
|
||||||
|
* <p>
|
||||||
|
* If the input collection is null, there is no change made.
|
||||||
|
*
|
||||||
|
* @param collection the collection to get the input from, may be null
|
||||||
|
* @param closure the closure to perform, may not be null
|
||||||
|
* @throws NullPointerException if the closure is null
|
||||||
*/
|
*/
|
||||||
public static void forAllDo(Collection collection, Closure closure) {
|
public static void forAllDo(Collection collection, Closure closure) {
|
||||||
if (collection != null) {
|
if (collection != null) {
|
||||||
|
@ -350,8 +343,65 @@ public class CollectionUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Selects all elements from inputCollection which match the given predicate
|
/**
|
||||||
* into an output collection
|
* Filter the collection by applying a Predicate to each element. If the
|
||||||
|
* predicate returns false, remove the element.
|
||||||
|
* <p>
|
||||||
|
* If the input collection or predicate is null, there is no change made.
|
||||||
|
*
|
||||||
|
* @param collection the collection to get the input from, may be null
|
||||||
|
* @param predicate the predicate to use as a filter, may be null
|
||||||
|
*/
|
||||||
|
public static void filter(Collection collection, Predicate predicate) {
|
||||||
|
if (collection != null && predicate != null) {
|
||||||
|
for (Iterator iter = collection.iterator(); iter.hasNext();) {
|
||||||
|
Object element = iter.next();
|
||||||
|
if (predicate.evaluate(element) == false) {
|
||||||
|
iter.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Transform the collection by applying a Transformer to each element.
|
||||||
|
* <p>
|
||||||
|
* If the input collection or transformer is null, there is no change made.
|
||||||
|
* <p>
|
||||||
|
* This routine is best for Lists and uses set(), however it adapts for all
|
||||||
|
* Collections that support clear() and addAll().
|
||||||
|
* <p>
|
||||||
|
* If the input collection controls its input, such as a Set, and the
|
||||||
|
* Transformer creates duplicates (or are otherwise invalid), the
|
||||||
|
* collection may reduce in size due to calling this method.
|
||||||
|
*
|
||||||
|
* @param collection the collection to get the input from, may be null
|
||||||
|
* @param transformer the transformer to perform, may be null
|
||||||
|
*/
|
||||||
|
public static void transform(Collection collection, Transformer transformer) {
|
||||||
|
if (collection != null && transformer != null) {
|
||||||
|
if (collection instanceof List) {
|
||||||
|
List list = (List) collection;
|
||||||
|
for (ListIterator iter = list.listIterator(); iter.hasNext();) {
|
||||||
|
Object element = iter.next();
|
||||||
|
iter.set(transformer.transform(element));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
Collection resultCollection = collect(collection, transformer);
|
||||||
|
collection.clear();
|
||||||
|
collection.addAll(resultCollection);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Selects all elements from input collection which match the given predicate
|
||||||
|
* into an output collection.
|
||||||
|
*
|
||||||
|
* @param inputCollection the collection to get the input from, may not be null
|
||||||
|
* @param predicate the predicate to use, may be null
|
||||||
|
* @return the elements matching the predicate (new list)
|
||||||
|
* @throws NullPointerException if the input collection is null
|
||||||
*/
|
*/
|
||||||
public static Collection select(Collection inputCollection, Predicate predicate) {
|
public static Collection select(Collection inputCollection, Predicate predicate) {
|
||||||
ArrayList answer = new ArrayList(inputCollection.size());
|
ArrayList answer = new ArrayList(inputCollection.size());
|
||||||
|
@ -359,8 +409,18 @@ public class CollectionUtils {
|
||||||
return answer;
|
return answer;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Selects all elements from inputCollection which match the given predicate
|
/**
|
||||||
* and adds them to outputCollection
|
* Selects all elements from input collection which match the given predicate
|
||||||
|
* and adds them to outputCollection.
|
||||||
|
* <p>
|
||||||
|
* If the input collection or predicate is null, there is no change to the
|
||||||
|
* output collection.
|
||||||
|
*
|
||||||
|
* @param inputCollection the collection to get the input from, may be null
|
||||||
|
* @param predicate the predicate to use, may be null
|
||||||
|
* @param outputCollection the collection to output into, may not be null
|
||||||
|
* @return the outputCollection with the the elements matching the predicate added
|
||||||
|
* @throws NullPointerException if the input collection is null
|
||||||
*/
|
*/
|
||||||
public static void select(Collection inputCollection, Predicate predicate, Collection outputCollection) {
|
public static void select(Collection inputCollection, Predicate predicate, Collection outputCollection) {
|
||||||
if (inputCollection != null && predicate != null) {
|
if (inputCollection != null && predicate != null) {
|
||||||
|
@ -373,8 +433,16 @@ public class CollectionUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Transforms all elements from inputCollection with the given transformer
|
/**
|
||||||
* and adds them to the outputCollection
|
* Transforms all elements from inputCollection with the given transformer
|
||||||
|
* and adds them to the outputCollection.
|
||||||
|
* <p>
|
||||||
|
* If the input transfomer is null, the result is an empty list.
|
||||||
|
*
|
||||||
|
* @param inputCollection the collection to get the input from, may not be null
|
||||||
|
* @param transformer the transformer to use, may be null
|
||||||
|
* @return the transformed result (new list)
|
||||||
|
* @throws NullPointerException if the input collection is null
|
||||||
*/
|
*/
|
||||||
public static Collection collect(Collection inputCollection, Transformer transformer) {
|
public static Collection collect(Collection inputCollection, Transformer transformer) {
|
||||||
ArrayList answer = new ArrayList(inputCollection.size());
|
ArrayList answer = new ArrayList(inputCollection.size());
|
||||||
|
@ -382,8 +450,15 @@ public class CollectionUtils {
|
||||||
return answer;
|
return answer;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Transforms all elements from the inputIterator with the given transformer
|
/**
|
||||||
* and adds them to the outputCollection
|
* Transforms all elements from the inputIterator with the given transformer
|
||||||
|
* and adds them to the outputCollection.
|
||||||
|
* <p>
|
||||||
|
* If the input iterator or transfomer is null, the result is an empty list.
|
||||||
|
*
|
||||||
|
* @param inputIterator the iterator to get the input from, may be null
|
||||||
|
* @param transformer the transformer to use, may be null
|
||||||
|
* @return the transformed result (new list)
|
||||||
*/
|
*/
|
||||||
public static Collection collect(Iterator inputIterator, Transformer transformer) {
|
public static Collection collect(Iterator inputIterator, Transformer transformer) {
|
||||||
ArrayList answer = new ArrayList();
|
ArrayList answer = new ArrayList();
|
||||||
|
@ -391,10 +466,18 @@ public class CollectionUtils {
|
||||||
return answer;
|
return answer;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Transforms all elements from inputCollection with the given transformer
|
/**
|
||||||
* and adds them to the outputCollection
|
* Transforms all elements from inputCollection with the given transformer
|
||||||
|
* and adds them to the outputCollection.
|
||||||
|
* <p>
|
||||||
|
* If the input collection or transfomer is null, there is no change to the
|
||||||
|
* output collection.
|
||||||
*
|
*
|
||||||
* @return the outputCollection
|
* @param inputCollection the collection to get the input from, may be null
|
||||||
|
* @param transformer the transformer to use, may be null
|
||||||
|
* @param outputCollection the collection to output into, may not be null
|
||||||
|
* @return the outputCollection with the transformed input added
|
||||||
|
* @throws NullPointerException if the output collection is null
|
||||||
*/
|
*/
|
||||||
public static Collection collect(Collection inputCollection, final Transformer transformer, final Collection outputCollection) {
|
public static Collection collect(Collection inputCollection, final Transformer transformer, final Collection outputCollection) {
|
||||||
if (inputCollection != null) {
|
if (inputCollection != null) {
|
||||||
|
@ -403,10 +486,18 @@ public class CollectionUtils {
|
||||||
return outputCollection;
|
return outputCollection;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Transforms all elements from the inputIterator with the given transformer
|
/**
|
||||||
* and adds them to the outputCollection
|
* Transforms all elements from the inputIterator with the given transformer
|
||||||
|
* and adds them to the outputCollection.
|
||||||
|
* <p>
|
||||||
|
* If the input iterator or transfomer is null, there is no change to the
|
||||||
|
* output collection.
|
||||||
*
|
*
|
||||||
* @return the outputCollection
|
* @param inputIterator the iterator to get the input from, may be null
|
||||||
|
* @param transformer the transformer to use, may be null
|
||||||
|
* @param outputCollection the collection to output into, may not be null
|
||||||
|
* @return the outputCollection with the transformed input added
|
||||||
|
* @throws NullPointerException if the output collection is null
|
||||||
*/
|
*/
|
||||||
public static Collection collect(Iterator inputIterator, final Transformer transformer, final Collection outputCollection) {
|
public static Collection collect(Iterator inputIterator, final Transformer transformer, final Collection outputCollection) {
|
||||||
if (inputIterator != null && transformer != null) {
|
if (inputIterator != null && transformer != null) {
|
||||||
|
@ -419,7 +510,12 @@ public class CollectionUtils {
|
||||||
return outputCollection;
|
return outputCollection;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Adds all elements in the iteration to the given collection
|
/**
|
||||||
|
* Adds all elements in the iteration to the given collection.
|
||||||
|
*
|
||||||
|
* @param collection the collection to add to
|
||||||
|
* @param iterator the iterator of elements to add, may not be null
|
||||||
|
* @throws NullPointerException if the collection or iterator is null
|
||||||
*/
|
*/
|
||||||
public static void addAll(Collection collection, Iterator iterator) {
|
public static void addAll(Collection collection, Iterator iterator) {
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
|
@ -427,7 +523,12 @@ public class CollectionUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Adds all elements in the enumeration to the given collection
|
/**
|
||||||
|
* Adds all elements in the enumeration to the given collection.
|
||||||
|
*
|
||||||
|
* @param collection the collection to add to
|
||||||
|
* @param enumeration the enumeration of elements to add, may not be null
|
||||||
|
* @throws NullPointerException if the collection or enumeration is null
|
||||||
*/
|
*/
|
||||||
public static void addAll(Collection collection, Enumeration enumeration) {
|
public static void addAll(Collection collection, Enumeration enumeration) {
|
||||||
while (enumeration.hasMoreElements()) {
|
while (enumeration.hasMoreElements()) {
|
||||||
|
@ -435,7 +536,12 @@ public class CollectionUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Adds all elements in the array to the given collection
|
/**
|
||||||
|
* Adds all elements in the array to the given collection.
|
||||||
|
*
|
||||||
|
* @param collection the collection to add to
|
||||||
|
* @param elements the array of elements to add, may be null
|
||||||
|
* @throws NullPointerException if the collection or array is null
|
||||||
*/
|
*/
|
||||||
public static void addAll(Collection collection, Object[] elements) {
|
public static void addAll(Collection collection, Object[] elements) {
|
||||||
for (int i = 0, size = elements.length; i < size; i++) {
|
for (int i = 0, size = elements.length; i < size; i++) {
|
||||||
|
@ -446,14 +552,39 @@ public class CollectionUtils {
|
||||||
/**
|
/**
|
||||||
* Given an Object, and an index, it will get the nth value in the
|
* Given an Object, and an index, it will get the nth value in the
|
||||||
* object.
|
* object.
|
||||||
|
* <ul>
|
||||||
|
* <li>If obj is a Map, get the nth value from the <b>key</b> iterator.
|
||||||
|
* <li>If obj is a List or an array, get the nth value.
|
||||||
|
* <li>If obj is an iterator, enumeration or Collection, get the nth value from the iterator.
|
||||||
|
* <li>Return the original obj.
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @param obj the object to get an index of
|
||||||
|
* @param index the index to get
|
||||||
|
* @throws IndexOutOfBoundsException
|
||||||
|
* @throws NoSuchElementException
|
||||||
*/
|
*/
|
||||||
public static Object index(Object obj, int idx) {
|
public static Object index(Object obj, int idx) {
|
||||||
return index(obj, new Integer(idx));
|
return index(obj, new Integer(idx));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Given an Object, and an index, it will get the nth value in the
|
* Given an Object, and a key (index), it will get value associated with
|
||||||
* object.
|
* that key in the Object. The following checks are made:
|
||||||
|
* <ul>
|
||||||
|
* <li>If obj is a Map, use the index as a key to get a value. If no match continue.
|
||||||
|
* <li>Check key is an Integer. If not, return the object passed in.
|
||||||
|
* <li>If obj is a Map, get the nth value from the <b>key</b> iterator.
|
||||||
|
* <li>If obj is a List or an array, get the nth value.
|
||||||
|
* <li>If obj is an iterator, enumeration or Collection, get the nth value from the iterator.
|
||||||
|
* <li>Return the original obj.
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @param obj the object to get an index of
|
||||||
|
* @param index the index to get
|
||||||
|
* @return the object at the specified index
|
||||||
|
* @throws IndexOutOfBoundsException
|
||||||
|
* @throws NoSuchElementException
|
||||||
*/
|
*/
|
||||||
public static Object index(Object obj, Object index) {
|
public static Object index(Object obj, Object index) {
|
||||||
if(obj instanceof Map) {
|
if(obj instanceof Map) {
|
||||||
|
|
Loading…
Reference in New Issue