2007-07-21 21:47:29 -06:00
|
|
|
package java.util;
|
|
|
|
|
|
|
|
public class Collections {
|
|
|
|
private Collections() { }
|
|
|
|
|
2007-10-16 19:17:37 -06:00
|
|
|
static String toString(Collection c) {
|
2007-08-23 19:57:42 -06:00
|
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.append("[");
|
2007-10-16 19:17:37 -06:00
|
|
|
for (Iterator it = c.iterator(); it.hasNext();) {
|
2007-08-23 19:57:42 -06:00
|
|
|
sb.append(it.next());
|
|
|
|
if (it.hasNext()) {
|
|
|
|
sb.append(",");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
sb.append("]");
|
|
|
|
return sb.toString();
|
|
|
|
}
|
|
|
|
|
2007-07-21 21:47:29 -06:00
|
|
|
static class IteratorEnumeration<T> implements Enumeration<T> {
|
|
|
|
private final Iterator<T> it;
|
|
|
|
|
|
|
|
public IteratorEnumeration(Iterator<T> it) {
|
|
|
|
this.it = it;
|
|
|
|
}
|
|
|
|
|
|
|
|
public T nextElement() {
|
|
|
|
return it.next();
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean hasMoreElements() {
|
|
|
|
return it.hasNext();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static class SynchronizedCollection<T> implements Collection<T> {
|
2007-09-26 09:19:21 -06:00
|
|
|
protected final Object lock;
|
|
|
|
protected final Collection<T> collection;
|
2007-07-21 21:47:29 -06:00
|
|
|
|
|
|
|
public SynchronizedCollection(Object lock, Collection<T> collection) {
|
|
|
|
this.lock = lock;
|
|
|
|
this.collection = collection;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized int size() {
|
|
|
|
synchronized (lock) { return collection.size(); }
|
|
|
|
}
|
|
|
|
|
2007-11-07 09:48:09 -07:00
|
|
|
public boolean isEmpty() {
|
|
|
|
return size() == 0;
|
|
|
|
}
|
|
|
|
|
2007-07-22 13:06:21 -06:00
|
|
|
public synchronized boolean contains(T e) {
|
|
|
|
synchronized (lock) { return collection.contains(e); }
|
|
|
|
}
|
|
|
|
|
2007-07-21 21:47:29 -06:00
|
|
|
public synchronized boolean add(T e) {
|
|
|
|
synchronized (lock) { return collection.add(e); }
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean remove(T e) {
|
|
|
|
synchronized (lock) { return collection.remove(e); }
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void clear() {
|
|
|
|
synchronized (lock) { collection.clear(); }
|
|
|
|
}
|
|
|
|
|
|
|
|
public Iterator<T> iterator() {
|
|
|
|
return new SynchronizedIterator(lock, collection.iterator());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static class SynchronizedSet<T>
|
|
|
|
extends SynchronizedCollection<T>
|
|
|
|
implements Set<T>
|
|
|
|
{
|
|
|
|
public SynchronizedSet(Object lock, Set<T> set) {
|
|
|
|
super(lock, set);
|
|
|
|
}
|
2007-09-26 09:19:21 -06:00
|
|
|
|
|
|
|
public void addAll(Collection<T> c) {
|
|
|
|
synchronized (lock) { ((Set<T>)collection).addAll(c); }
|
|
|
|
}
|
2007-07-21 21:47:29 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
static class SynchronizedIterator<T> implements Iterator<T> {
|
|
|
|
private final Object lock;
|
|
|
|
private final Iterator<T> it;
|
|
|
|
|
|
|
|
public SynchronizedIterator(Object lock, Iterator<T> it) {
|
|
|
|
this.lock = lock;
|
|
|
|
this.it = it;
|
|
|
|
}
|
|
|
|
|
|
|
|
public T next() {
|
|
|
|
synchronized (lock) { return it.next(); }
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean hasNext() {
|
|
|
|
synchronized (lock) { return it.hasNext(); }
|
|
|
|
}
|
|
|
|
|
|
|
|
public void remove() {
|
|
|
|
synchronized (lock) { it.remove(); }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-09-26 09:48:59 -06:00
|
|
|
static class ArrayListIterator<T> implements ListIterator<T> {
|
2007-07-21 21:47:29 -06:00
|
|
|
private final List<T> list;
|
|
|
|
private boolean canRemove = false;
|
2007-09-26 09:48:59 -06:00
|
|
|
private int index;
|
2007-07-21 21:47:29 -06:00
|
|
|
|
|
|
|
public ArrayListIterator(List<T> list) {
|
2007-09-26 09:48:59 -06:00
|
|
|
this(list, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
public ArrayListIterator(List<T> list, int index) {
|
2007-07-21 21:47:29 -06:00
|
|
|
this.list = list;
|
2007-09-26 09:48:59 -06:00
|
|
|
this.index = index - 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean hasPrevious() {
|
|
|
|
return index >= 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public T previous() {
|
|
|
|
if (hasPrevious()) {
|
|
|
|
canRemove = true;
|
|
|
|
return list.get(index--);
|
|
|
|
} else {
|
|
|
|
throw new NoSuchElementException();
|
|
|
|
}
|
2007-07-21 21:47:29 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
public T next() {
|
|
|
|
if (hasNext()) {
|
|
|
|
canRemove = true;
|
|
|
|
return list.get(++index);
|
|
|
|
} else {
|
|
|
|
throw new NoSuchElementException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean hasNext() {
|
|
|
|
return index + 1 < list.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
public void remove() {
|
|
|
|
if (canRemove) {
|
|
|
|
canRemove = false;
|
|
|
|
list.remove(index--);
|
|
|
|
} else {
|
|
|
|
throw new IllegalStateException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|