aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/util/Collections.java
diff options
context:
space:
mode:
Diffstat (limited to 'libjava/java/util/Collections.java')
-rw-r--r--libjava/java/util/Collections.java63
1 files changed, 30 insertions, 33 deletions
diff --git a/libjava/java/util/Collections.java b/libjava/java/util/Collections.java
index a827071..af90b45 100644
--- a/libjava/java/util/Collections.java
+++ b/libjava/java/util/Collections.java
@@ -43,7 +43,6 @@ import java.io.Serializable;
*/
public class Collections
{
-
/**
* This class is non-instantiable.
*/
@@ -58,7 +57,6 @@ public class Collections
*/
public static final Set EMPTY_SET = new AbstractSet()
{
-
public int size()
{
return 0;
@@ -97,7 +95,6 @@ public class Collections
*/
public static final List EMPTY_LIST = new AbstractList()
{
-
public int size()
{
return 0;
@@ -116,7 +113,6 @@ public class Collections
*/
public static final Map EMPTY_MAP = new AbstractMap()
{
-
public Set entrySet()
{
return EMPTY_SET;
@@ -147,7 +143,6 @@ public class Collections
*/
private static int search(List l, Object key, final Comparator c)
{
-
int pos = 0;
// We use a linear search using an iterator if we can guess that the list
@@ -437,7 +432,6 @@ public class Collections
// stated - I just would be amazed if it isn't...
public static List nCopies(final int n, final Object o)
{
-
// Check for insane arguments
if (n < 0)
{
@@ -552,7 +546,6 @@ public class Collections
// Iterate backwards over l
while (i.hasPrevious())
{
-
// Obtain a random position to swap with. nextIndex is used so that the
// range of the random number includes the current position.
int swap = r.nextInt(i.nextIndex());
@@ -579,10 +572,8 @@ public class Collections
// It's not serializable because the spec is broken.
public static Set singleton(final Object o)
{
-
return new AbstractSet()
{
-
public int size()
{
return 1;
@@ -592,7 +583,6 @@ public class Collections
{
return new Iterator()
{
-
private boolean hasNext = true;
public boolean hasNext()
@@ -632,10 +622,8 @@ public class Collections
// It's not serializable because the spec is broken.
public static List singletonList(final Object o)
{
-
return new AbstractList()
{
-
public int size()
{
return 1;
@@ -666,7 +654,6 @@ public class Collections
// It's not serializable because the spec is broken.
public static Map singletonMap(final Object key, final Object value)
{
-
return new AbstractMap()
{
public Set entrySet()
@@ -811,7 +798,6 @@ public class Collections
private static class UnmodifiableListIterator extends UnmodifiableIterator
implements ListIterator
{
-
// This is stored both here and in the superclass, to avoid excessive
// casting.
private ListIterator li;
@@ -910,12 +896,15 @@ public class Collections
{
return c.toArray(a);
}
+ public String toString()
+ {
+ return c.toString();
+ }
}
private static class UnmodifiableList extends UnmodifiableCollection
implements List
{
-
// This is stored both here and in the superclass, to avoid excessive
// casting.
List l;
@@ -928,11 +917,11 @@ public class Collections
public void add(int index, Object o)
{
- l.add(index, o);
+ throw new UnsupportedOperationException();
}
public boolean addAll(int index, Collection c)
{
- return l.addAll(index, c);
+ throw new UnsupportedOperationException();
}
public boolean equals(Object o)
{
@@ -964,15 +953,11 @@ public class Collections
}
public Object remove(int index)
{
- return l.remove(index);
- }
- public boolean remove(Object o)
- {
- return l.remove(o);
+ throw new UnsupportedOperationException();
}
public Object set(int index, Object o)
{
- return l.set(index, o);
+ throw new UnsupportedOperationException();
}
public List subList(int fromIndex, int toIndex)
{
@@ -1000,7 +985,6 @@ public class Collections
private static class UnmodifiableSortedSet extends UnmodifiableSet
implements SortedSet
{
-
// This is stored both here and in the superclass, to avoid excessive
// casting.
private SortedSet ss;
@@ -1039,7 +1023,6 @@ public class Collections
private static class UnmodifiableMap implements Map, Serializable
{
-
Map m;
public UnmodifiableMap(Map m)
@@ -1143,12 +1126,15 @@ public class Collections
{
return new UnmodifiableCollection(m.values());
}
+ public String toString()
+ {
+ return m.toString();
+ }
}
private static class UnmodifiableSortedMap extends UnmodifiableMap
implements SortedMap
{
-
// This is stored both here and in the superclass, to avoid excessive
// casting.
private SortedMap sm;
@@ -1226,7 +1212,6 @@ public class Collections
private static class SynchronizedListIterator extends SynchronizedIterator
implements ListIterator
{
-
// This is stored both here and in the superclass, to avoid excessive
// casting.
private ListIterator li;
@@ -1389,12 +1374,18 @@ public class Collections
return c.toArray(a);
}
}
+ public String toString()
+ {
+ synchronized(sync)
+ {
+ return c.toString();
+ }
+ }
}
private static class SynchronizedList extends SynchronizedCollection
implements List
{
-
// This is stored both here and in the superclass, to avoid excessive
// casting.
List l;
@@ -1407,6 +1398,7 @@ public class Collections
public SynchronizedList(List l)
{
super(l);
+ this.l = l;
}
public void add(int index, Object o)
@@ -1505,7 +1497,6 @@ public class Collections
private static class SynchronizedSet extends SynchronizedCollection
implements Set
{
-
public SynchronizedSet(Object sync, Set s)
{
super(sync, s);
@@ -1534,7 +1525,6 @@ public class Collections
private static class SynchronizedSortedSet extends SynchronizedSet
implements SortedSet
{
-
// This is stored both here and in the superclass, to avoid excessive
// casting.
private SortedSet ss;
@@ -1547,6 +1537,7 @@ public class Collections
public SynchronizedSortedSet(SortedSet ss)
{
super(ss);
+ this.ss = ss;
}
public Comparator comparator()
@@ -1596,7 +1587,6 @@ public class Collections
private static class SynchronizedMap implements Map, Serializable
{
-
Object sync;
Map m;
@@ -1634,7 +1624,7 @@ public class Collections
}
// This is one of the ickiest cases of nesting I've ever seen. It just
- // means "return an SynchronizedSet, except that the iterator() method
+ // means "return a SynchronizedSet, except that the iterator() method
// returns an SynchronizedIterator whos next() method returns a
// synchronized wrapper around its normal return value".
public Set entrySet()
@@ -1772,12 +1762,18 @@ public class Collections
return new SynchronizedCollection(sync, m.values());
}
}
+ public String toString()
+ {
+ synchronized(sync)
+ {
+ return m.toString();
+ }
+ }
}
private static class SynchronizedSortedMap extends SynchronizedMap
implements SortedMap
{
-
// This is stored both here and in the superclass, to avoid excessive
// casting.
private SortedMap sm;
@@ -1790,6 +1786,7 @@ public class Collections
public SynchronizedSortedMap(SortedMap sm)
{
super(sm);
+ this.sm = sm;
}
public Comparator comparator()