/*
@VaadinApache2LicenseForJavaFiles@
*/
package com.vaadin.terminal;
import java.io.Serializable;
import java.util.HashMap;
/**
* KeyMapper
is the simple two-way map for generating textual keys
* for objects and retrieving the objects later with the key.
*
* @author Vaadin Ltd.
* @version
* @VERSION@
* @since 3.0
*/
public class KeyMapper implements Serializable {
private int lastKey = 0;
private final HashMap objectKeyMap = new HashMap();
private final HashMap keyObjectMap = new HashMap();
/**
* Gets key for an object.
*
* @param o
* the object.
*/
public String key(V o) {
if (o == null) {
return "null";
}
// If the object is already mapped, use existing key
String key = objectKeyMap.get(o);
if (key != null) {
return key;
}
// If the object is not yet mapped, map it
key = String.valueOf(++lastKey);
objectKeyMap.put(o, key);
keyObjectMap.put(key, o);
return key;
}
/**
* Retrieves object with the key.
*
* @param key
* the name with the desired value.
* @return the object with the key.
*/
public V get(String key) {
return keyObjectMap.get(key);
}
/**
* Removes object from the mapper.
*
* @param removeobj
* the object to be removed.
*/
public void remove(V removeobj) {
final String key = objectKeyMap.get(removeobj);
if (key != null) {
objectKeyMap.remove(removeobj);
keyObjectMap.remove(key);
}
}
/**
* Removes all objects from the mapper.
*/
public void removeAll() {
objectKeyMap.clear();
keyObjectMap.clear();
}
}