Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / untmp / whidbey / QFE / ndp / clr / src / BCL / System / Collections / ObjectModel / KeyedCollection.cs / 1 / KeyedCollection.cs
// Copyright (c) Microsoft Corporation. All rights reserved.
namespace System.Collections.ObjectModel
{
using System;
using System.Collections.Generic;
using System.Diagnostics;
[Serializable()]
[System.Runtime.InteropServices.ComVisible(false)]
[DebuggerTypeProxy(typeof(Mscorlib_KeyedCollectionDebugView<,>))]
[DebuggerDisplay("Count = {Count}")]
public abstract class KeyedCollection: Collection
{
const int defaultThreshold = 0;
IEqualityComparer comparer;
Dictionary dict;
int keyCount;
int threshold;
protected KeyedCollection(): this(null, defaultThreshold) {}
protected KeyedCollection(IEqualityComparer comparer): this(comparer, defaultThreshold) {}
protected KeyedCollection(IEqualityComparer comparer, int dictionaryCreationThreshold) {
if (comparer == null) {
comparer = EqualityComparer.Default;
}
if (dictionaryCreationThreshold == -1) {
dictionaryCreationThreshold = int.MaxValue;
}
if( dictionaryCreationThreshold < -1) {
ThrowHelper.ThrowArgumentOutOfRangeException(ExceptionArgument.dictionaryCreationThreshold, ExceptionResource.ArgumentOutOfRange_InvalidThreshold);
}
this.comparer = comparer;
this.threshold = dictionaryCreationThreshold;
}
public IEqualityComparer Comparer {
get {
return comparer;
}
}
public TItem this[TKey key] {
get {
if( key == null) {
ThrowHelper.ThrowArgumentNullException(ExceptionArgument.key);
}
if (dict != null) {
return dict[key];
}
foreach (TItem item in Items) {
if (comparer.Equals(GetKeyForItem(item), key)) return item;
}
ThrowHelper.ThrowKeyNotFoundException();
return default(TItem);
}
}
public bool Contains(TKey key) {
if( key == null) {
ThrowHelper.ThrowArgumentNullException(ExceptionArgument.key);
}
if (dict != null) {
return dict.ContainsKey(key);
}
if (key != null) {
foreach (TItem item in Items) {
if (comparer.Equals(GetKeyForItem(item), key)) return true;
}
}
return false;
}
private bool ContainsItem(TItem item) {
TKey key;
if( (dict == null) || ((key = GetKeyForItem(item)) == null)) {
return Items.Contains(item);
}
TItem itemInDict;
bool exist = dict.TryGetValue(key, out itemInDict);
if( exist) {
return EqualityComparer.Default.Equals(itemInDict, item);
}
return false;
}
public bool Remove(TKey key) {
if( key == null) {
ThrowHelper.ThrowArgumentNullException(ExceptionArgument.key);
}
if (dict != null) {
if (dict.ContainsKey(key)) {
return Remove(dict[key]);
}
return false;
}
if (key != null) {
for (int i = 0; i < Items.Count; i++) {
if (comparer.Equals(GetKeyForItem(Items[i]), key)) {
RemoveItem(i);
return true;
}
}
}
return false;
}
protected IDictionary Dictionary {
get { return dict; }
}
protected void ChangeItemKey(TItem item, TKey newKey) {
//
if( !ContainsItem(item)) {
ThrowHelper.ThrowArgumentException(ExceptionResource.Argument_ItemNotExist);
}
TKey oldKey = GetKeyForItem(item);
if (!comparer.Equals(oldKey, newKey)) {
if (newKey != null) {
AddKey(newKey, item);
}
if (oldKey != null) {
RemoveKey(oldKey);
}
}
}
protected override void ClearItems() {
base.ClearItems();
if (dict != null) {
dict.Clear();
}
keyCount = 0;
}
protected abstract TKey GetKeyForItem(TItem item);
protected override void InsertItem(int index, TItem item) {
TKey key = GetKeyForItem(item);
if (key != null) {
AddKey(key, item);
}
base.InsertItem(index, item);
}
protected override void RemoveItem(int index) {
TKey key = GetKeyForItem(Items[index]);
if (key != null) {
RemoveKey(key);
}
base.RemoveItem(index);
}
protected override void SetItem(int index, TItem item) {
TKey newKey = GetKeyForItem(item);
TKey oldKey = GetKeyForItem(Items[index]);
if (comparer.Equals(oldKey, newKey)) {
if (newKey != null && dict != null) {
dict[newKey] = item;
}
}
else {
if (newKey != null) {
AddKey(newKey, item);
}
if (oldKey != null) {
RemoveKey(oldKey);
}
}
base.SetItem(index, item);
}
private void AddKey(TKey key, TItem item) {
if (dict != null) {
dict.Add(key, item);
}
else if (keyCount == threshold) {
CreateDictionary();
dict.Add(key, item);
}
else {
if (Contains(key)) {
ThrowHelper.ThrowArgumentException(ExceptionResource.Argument_AddingDuplicate);
}
keyCount++;
}
}
private void CreateDictionary() {
dict = new Dictionary(comparer);
foreach (TItem item in Items) {
TKey key = GetKeyForItem(item);
if (key != null) {
dict.Add(key, item);
}
}
}
private void RemoveKey(TKey key) {
BCLDebug.Assert(key != null, "key shouldn't be null!");
if (dict != null) {
dict.Remove(key);
}
else {
keyCount--;
}
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- PersianCalendar.cs
- TimersDescriptionAttribute.cs
- TypeBuilderInstantiation.cs
- HandlerBase.cs
- BinarySecretKeyIdentifierClause.cs
- SwitchLevelAttribute.cs
- XmlSchemaDatatype.cs
- lengthconverter.cs
- GridSplitterAutomationPeer.cs
- TCPListener.cs
- CodeNamespace.cs
- InfoCardKeyedHashAlgorithm.cs
- CommandField.cs
- MgmtConfigurationRecord.cs
- GlobalizationAssembly.cs
- IsolatedStorageFileStream.cs
- ErrorInfoXmlDocument.cs
- Point3D.cs
- documentsequencetextview.cs
- HealthMonitoringSectionHelper.cs
- tooltip.cs
- XmlHelper.cs
- TextDocumentView.cs
- AutomationPatternInfo.cs
- FormViewCommandEventArgs.cs
- TextFindEngine.cs
- BreakRecordTable.cs
- PrinterUnitConvert.cs
- ItemCheckEvent.cs
- ChtmlPhoneCallAdapter.cs
- FontStyleConverter.cs
- CodeMethodMap.cs
- TagMapInfo.cs
- ClientConvert.cs
- MailHeaderInfo.cs
- HtmlShim.cs
- DynamicScriptObject.cs
- CultureInfoConverter.cs
- DashStyle.cs
- MatrixTransform.cs
- SqlCommandBuilder.cs
- ThreadStateException.cs
- RadialGradientBrush.cs
- ReturnEventArgs.cs
- WindowsImpersonationContext.cs
- Semaphore.cs
- Literal.cs
- BindingEntityInfo.cs
- Span.cs
- DataGridColumnHeadersPresenterAutomationPeer.cs
- TextEmbeddedObject.cs
- Image.cs
- AssemblyBuilder.cs
- FixedSOMPageElement.cs
- ZipIOExtraFieldPaddingElement.cs
- CacheSection.cs
- CollectionChangeEventArgs.cs
- Boolean.cs
- ComponentEvent.cs
- NetStream.cs
- StorageMappingItemCollection.cs
- ValueUtilsSmi.cs
- ObjectCloneHelper.cs
- WpfWebRequestHelper.cs
- LinearGradientBrush.cs
- WebEventCodes.cs
- DbConnectionPoolGroup.cs
- SqlFileStream.cs
- FontStretches.cs
- RowUpdatingEventArgs.cs
- Line.cs
- UIElementCollection.cs
- ContentValidator.cs
- SafeLocalMemHandle.cs
- securitymgrsite.cs
- XamlTemplateSerializer.cs
- ScriptResourceDefinition.cs
- InternalTypeHelper.cs
- PropertyPushdownHelper.cs
- HitTestResult.cs
- StringTraceRecord.cs
- ReferencedCollectionType.cs
- ValidationError.cs
- HttpInputStream.cs
- TemplateComponentConnector.cs
- EnglishPluralizationService.cs
- CultureInfoConverter.cs
- NameScopePropertyAttribute.cs
- InvalidDataException.cs
- FixedSOMContainer.cs
- _UncName.cs
- RoleService.cs
- SystemInfo.cs
- RangeValidator.cs
- HttpHandlersSection.cs
- MultiBindingExpression.cs
- XmlUtil.cs
- VirtualPath.cs
- Menu.cs
- ToolboxItemFilterAttribute.cs