Class CloningDictionary<K, V>
- Namespace
 - Sportradar.LiveData.Sdk.Common.Utils
 
- Assembly
 - Sportradar.LiveData.Sdk.dll
 
public class CloningDictionary<K, V> : IDictionary<K, V>, ICollection<KeyValuePair<K, V>>, IEnumerable<KeyValuePair<K, V>>, IEnumerable where V : ICloneable
  Type Parameters
KV
- Inheritance
 - 
      
      CloningDictionary<K, V>
 
- Implements
 - 
      IDictionary<K, V>ICollection<KeyValuePair<K, V>>IEnumerable<KeyValuePair<K, V>>
 
- Inherited Members
 
- Extension Methods
 
Constructors
CloningDictionary(IDictionary<K, V>)
public CloningDictionary(IDictionary<K, V> inner)
  Parameters
innerIDictionary<K, V>
Properties
Count
Gets the number of elements contained in the ICollection<T>.
public int Count { get; }
  Property Value
- int
 The number of elements contained in the ICollection<T>.
IsReadOnly
Gets a value indicating whether the ICollection<T> is read-only.
public bool IsReadOnly { get; }
  Property Value
- bool
 true if the ICollection<T> is read-only; otherwise, false.
this[K]
Gets or sets the element with the specified key.
public V this[K key] { get; set; }
  Parameters
keyKThe key of the element to get or set.
Property Value
- V
 The element with the specified key.
Exceptions
- ArgumentNullException
 keyis null.- KeyNotFoundException
 The property is retrieved and
keyis not found.- NotSupportedException
 The property is set and the IDictionary<TKey, TValue> is read-only.
Keys
Gets an ICollection<T> containing the keys of the IDictionary<TKey, TValue>.
public ICollection<K> Keys { get; }
  Property Value
- ICollection<K>
 An ICollection<T> containing the keys of the object that implements IDictionary<TKey, TValue>.
Values
Gets an ICollection<T> containing the values in the IDictionary<TKey, TValue>.
public ICollection<V> Values { get; }
  Property Value
- ICollection<V>
 An ICollection<T> containing the values in the object that implements IDictionary<TKey, TValue>.
Methods
Add(KeyValuePair<K, V>)
Adds an item to the ICollection<T>.
public void Add(KeyValuePair<K, V> item)
  Parameters
itemKeyValuePair<K, V>The object to add to the ICollection<T>.
Exceptions
- NotSupportedException
 The ICollection<T> is read-only.
Add(K, V)
Adds an element with the provided key and value to the IDictionary<TKey, TValue>.
public void Add(K key, V value)
  Parameters
keyKThe object to use as the key of the element to add.
valueVThe object to use as the value of the element to add.
Exceptions
- ArgumentNullException
 keyis null.- ArgumentException
 An element with the same key already exists in the IDictionary<TKey, TValue>.
- NotSupportedException
 The IDictionary<TKey, TValue> is read-only.
Clear()
Removes all items from the ICollection<T>.
public void Clear()
  Exceptions
- NotSupportedException
 The ICollection<T> is read-only.
Contains(KeyValuePair<K, V>)
Determines whether the ICollection<T> contains a specific value.
public bool Contains(KeyValuePair<K, V> item)
  Parameters
itemKeyValuePair<K, V>The object to locate in the ICollection<T>.
Returns
- bool
 true if
itemis found in the ICollection<T>; otherwise, false.
ContainsKey(K)
Determines whether the IDictionary<TKey, TValue> contains an element with the specified key.
public bool ContainsKey(K key)
  Parameters
keyKThe key to locate in the IDictionary<TKey, TValue>.
Returns
- bool
 true if the IDictionary<TKey, TValue> contains an element with the key; otherwise, false.
Exceptions
- ArgumentNullException
 keyis null.
CopyTo(KeyValuePair<K, V>[], int)
Copies the elements of the ICollection<T> to an Array, starting at a particular Array index.
public void CopyTo(KeyValuePair<K, V>[] array, int arrayIndex)
  Parameters
arrayKeyValuePair<K, V>[]The one-dimensional Array that is the destination of the elements copied from ICollection<T>. The Array must have zero-based indexing.
arrayIndexintThe zero-based index in
arrayat which copying begins.
Exceptions
- ArgumentNullException
 arrayis null.- ArgumentOutOfRangeException
 arrayIndexis less than 0.- ArgumentException
 The number of elements in the source ICollection<T> is greater than the available space from
arrayIndexto the end of the destinationarray.
GetEnumerator()
Returns an enumerator that iterates through the collection.
public IEnumerator<KeyValuePair<K, V>> GetEnumerator()
  Returns
- IEnumerator<KeyValuePair<K, V>>
 An enumerator that can be used to iterate through the collection.
Remove(KeyValuePair<K, V>)
Removes the first occurrence of a specific object from the ICollection<T>.
public bool Remove(KeyValuePair<K, V> item)
  Parameters
itemKeyValuePair<K, V>The object to remove from the ICollection<T>.
Returns
- bool
 true if
itemwas successfully removed from the ICollection<T>; otherwise, false. This method also returns false ifitemis not found in the original ICollection<T>.
Exceptions
- NotSupportedException
 The ICollection<T> is read-only.
Remove(K)
Removes the element with the specified key from the IDictionary<TKey, TValue>.
public bool Remove(K key)
  Parameters
keyKThe key of the element to remove.
Returns
- bool
 true if the element is successfully removed; otherwise, false. This method also returns false if
keywas not found in the original IDictionary<TKey, TValue>.
Exceptions
- ArgumentNullException
 keyis null.- NotSupportedException
 The IDictionary<TKey, TValue> is read-only.
TryGetValue(K, out V)
Gets the value associated with the specified key.
public bool TryGetValue(K key, out V value)
  Parameters
keyKThe key whose value to get.
valueVWhen this method returns, the value associated with the specified key, if the key is found; otherwise, the default value for the type of the
valueparameter. This parameter is passed uninitialized.
Returns
- bool
 true if the object that implements IDictionary<TKey, TValue> contains an element with the specified key; otherwise, false.
Exceptions
- ArgumentNullException
 keyis null.