git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/collections/trunk@131716 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Stephen Colebourne 2004-05-15 11:59:15 +00:00
parent 5ca563790b
commit bad1d79b7a
1 changed files with 27 additions and 7 deletions

View File

@ -67,7 +67,7 @@ import org.apache.commons.collections.keyvalue.UnmodifiableMapEntry;
* UnsupportedOperationException on attempts to call that method. * UnsupportedOperationException on attempts to call that method.
* *
* @since Commons Collections 3.0 (previously DoubleOrderedMap v2.0) * @since Commons Collections 3.0 (previously DoubleOrderedMap v2.0)
* @version $Revision: 1.12 $ $Date: 2004/02/18 00:57:39 $ * @version $Revision: 1.13 $ $Date: 2004/05/15 11:59:15 $
* *
* @author Marc Johnson * @author Marc Johnson
* @author Stephen Colebourne * @author Stephen Colebourne
@ -505,8 +505,8 @@ public class TreeBidiMap implements OrderedBidiMap {
// store previous and remove previous mappings // store previous and remove previous mappings
Object prev = (index == KEY ? doGet(key, KEY) : doGet(value, VALUE)); Object prev = (index == KEY ? doGet(key, KEY) : doGet(value, VALUE));
doRemove((Comparable) key, KEY); doRemove(key, KEY);
doRemove((Comparable) value, VALUE); doRemove(value, VALUE);
Node node = rootNode[KEY]; Node node = rootNode[KEY];
if (node == null) { if (node == null) {
@ -1464,8 +1464,11 @@ public class TreeBidiMap implements OrderedBidiMap {
*/ */
static class View extends AbstractSet { static class View extends AbstractSet {
/** The parent map. */
protected final TreeBidiMap main; protected final TreeBidiMap main;
/** Whether to return KEY or VALUE order. */
protected final int orderType; protected final int orderType;
/** Whether to return KEY, VALUE, MAPENTRY or INVERSEMAPENTRY data. */
protected final int dataType; protected final int dataType;
/** /**
@ -1510,12 +1513,19 @@ public class TreeBidiMap implements OrderedBidiMap {
*/ */
static class ViewIterator implements OrderedIterator { static class ViewIterator implements OrderedIterator {
/** The parent map. */
protected final TreeBidiMap main; protected final TreeBidiMap main;
/** Whether to return KEY or VALUE order. */
protected final int orderType; protected final int orderType;
/** Whether to return KEY, VALUE, MAPENTRY or INVERSEMAPENTRY data. */
protected final int dataType; protected final int dataType;
/** The last node returned by the iterator. */
protected Node lastReturnedNode; protected Node lastReturnedNode;
/** The next node to be returned by the iterator. */
protected Node nextNode; protected Node nextNode;
/** The previous node in the sequence returned by the iterator. */
protected Node previousNode; protected Node previousNode;
/** The modification count. */
private int expectedModifications; private int expectedModifications;
/** /**
@ -1573,6 +1583,10 @@ public class TreeBidiMap implements OrderedBidiMap {
return doGetData(); return doGetData();
} }
/**
* Gets the data value for the lastReturnedNode field.
* @return the data value
*/
protected Object doGetData() { protected Object doGetData() {
switch (dataType) { switch (dataType) {
case KEY: case KEY:
@ -1887,10 +1901,8 @@ public class TreeBidiMap implements OrderedBidiMap {
* Returns true if the given object is also a map entry and * Returns true if the given object is also a map entry and
* the two entries represent the same mapping. * the two entries represent the same mapping.
* *
* @param o object to be compared for equality with this map * @param obj the object to be compared for equality with this entry.
* entry. * @return true if the specified object is equal to this entry.
* @return true if the specified object is equal to this map
* entry.
*/ */
public boolean equals(final Object obj) { public boolean equals(final Object obj) {
if (obj == this) { if (obj == this) {
@ -1921,11 +1933,19 @@ public class TreeBidiMap implements OrderedBidiMap {
*/ */
static class Inverse implements OrderedBidiMap { static class Inverse implements OrderedBidiMap {
/** The parent map. */
private final TreeBidiMap main; private final TreeBidiMap main;
/** Store the keySet once created. */
private Set keySet; private Set keySet;
/** Store the valuesSet once created. */
private Set valuesSet; private Set valuesSet;
/** Store the entrySet once created. */
private Set entrySet; private Set entrySet;
/**
* Constructor.
* @param main the main map
*/
Inverse(final TreeBidiMap main) { Inverse(final TreeBidiMap main) {
super(); super();
this.main = main; this.main = main;