Subversion Repositories mkgmap

Rev

Rev 2014 | Blame | Compare with Previous | Last modification | View Log | RSS feed

package uk.me.parabola.util;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;


public class MultiHashMap<K,V> extends HashMap<K,List<V>> {

        /**
        * the empty list to be returned when there is key without values.
        */

        private final List<V> emptyList = Collections.unmodifiableList(new ArrayList<V>(0));

        /**
        * Returns the list of values associated with the given key.
        *
        * @param key the key to get the values for.
        * @return a list of values for the given keys or the empty list of no such
        *         value exist.
        */

        public List<V> get(Object key) {
                List<V> result = super.get(key);
                return result == null ? emptyList : result;
        }


        public V add(K key, V value )
        {
           
            List<V> values = super.get(key);
            if (values == null ) {
                values = new LinkedList<V>();
                super.put( key, values );
            }
           
            boolean results = values.add(value);
           
            return ( results ? value : null );
        }

        public V remove(K key, V value )
        {
           
            List<V> values = super.get(key);
            if (values == null )
                        return null;
       
            values.remove(value);
               
                if (values.isEmpty())
                        super.remove(key);

                return value;
        }
}