343 lines
8.8 KiB
C#
343 lines
8.8 KiB
C#
|
//-----------------------------------------------------------------------------
|
||
|
// Copyright (c) Microsoft Corporation. All rights reserved.
|
||
|
//-----------------------------------------------------------------------------
|
||
|
|
||
|
namespace System.Runtime.Collections
|
||
|
{
|
||
|
using System;
|
||
|
using System.Collections;
|
||
|
using System.Collections.Generic;
|
||
|
using System.Collections.Specialized;
|
||
|
|
||
|
// System.Collections.Specialized.OrderedDictionary is NOT generic.
|
||
|
// This class is essentially a generic wrapper for OrderedDictionary.
|
||
|
class OrderedDictionary<TKey, TValue> : IDictionary<TKey, TValue>, IDictionary
|
||
|
{
|
||
|
OrderedDictionary privateDictionary;
|
||
|
|
||
|
public OrderedDictionary()
|
||
|
{
|
||
|
this.privateDictionary = new OrderedDictionary();
|
||
|
}
|
||
|
|
||
|
public OrderedDictionary(IDictionary<TKey, TValue> dictionary)
|
||
|
{
|
||
|
if (dictionary != null)
|
||
|
{
|
||
|
this.privateDictionary = new OrderedDictionary();
|
||
|
|
||
|
foreach (KeyValuePair<TKey, TValue> pair in dictionary)
|
||
|
{
|
||
|
this.privateDictionary.Add(pair.Key, pair.Value);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public int Count
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return this.privateDictionary.Count;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public bool IsReadOnly
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public TValue this[TKey key]
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
if (key == null)
|
||
|
{
|
||
|
throw Fx.Exception.ArgumentNull("key");
|
||
|
}
|
||
|
|
||
|
if (this.privateDictionary.Contains(key))
|
||
|
{
|
||
|
return (TValue)this.privateDictionary[(object)key];
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
throw Fx.Exception.AsError(new KeyNotFoundException(InternalSR.KeyNotFoundInDictionary));
|
||
|
}
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
if (key == null)
|
||
|
{
|
||
|
throw Fx.Exception.ArgumentNull("key");
|
||
|
}
|
||
|
|
||
|
this.privateDictionary[(object)key] = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public ICollection<TKey> Keys
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
List<TKey> keys = new List<TKey>(this.privateDictionary.Count);
|
||
|
|
||
|
foreach (TKey key in this.privateDictionary.Keys)
|
||
|
{
|
||
|
keys.Add(key);
|
||
|
}
|
||
|
|
||
|
// Keys should be put in a ReadOnlyCollection,
|
||
|
// but since this is an internal class, for performance reasons,
|
||
|
// we choose to avoid creating yet another collection.
|
||
|
|
||
|
return keys;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public ICollection<TValue> Values
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
List<TValue> values = new List<TValue>(this.privateDictionary.Count);
|
||
|
|
||
|
foreach (TValue value in this.privateDictionary.Values)
|
||
|
{
|
||
|
values.Add(value);
|
||
|
}
|
||
|
|
||
|
// Values should be put in a ReadOnlyCollection,
|
||
|
// but since this is an internal class, for performance reasons,
|
||
|
// we choose to avoid creating yet another collection.
|
||
|
|
||
|
return values;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void Add(KeyValuePair<TKey, TValue> item)
|
||
|
{
|
||
|
Add(item.Key, item.Value);
|
||
|
}
|
||
|
|
||
|
public void Add(TKey key, TValue value)
|
||
|
{
|
||
|
if (key == null)
|
||
|
{
|
||
|
throw Fx.Exception.ArgumentNull("key");
|
||
|
}
|
||
|
|
||
|
this.privateDictionary.Add(key, value);
|
||
|
}
|
||
|
|
||
|
public void Clear()
|
||
|
{
|
||
|
this.privateDictionary.Clear();
|
||
|
}
|
||
|
|
||
|
public bool Contains(KeyValuePair<TKey, TValue> item)
|
||
|
{
|
||
|
if (item.Key == null || !this.privateDictionary.Contains(item.Key))
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
return this.privateDictionary[(object)item.Key].Equals(item.Value);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public bool ContainsKey(TKey key)
|
||
|
{
|
||
|
if (key == null)
|
||
|
{
|
||
|
throw Fx.Exception.ArgumentNull("key");
|
||
|
}
|
||
|
|
||
|
return this.privateDictionary.Contains(key);
|
||
|
}
|
||
|
|
||
|
public void CopyTo(KeyValuePair<TKey, TValue>[] array, int arrayIndex)
|
||
|
{
|
||
|
if (array == null)
|
||
|
{
|
||
|
throw Fx.Exception.ArgumentNull("array");
|
||
|
}
|
||
|
|
||
|
if (arrayIndex < 0)
|
||
|
{
|
||
|
throw Fx.Exception.AsError(new ArgumentOutOfRangeException("arrayIndex"));
|
||
|
}
|
||
|
|
||
|
if (array.Rank > 1 || arrayIndex >= array.Length || array.Length - arrayIndex < this.privateDictionary.Count)
|
||
|
{
|
||
|
throw Fx.Exception.Argument("array", InternalSR.BadCopyToArray);
|
||
|
}
|
||
|
|
||
|
int index = arrayIndex;
|
||
|
foreach (DictionaryEntry entry in this.privateDictionary)
|
||
|
{
|
||
|
array[index] = new KeyValuePair<TKey, TValue>((TKey)entry.Key, (TValue)entry.Value);
|
||
|
index++;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public IEnumerator<KeyValuePair<TKey, TValue>> GetEnumerator()
|
||
|
{
|
||
|
foreach (DictionaryEntry entry in this.privateDictionary)
|
||
|
{
|
||
|
yield return new KeyValuePair<TKey, TValue>((TKey)entry.Key, (TValue)entry.Value);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
IEnumerator IEnumerable.GetEnumerator()
|
||
|
{
|
||
|
return GetEnumerator();
|
||
|
}
|
||
|
|
||
|
public bool Remove(KeyValuePair<TKey, TValue> item)
|
||
|
{
|
||
|
if (Contains(item))
|
||
|
{
|
||
|
this.privateDictionary.Remove(item.Key);
|
||
|
return true;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public bool Remove(TKey key)
|
||
|
{
|
||
|
if (key == null)
|
||
|
{
|
||
|
throw Fx.Exception.ArgumentNull("key");
|
||
|
}
|
||
|
|
||
|
if (this.privateDictionary.Contains(key))
|
||
|
{
|
||
|
this.privateDictionary.Remove(key);
|
||
|
return true;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public bool TryGetValue(TKey key, out TValue value)
|
||
|
{
|
||
|
if (key == null)
|
||
|
{
|
||
|
throw Fx.Exception.ArgumentNull("key");
|
||
|
}
|
||
|
|
||
|
bool keyExists = this.privateDictionary.Contains(key);
|
||
|
value = keyExists ? (TValue)this.privateDictionary[(object)key] : default(TValue);
|
||
|
|
||
|
return keyExists;
|
||
|
}
|
||
|
|
||
|
void IDictionary.Add(object key, object value)
|
||
|
{
|
||
|
this.privateDictionary.Add(key, value);
|
||
|
}
|
||
|
|
||
|
void IDictionary.Clear()
|
||
|
{
|
||
|
this.privateDictionary.Clear();
|
||
|
}
|
||
|
|
||
|
bool IDictionary.Contains(object key)
|
||
|
{
|
||
|
return this.privateDictionary.Contains(key);
|
||
|
}
|
||
|
|
||
|
IDictionaryEnumerator IDictionary.GetEnumerator()
|
||
|
{
|
||
|
return this.privateDictionary.GetEnumerator();
|
||
|
}
|
||
|
|
||
|
bool IDictionary.IsFixedSize
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return ((IDictionary)this.privateDictionary).IsFixedSize;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
bool IDictionary.IsReadOnly
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return this.privateDictionary.IsReadOnly;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
ICollection IDictionary.Keys
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return this.privateDictionary.Keys;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void IDictionary.Remove(object key)
|
||
|
{
|
||
|
this.privateDictionary.Remove(key);
|
||
|
}
|
||
|
|
||
|
ICollection IDictionary.Values
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return this.privateDictionary.Values;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
object IDictionary.this[object key]
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return this.privateDictionary[key];
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
this.privateDictionary[key] = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void ICollection.CopyTo(Array array, int index)
|
||
|
{
|
||
|
this.privateDictionary.CopyTo(array, index);
|
||
|
}
|
||
|
|
||
|
int ICollection.Count
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return this.privateDictionary.Count;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
bool ICollection.IsSynchronized
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return ((ICollection)this.privateDictionary).IsSynchronized;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
object ICollection.SyncRoot
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return ((ICollection)this.privateDictionary).SyncRoot;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|