Lookup.cs 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. // Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. See License.txt in the project root for license information.
  2. using System.Collections;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. namespace System.Reactive
  6. {
  7. class Lookup<K, E> : ILookup<K, E>
  8. {
  9. private readonly Dictionary<K, List<E>> d;
  10. public Lookup(IEqualityComparer<K> comparer)
  11. {
  12. d = new Dictionary<K, List<E>>(comparer);
  13. }
  14. public void Add(K key, E element)
  15. {
  16. var list = default(List<E>);
  17. if (!d.TryGetValue(key, out list))
  18. d[key] = list = new List<E>();
  19. list.Add(element);
  20. }
  21. public bool Contains(K key)
  22. {
  23. return d.ContainsKey(key);
  24. }
  25. public int Count
  26. {
  27. get { return d.Count; }
  28. }
  29. public IEnumerable<E> this[K key]
  30. {
  31. get
  32. {
  33. var list = default(List<E>);
  34. if (!d.TryGetValue(key, out list))
  35. return Enumerable.Empty<E>();
  36. return Hide(list);
  37. }
  38. }
  39. private IEnumerable<E> Hide(List<E> elements)
  40. {
  41. foreach (var x in elements)
  42. yield return x;
  43. }
  44. public IEnumerator<IGrouping<K, E>> GetEnumerator()
  45. {
  46. foreach (var kv in d)
  47. yield return new Grouping(kv);
  48. }
  49. class Grouping : IGrouping<K, E>
  50. {
  51. KeyValuePair<K, List<E>> kv;
  52. public Grouping(KeyValuePair<K, List<E>> kv)
  53. {
  54. this.kv = kv;
  55. }
  56. public K Key
  57. {
  58. get { return kv.Key; }
  59. }
  60. public IEnumerator<E> GetEnumerator()
  61. {
  62. return kv.Value.GetEnumerator();
  63. }
  64. IEnumerator IEnumerable.GetEnumerator()
  65. {
  66. return GetEnumerator();
  67. }
  68. }
  69. IEnumerator IEnumerable.GetEnumerator()
  70. {
  71. return GetEnumerator();
  72. }
  73. }
  74. }