Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DataEntity / System / Data / Common / Utils / KeyToListMap.cs / 1305376 / KeyToListMap.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.Text; using System.Collections.ObjectModel; namespace System.Data.Common.Utils { // This class contains an abstraction that map a key of type TKey to a // list of values (of type TValue). This is really a convenience abstraction internal class KeyToListMap: InternalBase { #region Constructors // effects: Creates an empty map with keys compared using comparer internal KeyToListMap(IEqualityComparer comparer) { Debug.Assert(null != comparer); m_map = new Dictionary >(comparer); } #endregion #region Fields // Just a regular dictionary private Dictionary > m_map; #endregion #region Properties // effects: Yields all the keys in this internal IEnumerable Keys { get { return m_map.Keys; } } // effects: Returns all the values for all keys with all the values // of a particular key adjacent to each other internal IEnumerable AllValues { get { foreach (TKey key in Keys) { foreach (TValue value in ListForKey(key)) { yield return value; } } } } // effects: Returns all the Dictionary Entries in this Map. internal IEnumerable >> KeyValuePairs { get { return m_map; } } #endregion #region Methods internal bool ContainsKey(TKey key) { return m_map.ContainsKey(key); } // effects: Adds to this. If the entry already exists, another one is added internal void Add(TKey key, TValue value) { // If entry for key already exists, add value to the list, else // create a new list and add the value to it List valueList; if (!m_map.TryGetValue(key, out valueList)) { valueList = new List (); m_map[key] = valueList; } valueList.Add(value); } // effects: Adds for each value in values to this. If the entry already exists, another one is added internal void AddRange(TKey key, IEnumerable values) { foreach (TValue value in values) { Add(key, value); } } // effects: Removes all entries corresponding to key // Returns true iff the key was removed internal bool RemoveKey(TKey key) { return m_map.Remove(key); } // requires: key exist in this // effects: Returns the values associated with key internal System.Collections.ObjectModel.ReadOnlyCollection ListForKey(TKey key) { Debug.Assert(m_map.ContainsKey(key), "key not registered in map"); return new System.Collections.ObjectModel.ReadOnlyCollection (m_map[key]); } // effects: Returns true if the key exists and false if not. // In case the Key exists, the out parameter is assigned the List for that key, // otherwise it is assigned a null value internal bool TryGetListForKey(TKey key, out System.Collections.ObjectModel.ReadOnlyCollection valueCollection) { List list; valueCollection = null; if (m_map.TryGetValue(key, out list)) { valueCollection = new System.Collections.ObjectModel.ReadOnlyCollection (list); return true; } return false; } // Returns all values for the given key. If no values have been added for the key, // yields no values. internal IEnumerable EnumerateValues(TKey key) { List values; if (m_map.TryGetValue(key, out values)) { foreach (TValue value in values) { yield return value; } } } internal override void ToCompactString(StringBuilder builder) { foreach (TKey key in Keys) { // Calling key's ToString here StringUtil.FormatStringBuilder(builder, "{0}", key); builder.Append(": "); IEnumerable values = ListForKey(key); StringUtil.ToSeparatedString(builder, values, ",", "null"); builder.Append("; "); } } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- // // Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.Text; using System.Collections.ObjectModel; namespace System.Data.Common.Utils { // This class contains an abstraction that map a key of type TKey to a // list of values (of type TValue). This is really a convenience abstraction internal class KeyToListMap: InternalBase { #region Constructors // effects: Creates an empty map with keys compared using comparer internal KeyToListMap(IEqualityComparer comparer) { Debug.Assert(null != comparer); m_map = new Dictionary >(comparer); } #endregion #region Fields // Just a regular dictionary private Dictionary > m_map; #endregion #region Properties // effects: Yields all the keys in this internal IEnumerable Keys { get { return m_map.Keys; } } // effects: Returns all the values for all keys with all the values // of a particular key adjacent to each other internal IEnumerable AllValues { get { foreach (TKey key in Keys) { foreach (TValue value in ListForKey(key)) { yield return value; } } } } // effects: Returns all the Dictionary Entries in this Map. internal IEnumerable >> KeyValuePairs { get { return m_map; } } #endregion #region Methods internal bool ContainsKey(TKey key) { return m_map.ContainsKey(key); } // effects: Adds to this. If the entry already exists, another one is added internal void Add(TKey key, TValue value) { // If entry for key already exists, add value to the list, else // create a new list and add the value to it List valueList; if (!m_map.TryGetValue(key, out valueList)) { valueList = new List (); m_map[key] = valueList; } valueList.Add(value); } // effects: Adds for each value in values to this. If the entry already exists, another one is added internal void AddRange(TKey key, IEnumerable values) { foreach (TValue value in values) { Add(key, value); } } // effects: Removes all entries corresponding to key // Returns true iff the key was removed internal bool RemoveKey(TKey key) { return m_map.Remove(key); } // requires: key exist in this // effects: Returns the values associated with key internal System.Collections.ObjectModel.ReadOnlyCollection ListForKey(TKey key) { Debug.Assert(m_map.ContainsKey(key), "key not registered in map"); return new System.Collections.ObjectModel.ReadOnlyCollection (m_map[key]); } // effects: Returns true if the key exists and false if not. // In case the Key exists, the out parameter is assigned the List for that key, // otherwise it is assigned a null value internal bool TryGetListForKey(TKey key, out System.Collections.ObjectModel.ReadOnlyCollection valueCollection) { List list; valueCollection = null; if (m_map.TryGetValue(key, out list)) { valueCollection = new System.Collections.ObjectModel.ReadOnlyCollection (list); return true; } return false; } // Returns all values for the given key. If no values have been added for the key, // yields no values. internal IEnumerable EnumerateValues(TKey key) { List values; if (m_map.TryGetValue(key, out values)) { foreach (TValue value in values) { yield return value; } } } internal override void ToCompactString(StringBuilder builder) { foreach (TKey key in Keys) { // Calling key's ToString here StringUtil.FormatStringBuilder(builder, "{0}", key); builder.Append(": "); IEnumerable values = ListForKey(key); StringUtil.ToSeparatedString(builder, values, ",", "null"); builder.Append("; "); } } #endregion } } // 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
- CompoundFileStreamReference.cs
- XmlILTrace.cs
- WebBrowserPermission.cs
- GestureRecognitionResult.cs
- FixedSOMPageConstructor.cs
- DefaultTraceListener.cs
- AppSettings.cs
- QueryCoreOp.cs
- WebPartConnection.cs
- TypeUtils.cs
- RequestQueue.cs
- ProgressBarAutomationPeer.cs
- MissingMethodException.cs
- ConfigurationLocationCollection.cs
- KeyPullup.cs
- SecurityDescriptor.cs
- DataTableTypeConverter.cs
- Inflater.cs
- AccessorTable.cs
- VersionPair.cs
- SimplePropertyEntry.cs
- TransactionInformation.cs
- ConfigurationException.cs
- HostProtectionException.cs
- BinaryCommonClasses.cs
- SettingsProperty.cs
- StrokeNodeOperations2.cs
- ExtentCqlBlock.cs
- DPCustomTypeDescriptor.cs
- EventHandlerList.cs
- Decoder.cs
- OrCondition.cs
- EventLogReader.cs
- UniqueIdentifierService.cs
- XmlReflectionMember.cs
- PolyQuadraticBezierSegment.cs
- TextServicesHost.cs
- UnsafeNativeMethods.cs
- WorkItem.cs
- WriteableBitmap.cs
- Parameter.cs
- CacheAxisQuery.cs
- GeneralTransform3DGroup.cs
- Int32AnimationBase.cs
- TextEmbeddedObject.cs
- ExtractedStateEntry.cs
- NetworkAddressChange.cs
- PageBreakRecord.cs
- ZipIOCentralDirectoryBlock.cs
- UpdateEventArgs.cs
- GridViewDeletedEventArgs.cs
- ExtendedPropertyDescriptor.cs
- TripleDESCryptoServiceProvider.cs
- DbConnectionOptions.cs
- UnicastIPAddressInformationCollection.cs
- SystemUnicastIPAddressInformation.cs
- PrivacyNoticeBindingElementImporter.cs
- MultiSelectRootGridEntry.cs
- DataKeyCollection.cs
- IconConverter.cs
- XmlSchemaAnnotated.cs
- UIElement.cs
- PriorityQueue.cs
- WindowsScrollBar.cs
- NamedPermissionSet.cs
- BrowserDefinition.cs
- DesignerObjectListAdapter.cs
- GradientBrush.cs
- FixUpCollection.cs
- ToolStripDropTargetManager.cs
- CallContext.cs
- ConfigurationManagerInternal.cs
- RewritingValidator.cs
- PathParser.cs
- HttpServerUtilityWrapper.cs
- InboundActivityHelper.cs
- CommentEmitter.cs
- TcpServerChannel.cs
- XmlMemberMapping.cs
- FlowDocumentScrollViewerAutomationPeer.cs
- XmlException.cs
- Compilation.cs
- DependencyObjectType.cs
- WebPartManager.cs
- JulianCalendar.cs
- RectangleHotSpot.cs
- Enum.cs
- BindingBase.cs
- URLAttribute.cs
- StreamUpgradeProvider.cs
- User.cs
- SystemIPGlobalStatistics.cs
- Vector3DAnimation.cs
- PartitionerQueryOperator.cs
- SpeakProgressEventArgs.cs
- JournalEntryStack.cs
- DynamicResourceExtensionConverter.cs
- Models.cs
- DecimalAnimation.cs
- Zone.cs