import java.util.*; import java.util.concurrent.*; import java.util.concurrent.locks.*; /** * This is an incomplete implementation of a wrapper class * that places read-write locks around unsynchronized Maps. * Exists as a sample input for MapLoops test. */ public class SMap implements Map { private final Map m; public SMap(Map m) { if (m == null) throw new NullPointerException(); this.m = m; } public SMap() { this(new TreeMap()); // use TreeMap by default } public synchronized int size() { return m.size(); } public synchronized boolean isEmpty(){ return m.isEmpty(); } public synchronized Object get(Object key) { return m.get(key); } public synchronized boolean containsKey(Object key) { return m.containsKey(key); } public synchronized boolean containsValue(Object value){ return m.containsValue(value); } public synchronized Set keySet() { // Not implemented return m.keySet(); } public synchronized Set entrySet() { // Not implemented return m.entrySet(); } public synchronized Collection values() { // Not implemented return m.values(); } public synchronized boolean equals(Object o) { return m.equals(o); } public synchronized int hashCode() { return m.hashCode(); } public synchronized String toString() { return m.toString(); } public synchronized Object put(Object key, Object value) { return m.put(key, value); } public synchronized Object remove(Object key) { return m.remove(key); } public synchronized void putAll(Map map) { m.putAll(map); } public synchronized void clear() { m.clear(); } }