blob: c606645af65a968e8d6d0425a44b22777ba31b9c [file] [log] [blame]
package org.testng.collections;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
public abstract class MultiMap<K, V, C extends Collection<V>> {
protected final Map<K, C> m_objects = Maps.newHashMap();
protected abstract C createValue();
public boolean put(K key, V method) {
boolean setExists = true;
C l = m_objects.get(key);
if (l == null) {
setExists = false;
l = createValue();
m_objects.put(key, l);
}
return l.add(method) && setExists;
}
public C get(K key) {
return m_objects.get(key);
}
@Deprecated
public List<K> getKeys() {
return new ArrayList<>(keySet());
}
public Set<K> keySet() {
return new HashSet(m_objects.keySet());
}
public boolean containsKey(K k) {
return m_objects.containsKey(k);
}
@Override
public String toString() {
StringBuilder result = new StringBuilder();
Set<K> indices = keySet();
for (K i : indices) {
result.append("\n ").append(i).append(" <-- ");
for (Object o : m_objects.get(i)) {
result.append(o).append(" ");
}
}
return result.toString();
}
public boolean isEmpty() {
return m_objects.size() == 0;
}
@Deprecated
public int getSize() {
return size();
}
public int size() {
return m_objects.size();
}
@Deprecated
public C remove(K key) {
return removeAll(key);
}
public boolean remove(K key, V value) {
C values = get(key);
if (values == null) {
return false;
}
return values.remove(value);
}
public C removeAll(K key) {
return m_objects.remove(key);
}
@Deprecated
public Set<Map.Entry<K, C>> getEntrySet() {
return entrySet();
}
public Set<Map.Entry<K, C>> entrySet() {
return m_objects.entrySet();
}
@Deprecated
public Collection<C> getValues() {
return values();
}
public Collection<C> values() {
return m_objects.values();
}
public boolean putAll(K k, Collection<? extends V> values) {
boolean result = false;
for (V v : values) {
result = put(k, v) || result;
}
return result;
}
}