Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
MultiValueMap |
|
| 1.75;1.75 |
1 | /******************************************************************************* | |
2 | * Copyright (c) 2008-2009 SWTBot Committers and others. | |
3 | * All rights reserved. This program and the accompanying materials | |
4 | * are made available under the terms of the Eclipse Public License v1.0 | |
5 | * which accompanies this distribution, and is available at | |
6 | * http://www.eclipse.org/legal/epl-v10.html | |
7 | * | |
8 | * Contributors: | |
9 | * Ketan Padegaonkar - initial API and implementation | |
10 | *******************************************************************************/ | |
11 | package org.eclipse.swtbot.swt.finder.utils; | |
12 | ||
13 | import java.util.Collection; | |
14 | import java.util.Collections; | |
15 | import java.util.HashMap; | |
16 | import java.util.LinkedHashSet; | |
17 | import java.util.Set; | |
18 | ||
19 | /** | |
20 | * Maps a key to a collection of values. The values are maintained in a set that gurantees order, adding the same value twice for the same key will have no effect. | |
21 | * | |
22 | * @author Ketan Padegaonkar <KetanPadegaonkar [at] gmail [dot] com> | |
23 | * @version $Id$ | |
24 | * @noinstantiate This class is not intended to be instantiated by clients. | |
25 | * @noextend This class is not intended to be subclassed by clients. | |
26 | */ | |
27 | public class MultiValueMap<K, V> { | |
28 | ||
29 | private HashMap<K, LinkedHashSet<V>> map; | |
30 | ||
31 | 8057 | public MultiValueMap() { |
32 | 8057 | map = new HashMap<K, LinkedHashSet<V>>(); |
33 | 8057 | } |
34 | ||
35 | public void put(K k, V v) { | |
36 | 72487 | LinkedHashSet<V> collection = map.get(k); |
37 | 72487 | if (collection == null) { |
38 | 72485 | collection = new LinkedHashSet<V>(); |
39 | 72485 | map.put(k, collection); |
40 | } | |
41 | 72487 | collection.add(v); |
42 | 72487 | } |
43 | ||
44 | public Collection<V> getCollection(K k) { | |
45 | 370627 | LinkedHashSet<V> result = map.get(k); |
46 | 370627 | if (result != null) |
47 | 210717 | return result; |
48 | 159910 | return Collections.emptySet(); |
49 | } | |
50 | ||
51 | public Set<K> keySet() { | |
52 | 4 | return map.keySet(); |
53 | } | |
54 | ||
55 | } |