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
- DesignerEventService.cs
- GeneratedContractType.cs
- FixedTextView.cs
- SynchronousSendBindingElement.cs
- UnhandledExceptionEventArgs.cs
- DataContractSerializerFaultFormatter.cs
- WindowsContainer.cs
- ObjRef.cs
- LeaseManager.cs
- VarInfo.cs
- storepermission.cs
- ExpressionHelper.cs
- TableLayoutColumnStyleCollection.cs
- DTCTransactionManager.cs
- BooleanAnimationUsingKeyFrames.cs
- X509IssuerSerialKeyIdentifierClause.cs
- ColumnMapProcessor.cs
- ObjectStateManagerMetadata.cs
- DetailsViewInsertedEventArgs.cs
- RegexTree.cs
- Privilege.cs
- Rect3D.cs
- SerializerProvider.cs
- InkCanvasSelection.cs
- PassportPrincipal.cs
- ManifestSignedXml.cs
- Transform.cs
- PrimaryKeyTypeConverter.cs
- BasePropertyDescriptor.cs
- InProcStateClientManager.cs
- MenuItemBindingCollection.cs
- NonParentingControl.cs
- ProxyHelper.cs
- BitmapMetadataEnumerator.cs
- Profiler.cs
- sqlpipe.cs
- GeometryDrawing.cs
- TrackBarDesigner.cs
- XmlSchemaComplexContent.cs
- PageAsyncTaskManager.cs
- HelpProvider.cs
- DependencyObjectType.cs
- HtmlInputImage.cs
- SessionStateContainer.cs
- BitmapEffectInput.cs
- TakeOrSkipQueryOperator.cs
- CacheHelper.cs
- SamlSerializer.cs
- BaseProcessProtocolHandler.cs
- XmlSchemaAnnotation.cs
- WmlValidatorAdapter.cs
- OracleConnection.cs
- DbXmlEnabledProviderManifest.cs
- RawContentTypeMapper.cs
- PartEditor.cs
- ThreadExceptionDialog.cs
- ConfigurationSettings.cs
- Repeater.cs
- JsonEnumDataContract.cs
- HttpCapabilitiesEvaluator.cs
- UnsafeNativeMethods.cs
- PanelContainerDesigner.cs
- ProtectedConfigurationSection.cs
- BuilderInfo.cs
- SingleAnimationUsingKeyFrames.cs
- AuthenticationModuleElement.cs
- DateTimeValueSerializer.cs
- DefaultShape.cs
- DesignerCommandSet.cs
- Rectangle.cs
- unsafenativemethodstextservices.cs
- SplayTreeNode.cs
- TypeContext.cs
- ListBox.cs
- FormViewCommandEventArgs.cs
- AutomationEvent.cs
- SignatureConfirmations.cs
- WsdlBuildProvider.cs
- SortQuery.cs
- ToolStripHighContrastRenderer.cs
- VerificationAttribute.cs
- EncryptedType.cs
- SigningCredentials.cs
- DeferredSelectedIndexReference.cs
- EventDescriptorCollection.cs
- DefaultTypeArgumentAttribute.cs
- TreeBuilder.cs
- ConfigXmlCDataSection.cs
- XmlTextAttribute.cs
- SimpleWorkerRequest.cs
- SchemaNames.cs
- MultiView.cs
- JournalEntry.cs
- shaperfactoryquerycachekey.cs
- LinearKeyFrames.cs
- RoutedEventHandlerInfo.cs
- TextInfo.cs
- CommandDevice.cs
- HtmlTableRowCollection.cs
- URLAttribute.cs