2001-05-16 18:32:04 -04:00
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<title>Status File for Jakarta Commons "Collections" Package</title>
|
|
|
|
<head>
|
|
|
|
<body bgcolor="white">
|
|
|
|
|
|
|
|
|
|
|
|
<div align="center">
|
|
|
|
<h1>The Jakarta Commons <em>Collections</em> Package</h1>
|
2002-02-26 16:34:03 -05:00
|
|
|
$Id: STATUS.html,v 1.11 2002/02/26 21:34:03 morgand Exp $<br>
|
2001-05-16 18:32:04 -04:00
|
|
|
<a href="#Introduction">[Introduction]</a>
|
|
|
|
<a href="#Dependencies">[Dependencies]</a>
|
|
|
|
<a href="#Release Info">[Release Info]</a>
|
|
|
|
<a href="#Committers">[Committers]</a>
|
|
|
|
<a href="#Action Items">[Action Items]</a>
|
|
|
|
<br><br>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<a name="Introduction"></a>
|
|
|
|
<h3>1. INTRODUCTION</h3>
|
|
|
|
|
|
|
|
<p>The <em>Collections</em> package contains a set of Java classes that
|
|
|
|
extend or augment the Java Collections Framework.
|
|
|
|
The following classes are included:</p>
|
|
|
|
<ul>
|
|
|
|
<li><strong>ArrayEnumeration</strong> - a java.util.Enumeration wrapper for arrays.</li>
|
|
|
|
<li><strong>ArrayIterator</strong> - a java.util.Iterator wrapper for arrays.</li>
|
|
|
|
<li><strong>ArrayStack</strong> - An implementation of the java.util.Stack API
|
|
|
|
that is based on an ArrayList instead of a Vector, so it is not synchronized to
|
|
|
|
protect against multi-threaded access.</li>
|
2002-02-26 16:34:03 -05:00
|
|
|
<li><strong>Bag</strong> - A Collection that keeps a count of its members of the same
|
|
|
|
type, using <code>hashCode</code> to check for equality. Suppose
|
|
|
|
you have a Bag that contains <code>{a, a, b, c}</code>. Calling
|
|
|
|
getCount on <code>a</code> would return 2, while calling
|
|
|
|
uniqueSet would return <code>{a, b, c}</code>. <i>Note: this is an
|
|
|
|
interface with several implementations.</i></li>
|
2001-05-16 18:32:04 -04:00
|
|
|
<li><strong>BeanMap</strong> - An implementation of the java.util.Map API
|
|
|
|
that is based on a JavaBean using introspection. The property names are the
|
|
|
|
keys of the map and the property values are the values of the map.</li>
|
|
|
|
<li><strong>CollectionUtils</strong> - a variety of helper methods
|
|
|
|
for working with collections.</li>
|
|
|
|
<li><strong>CursorableLinkedList</strong> - an implementation of the java.util.List
|
|
|
|
interface supporting a java.util.ListIterator that allows concurrent
|
|
|
|
modifications to the underlying list.</li>
|
2002-02-26 16:34:03 -05:00
|
|
|
<li><strong>DoubleOrderedMap</strong> - Red-Black tree-based implementation of Map.
|
|
|
|
This class guarantees
|
|
|
|
that the map will be in both ascending key order and ascending
|
|
|
|
value order, sorted according to the natural order for the key's
|
|
|
|
and value's classes.</li>
|
2001-05-16 18:32:04 -04:00
|
|
|
<li><strong>ExtendedProperties</strong> - extends normal Java properties by adding
|
|
|
|
the possibility to use the same key many times, concatenating the value strings
|
|
|
|
instead of overwriting them.</li>
|
|
|
|
<li><strong>FastArrayList</strong> - a custom implementation of java.util.ArrayList
|
|
|
|
designed to operate in a multithreaded environment where the large majority of
|
|
|
|
method calls are read-only, instead of structural changes.</li>
|
|
|
|
<li><strong>FastHashMap</strong> - a custom implementation of java.util.HashMap
|
|
|
|
designed to operate in a multithreaded environment where the large majority of
|
|
|
|
method calls are read-only, instead of structural changes.</li>
|
|
|
|
<li><strong>FastTreeMap</strong> - a custom implementation of java.util.TreeMap
|
|
|
|
designed to operate in a multithreaded environment where the large majority of
|
|
|
|
method calls are read-only, instead of structural changes.</li>
|
2002-02-26 16:34:03 -05:00
|
|
|
<li><strong>FilterIterator</strong> - A Proxy <code>Iterator</code> which takes a
|
|
|
|
<code>Predicate</code>
|
|
|
|
instance to filter out objects from an underlying <code>Iterator</code> instance.
|
|
|
|
Only objects for which the
|
|
|
|
specified <code>Predicate</code> evaluates to <code>true</code> are
|
|
|
|
returned.</li>
|
|
|
|
<li><strong>FilterListIterator</strong> - A proxy <code>ListIterator</code> which
|
|
|
|
takes a <code>Predicate</code> instance to filter
|
|
|
|
out objects from an underlying <code>ListIterator</code>
|
|
|
|
instance. Only objects for which the specified
|
|
|
|
<code>Predicate</code> evaluates to <code>true</code> are
|
|
|
|
returned by the iterator.</li>
|
|
|
|
<li><strong>HashBag</strong> - An implementation of <strong>Bag</strong> that is backed by a
|
|
|
|
HashMap.</li>
|
2001-05-16 18:32:04 -04:00
|
|
|
<li><strong>ListUtils</strong> - miscelaneous utilities to manipulate Lists.</li>
|
2002-02-26 16:34:03 -05:00
|
|
|
<li><strong>MultiMap</strong> - This is simply a Map with slightly different semantics.
|
|
|
|
Instead of returning an Object, it returns a Collection.
|
|
|
|
So for example, you can put( key, new Integer(1) );
|
|
|
|
and then a Object get( key ); will return you a Collection
|
|
|
|
instead of an Integer. This is an interface implemented
|
|
|
|
by <strong>MultiHashMap</strong>.</li>
|
2001-05-16 18:32:04 -04:00
|
|
|
<li><strong>PriorityQueue</strong> - a PriorityQueue interface, with
|
|
|
|
<strong>BinaryHeap</strong> and <strong>SynchronizedPriorityQueue</strong>
|
|
|
|
implementations.</li>
|
2002-02-26 16:34:03 -05:00
|
|
|
<li><strong>SequencedHashMap</strong> - A map of objects whose mapping entries are
|
|
|
|
sequenced based on the order in
|
|
|
|
which they were added.</li>
|
|
|
|
<li><strong>SingletonIterator</strong> - An Iterator over a single
|
|
|
|
object instance.</li>
|
|
|
|
<li><strong>SortedBag</strong> - A type of <strong>Bag</strong> that maintains order among its unique
|
|
|
|
representative members</li>
|
|
|
|
<li><strong>TreeBag</strong> - An implementation of <strong>Bag</strong> that is backed by a
|
|
|
|
TreeMap. Order will be maintained among the unique representative
|
|
|
|
members.</li>
|
2001-05-16 18:32:04 -04:00
|
|
|
</ul>
|
|
|
|
|
|
|
|
<a name="Dependencies"></a>
|
|
|
|
<h3>2. DEPENDENCIES</h3>
|
|
|
|
|
|
|
|
<p>The <em>Collections</em> package is dependent upon the following external
|
|
|
|
components for development and use:</p>
|
|
|
|
<ul>
|
|
|
|
<li><a href="http://java.sun.com/j2se">Java Development Kit</a>
|
|
|
|
(Version 1.2 or later)</li>
|
|
|
|
<li><a href="http://www.junit.org">JUnit Testing Framework</a>
|
2001-07-14 19:43:11 -04:00
|
|
|
(Version 3.7 or later) - for unit tests only, not required
|
2001-05-16 18:32:04 -04:00
|
|
|
for deployment</li>
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
|
|
|
|
<a name="Release Info"></a>
|
|
|
|
<h3>3. RELEASE INFO</h3>
|
|
|
|
|
2001-07-14 19:43:11 -04:00
|
|
|
<p>Current Release:
|
|
|
|
<a href="http://jakarta.apache.org/builds/jakarta-commons/release/commons-collections/v1.0">Version 1.0</a>
|
2001-05-16 18:32:04 -04:00
|
|
|
|
|
|
|
<p>Planned Next Release: TBD</p>
|
|
|
|
|
|
|
|
<a name="Committers"></a>
|
|
|
|
<h3>4. COMMITTERS</h3>
|
|
|
|
|
|
|
|
<p>The following individuals are the primary developers and maintainers of this
|
|
|
|
component. Developers who plan to use <em>Collections</em> in their own
|
|
|
|
projects are encouraged to collaborate on the future development of this
|
|
|
|
component to ensure that it continues to meet a variety of needs.</p>
|
|
|
|
<ul>
|
2002-02-20 21:01:21 -05:00
|
|
|
<li><a href="mailto:mas@apache.org">Michael A. Smith</a></li>
|
2002-02-13 15:21:05 -05:00
|
|
|
<li><a href="mailto:morgand@apache.org">Morgan Delagrange</a></li>
|
2001-05-16 18:32:04 -04:00
|
|
|
<li><a href="mailto:donaldp@apache.org">Peter Donald</a></li>
|
|
|
|
<li><a href="mailto:geirm@apache.org">Geir Magnusson Jr.</a></li>
|
|
|
|
<li><a href="mailto:craigmcc@apache.org">Craig McClanahan</a></li>
|
|
|
|
<li><a href="mailto:jstrachan@apache.org">James Strachan</a></li>
|
|
|
|
<li><a href="mailto:rwaldhoff@apache.org">Rodney Waldhoff</a></li>
|
|
|
|
<li><a href="mailto:jvanzyl@apache.org">Jason van Zyl</a></li>
|
2002-02-21 12:38:28 -05:00
|
|
|
<li><a href="mailto:bayard@apache.org">Henri Yandell</a></li>
|
2001-05-16 18:32:04 -04:00
|
|
|
</ul>
|
|
|
|
|
|
|
|
<a name="Action Items"></a>
|
|
|
|
<h3>5. ACTION ITEMS</h3>
|
|
|
|
|
|
|
|
<p>Want to help? Here's some "to do" items the team has identified.</p>
|
|
|
|
|
|
|
|
<table border="1">
|
|
|
|
<tr>
|
|
|
|
<th width="80%">Action Item</th>
|
|
|
|
<th width="20%">Volunteer</th>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><strong>Additional Contributions</strong>. Other collection
|
|
|
|
or collection-related classes.</td>
|
|
|
|
<td align="center"> </td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><strong>Generalized Unit Tests</strong>. Create a generic
|
|
|
|
set of Unit Tests that test the standard contracts of the basic
|
|
|
|
Java Collections interfaces (List, Set, Map, etc.)</td>
|
|
|
|
<td align="center"> </td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><strong>Additional Documentation</strong>. Create simple
|
|
|
|
User's Guide, examples, or other documentation for this package.</td>
|
|
|
|
<td align="center"> </td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
|
|
|
</body>
|
2001-07-14 19:43:11 -04:00
|
|
|
</html>
|