Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / MS / Internal / Annotations / ObservableDictionary.cs / 1305600 / ObservableDictionary.cs
//------------------------------------------------------------------------------ // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // ContentLocatorPart represents a set of name/value pairs that identify a // piece of data within a certain context. The names and values are // strings. // // Spec: http://team/sites/ag/Specifications/Simplifying%20Store%20Cache%20Model.doc // // History: // 05/06/2004: ssimova: Created // 06/30/2004: rruiz: Added change notifications to parent, clean-up //----------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics; using System.Xml; namespace MS.Internal.Annotations { ////// ContentLocatorPart represents a set of name/value pairs that identify a /// piece of data within a certain context. The names and values are /// all strings. /// internal class ObservableDictionary : IDictionary, INotifyPropertyChanged { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- #region Constructors /// /// Creates a ContentLocatorPart with the specified type name and namespace. /// public ObservableDictionary() { _nameValues = new Dictionary(); } #endregion Constructors //------------------------------------------------------ // // Public Methods // //----------------------------------------------------- #region Public Methods /// /// Adds a key/value pair to the ContentLocatorPart. If a value for the key already /// exists, the old value is overwritten by the new value. /// /// key /// value ///key or val is null ///a value for key is already present in the locator part public void Add(string key, string val) { if (key == null || val == null) { throw new ArgumentNullException(key == null ? "key" : "val"); } _nameValues.Add(key, val); FireDictionaryChanged(); } ////// Removes all name/value pairs from the ContentLocatorPart. /// public void Clear() { int count = _nameValues.Count; if (count > 0) { _nameValues.Clear(); // Only fire changed event if the dictionary actually changed FireDictionaryChanged(); } } ////// Returns whether or not a value of the key exists in this ContentLocatorPart. /// /// the key to check for ///true - yes, false - no public bool ContainsKey(string key) { return _nameValues.ContainsKey(key); } ////// Removes the key and its value from the ContentLocatorPart. /// /// key to be removed ///true - the key was found in the ContentLocatorPart, false o- it wasn't public bool Remove(string key) { bool exists = _nameValues.Remove(key); // Only fire changed event if the key was actually removed if (exists) { FireDictionaryChanged(); } return exists; } ////// Returns an enumerator for the key/value pairs in this ContentLocatorPart. /// ///an enumerator for the key/value pairs; never returns null IEnumerator IEnumerable.GetEnumerator() { return _nameValues.GetEnumerator(); } ////// Returns an enumerator forthe key/value pairs in this ContentLocatorPart. /// ///an enumerator for the key/value pairs; never returns null public IEnumerator> GetEnumerator() { return ((IEnumerable >)_nameValues).GetEnumerator(); } /// /// /// /// /// ////// key is null public bool TryGetValue(string key, out string value) { if (key == null) throw new ArgumentNullException("key"); return _nameValues.TryGetValue(key, out value); } ////// /// /// ///pair is null void ICollection>.Add(KeyValuePair pair) { ((ICollection >)_nameValues).Add(pair); } /// /// /// /// ////// pair is null bool ICollection>.Contains(KeyValuePair pair) { return ((ICollection >)_nameValues).Contains(pair); } /// /// /// /// ////// pair is null bool ICollection>.Remove(KeyValuePair pair) { return ((ICollection >)_nameValues).Remove(pair); } /// /// /// /// /// ///target is null ///startIndex is less than zero or greater than the lenght of target void ICollection>.CopyTo(KeyValuePair [] target, int startIndex) { if (target == null) throw new ArgumentNullException("target"); if (startIndex < 0 || startIndex > target.Length) throw new ArgumentOutOfRangeException("startIndex"); ((ICollection >)_nameValues).CopyTo(target, startIndex); } #endregion Public Methods //------------------------------------------------------ // // Public Operators // //------------------------------------------------------ //----------------------------------------------------- // // Public Events // //------------------------------------------------------ //----------------------------------------------------- // // Public Properties // //----------------------------------------------------- #region Public Properties /// /// The number of name/value pairs in this ContentLocatorPart. /// ///count of name/value pairs public int Count { get { return _nameValues.Count; } } ////// Indexer provides lookup of values by key. Gets or sets the value /// in the ContentLocatorPart for the specified key. If the key does not exist /// in the ContentLocatorPart, /// /// key ///the value stored in this locator part for key public string this[string key] { get { if (key == null) { throw new ArgumentNullException("key"); } string value = null; _nameValues.TryGetValue(key, out value); return value; } set { if (key == null) { throw new ArgumentNullException("key"); } if (value == null) { throw new ArgumentNullException("value"); } string oldValue = null; _nameValues.TryGetValue(key, out oldValue); // If the new value is actually different, then we add it and fire // a change notification if ((oldValue == null) || (oldValue != value)) { _nameValues[key] = value; FireDictionaryChanged(); } } } ////// /// public bool IsReadOnly { get { return false; } } ////// Returns a collection of all the keys in this ContentLocatorPart. /// ///keys public ICollectionKeys { get { return _nameValues.Keys; } } /// /// Returns a collection of all the values in this ContentLocatorPart. /// ///values public ICollectionValues { get { return _nameValues.Values; } } #endregion Public Properties //----------------------------------------------------- // // Public Events // //------------------------------------------------------ //----------------------------------------------------- // // Internal Methods // //------------------------------------------------------ //------------------------------------------------------ // // Internal Operators // //----------------------------------------------------- //------------------------------------------------------ // // Internal Events // //----------------------------------------------------- #region Public Events /// /// /// public event PropertyChangedEventHandler PropertyChanged; #endregion Public Events //----------------------------------------------------- // // Internal Properties // //----------------------------------------------------- //------------------------------------------------------ // // Private Methods // //----------------------------------------------------- #region Private Methods ////// Notify the owner this ContentLocatorPart has changed. /// private void FireDictionaryChanged() { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(null)); } } #endregion Private Methods //------------------------------------------------------ // // Private Fields // //------------------------------------------------------ #region Private Fields ////// The internal data structure. /// private Dictionary_nameValues; #endregion Private Fields } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // // // Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // ContentLocatorPart represents a set of name/value pairs that identify a // piece of data within a certain context. The names and values are // strings. // // Spec: http://team/sites/ag/Specifications/Simplifying%20Store%20Cache%20Model.doc // // History: // 05/06/2004: ssimova: Created // 06/30/2004: rruiz: Added change notifications to parent, clean-up //----------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics; using System.Xml; namespace MS.Internal.Annotations { ////// ContentLocatorPart represents a set of name/value pairs that identify a /// piece of data within a certain context. The names and values are /// all strings. /// internal class ObservableDictionary : IDictionary, INotifyPropertyChanged { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- #region Constructors /// /// Creates a ContentLocatorPart with the specified type name and namespace. /// public ObservableDictionary() { _nameValues = new Dictionary(); } #endregion Constructors //------------------------------------------------------ // // Public Methods // //----------------------------------------------------- #region Public Methods /// /// Adds a key/value pair to the ContentLocatorPart. If a value for the key already /// exists, the old value is overwritten by the new value. /// /// key /// value ///key or val is null ///a value for key is already present in the locator part public void Add(string key, string val) { if (key == null || val == null) { throw new ArgumentNullException(key == null ? "key" : "val"); } _nameValues.Add(key, val); FireDictionaryChanged(); } ////// Removes all name/value pairs from the ContentLocatorPart. /// public void Clear() { int count = _nameValues.Count; if (count > 0) { _nameValues.Clear(); // Only fire changed event if the dictionary actually changed FireDictionaryChanged(); } } ////// Returns whether or not a value of the key exists in this ContentLocatorPart. /// /// the key to check for ///true - yes, false - no public bool ContainsKey(string key) { return _nameValues.ContainsKey(key); } ////// Removes the key and its value from the ContentLocatorPart. /// /// key to be removed ///true - the key was found in the ContentLocatorPart, false o- it wasn't public bool Remove(string key) { bool exists = _nameValues.Remove(key); // Only fire changed event if the key was actually removed if (exists) { FireDictionaryChanged(); } return exists; } ////// Returns an enumerator for the key/value pairs in this ContentLocatorPart. /// ///an enumerator for the key/value pairs; never returns null IEnumerator IEnumerable.GetEnumerator() { return _nameValues.GetEnumerator(); } ////// Returns an enumerator forthe key/value pairs in this ContentLocatorPart. /// ///an enumerator for the key/value pairs; never returns null public IEnumerator> GetEnumerator() { return ((IEnumerable >)_nameValues).GetEnumerator(); } /// /// /// /// /// ////// key is null public bool TryGetValue(string key, out string value) { if (key == null) throw new ArgumentNullException("key"); return _nameValues.TryGetValue(key, out value); } ////// /// /// ///pair is null void ICollection>.Add(KeyValuePair pair) { ((ICollection >)_nameValues).Add(pair); } /// /// /// /// ////// pair is null bool ICollection>.Contains(KeyValuePair pair) { return ((ICollection >)_nameValues).Contains(pair); } /// /// /// /// ////// pair is null bool ICollection>.Remove(KeyValuePair pair) { return ((ICollection >)_nameValues).Remove(pair); } /// /// /// /// /// ///target is null ///startIndex is less than zero or greater than the lenght of target void ICollection>.CopyTo(KeyValuePair [] target, int startIndex) { if (target == null) throw new ArgumentNullException("target"); if (startIndex < 0 || startIndex > target.Length) throw new ArgumentOutOfRangeException("startIndex"); ((ICollection >)_nameValues).CopyTo(target, startIndex); } #endregion Public Methods //------------------------------------------------------ // // Public Operators // //------------------------------------------------------ //----------------------------------------------------- // // Public Events // //------------------------------------------------------ //----------------------------------------------------- // // Public Properties // //----------------------------------------------------- #region Public Properties /// /// The number of name/value pairs in this ContentLocatorPart. /// ///count of name/value pairs public int Count { get { return _nameValues.Count; } } ////// Indexer provides lookup of values by key. Gets or sets the value /// in the ContentLocatorPart for the specified key. If the key does not exist /// in the ContentLocatorPart, /// /// key ///the value stored in this locator part for key public string this[string key] { get { if (key == null) { throw new ArgumentNullException("key"); } string value = null; _nameValues.TryGetValue(key, out value); return value; } set { if (key == null) { throw new ArgumentNullException("key"); } if (value == null) { throw new ArgumentNullException("value"); } string oldValue = null; _nameValues.TryGetValue(key, out oldValue); // If the new value is actually different, then we add it and fire // a change notification if ((oldValue == null) || (oldValue != value)) { _nameValues[key] = value; FireDictionaryChanged(); } } } ////// /// public bool IsReadOnly { get { return false; } } ////// Returns a collection of all the keys in this ContentLocatorPart. /// ///keys public ICollectionKeys { get { return _nameValues.Keys; } } /// /// Returns a collection of all the values in this ContentLocatorPart. /// ///values public ICollectionValues { get { return _nameValues.Values; } } #endregion Public Properties //----------------------------------------------------- // // Public Events // //------------------------------------------------------ //----------------------------------------------------- // // Internal Methods // //------------------------------------------------------ //------------------------------------------------------ // // Internal Operators // //----------------------------------------------------- //------------------------------------------------------ // // Internal Events // //----------------------------------------------------- #region Public Events /// /// /// public event PropertyChangedEventHandler PropertyChanged; #endregion Public Events //----------------------------------------------------- // // Internal Properties // //----------------------------------------------------- //------------------------------------------------------ // // Private Methods // //----------------------------------------------------- #region Private Methods ////// Notify the owner this ContentLocatorPart has changed. /// private void FireDictionaryChanged() { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(null)); } } #endregion Private Methods //------------------------------------------------------ // // Private Fields // //------------------------------------------------------ #region Private Fields ////// The internal data structure. /// private Dictionary_nameValues; #endregion Private Fields } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ChtmlTextWriter.cs
- TTSVoice.cs
- BuildResult.cs
- StreamSecurityUpgradeAcceptor.cs
- GreaterThan.cs
- TextTreePropertyUndoUnit.cs
- Calendar.cs
- LinqDataSourceDisposeEventArgs.cs
- AppDomainProtocolHandler.cs
- BamlLocalizationDictionary.cs
- StretchValidation.cs
- TreeNodeCollection.cs
- EntityDataSourceWrapper.cs
- TimeZone.cs
- HotCommands.cs
- WindowsGraphics.cs
- XmlSchemaSimpleContent.cs
- ListBoxAutomationPeer.cs
- GetImportedCardRequest.cs
- TemplateBuilder.cs
- PlanCompilerUtil.cs
- ImageAttributes.cs
- TextParagraphProperties.cs
- DefaultValueMapping.cs
- BevelBitmapEffect.cs
- ResourceManagerWrapper.cs
- CallbackHandler.cs
- XhtmlTextWriter.cs
- ScriptReferenceBase.cs
- CodeSpit.cs
- _LazyAsyncResult.cs
- DefaultSection.cs
- ScaleTransform.cs
- SqlProcedureAttribute.cs
- OleCmdHelper.cs
- BaseValidatorDesigner.cs
- DelimitedListTraceListener.cs
- ImageAutomationPeer.cs
- QueueProcessor.cs
- ControlBindingsCollection.cs
- OrderByBuilder.cs
- AssemblyHelper.cs
- GorillaCodec.cs
- SvcMapFileSerializer.cs
- SHA384.cs
- OpCellTreeNode.cs
- XhtmlBasicLiteralTextAdapter.cs
- AsyncPostBackErrorEventArgs.cs
- QuinticEase.cs
- Int16Animation.cs
- UnaryQueryOperator.cs
- DataGridViewImageCell.cs
- Viewport2DVisual3D.cs
- CheckBoxStandardAdapter.cs
- ComponentRenameEvent.cs
- DefaultShape.cs
- WebExceptionStatus.cs
- BindingSource.cs
- Int32Collection.cs
- KerberosTicketHashIdentifierClause.cs
- SimpleHandlerFactory.cs
- WebProxyScriptElement.cs
- BidOverLoads.cs
- FunctionQuery.cs
- GeometryDrawing.cs
- CreateParams.cs
- PointF.cs
- PolyQuadraticBezierSegment.cs
- InternalControlCollection.cs
- GridViewRowPresenterBase.cs
- DebugView.cs
- PowerModeChangedEventArgs.cs
- UserControlCodeDomTreeGenerator.cs
- JsonDeserializer.cs
- EasingQuaternionKeyFrame.cs
- DecimalConstantAttribute.cs
- PropertySegmentSerializationProvider.cs
- Identity.cs
- SelectionPatternIdentifiers.cs
- DoubleMinMaxAggregationOperator.cs
- IfJoinedCondition.cs
- WebPartVerbsEventArgs.cs
- BufferBuilder.cs
- TabControlDesigner.cs
- StateMachineSubscription.cs
- ConfigXmlWhitespace.cs
- RegexCompiler.cs
- MemberHolder.cs
- BooleanExpr.cs
- HttpDebugHandler.cs
- nulltextcontainer.cs
- DataServiceHost.cs
- SchemaTableColumn.cs
- InterleavedZipPartStream.cs
- ReadOnlyCollectionBase.cs
- TransformCryptoHandle.cs
- xml.cs
- HMACMD5.cs
- CacheChildrenQuery.cs
- EntityDataSourceDesignerHelper.cs