corda/classpath/java/util/Collections.java

155 lines
3.4 KiB
Java
Raw Normal View History

2007-07-22 03:47:29 +00:00
package java.util;
public class Collections {
private Collections() { }
2007-10-17 01:17:37 +00:00
static String toString(Collection c) {
2007-08-24 01:57:42 +00:00
StringBuilder sb = new StringBuilder();
sb.append("[");
2007-10-17 01:17:37 +00:00
for (Iterator it = c.iterator(); it.hasNext();) {
2007-08-24 01:57:42 +00:00
sb.append(it.next());
if (it.hasNext()) {
sb.append(",");
}
}
sb.append("]");
return sb.toString();
}
2007-07-22 03:47:29 +00: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 15:19:21 +00:00
protected final Object lock;
protected final Collection<T> collection;
2007-07-22 03:47:29 +00:00
public SynchronizedCollection(Object lock, Collection<T> collection) {
this.lock = lock;
this.collection = collection;
}
public synchronized int size() {
synchronized (lock) { return collection.size(); }
}
2007-07-22 19:06:21 +00:00
public synchronized boolean contains(T e) {
synchronized (lock) { return collection.contains(e); }
}
2007-07-22 03:47:29 +00: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 15:19:21 +00:00
public void addAll(Collection<T> c) {
synchronized (lock) { ((Set<T>)collection).addAll(c); }
}
2007-07-22 03:47:29 +00: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(); }
}
}
static class ArrayListIterator<T> implements ListIterator<T> {
2007-07-22 03:47:29 +00:00
private final List<T> list;
private boolean canRemove = false;
private int index;
2007-07-22 03:47:29 +00:00
public ArrayListIterator(List<T> list) {
this(list, 0);
}
public ArrayListIterator(List<T> list, int index) {
2007-07-22 03:47:29 +00:00
this.list = list;
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-22 03:47:29 +00: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();
}
}
}
}