Lucene.Net  3.0.3
Lucene.Net is a port of the Lucene search engine library, written in C# and targeted at .NET runtime users.
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Properties Pages
MapOfSets.cs
Go to the documentation of this file.
1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one or more
3  * contributor license agreements. See the NOTICE file distributed with
4  * this work for additional information regarding copyright ownership.
5  * The ASF licenses this file to You under the Apache License, Version 2.0
6  * (the "License"); you may not use this file except in compliance with
7  * the License. You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17 
18 using System;
19 using System.Collections.Generic;
20 
21 namespace Lucene.Net.Util
22 {
23 
24  /// <summary> Helper class for keeping Listss of Objects associated with keys. <b>WARNING: THIS CLASS IS NOT THREAD SAFE</b></summary>
25  public class MapOfSets<TKey, TValue>
26  {
27  private IDictionary<TKey, HashSet<TValue>> theMap;
28 
29  /// <param name="m">the backing store for this object
30  /// </param>
31  public MapOfSets(IDictionary<TKey, HashSet<TValue>> m)
32  {
33  theMap = m;
34  }
35 
36  /// <value> direct access to the map backing this object. </value>
37  public virtual IDictionary<TKey, HashSet<TValue>> Map
38  {
39  get { return theMap; }
40  }
41 
42  /// <summary> Adds val to the Set associated with key in the Map. If key is not
43  /// already in the map, a new Set will first be created.
44  /// </summary>
45  /// <returns> the size of the Set associated with key once val is added to it.
46  /// </returns>
47  public virtual int Put(TKey key, TValue val)
48  {
49  HashSet<TValue> theSet;
50  if (!theMap.TryGetValue(key, out theSet))
51  {
52  theSet = new HashSet<TValue>();
53  theMap[key] = theSet;
54  }
55  theSet.Add(val);
56  return theSet.Count;
57  }
58  /// <summary> Adds multiple vals to the Set associated with key in the Map.
59  /// If key is not
60  /// already in the map, a new Set will first be created.
61  /// </summary>
62  /// <returns> the size of the Set associated with key once val is added to it.
63  /// </returns>
64  public virtual int PutAll(TKey key, IEnumerable<TValue> vals)
65  {
66  HashSet<TValue> theSet;
67  if (!theMap.TryGetValue(key, out theSet))
68  {
69  theSet = new HashSet<TValue>();
70  theMap[key] = theSet;
71  }
72  theSet.UnionWith(vals);
73  return theSet.Count;
74  }
75  }
76 }