package org.antlr.v4.misc;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
public class OrderedHashMap<K,V> extends LinkedHashMap<K,V> {
protected List<K> elements = new ArrayList<K>();
public K getKey(int i) { return elements.get(i); }
public V getElement(int i) { return get(elements.get(i)); }
@Override
public V put(K key, V value) {
elements.add(key);
return super.put(key, value);
}
@Override
public void putAll(Map<? extends K, ? extends V> m) {
for (Map.Entry<? extends K, ? extends V> entry : m.entrySet()) {
put(entry.getKey(), entry.getValue());
}
}
@Override
public V remove(Object key) {
elements.remove(key);
return super.remove(key);
}
@Override
public void clear() {
elements.clear();
super.clear();
}
}