Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / Configuration / System / Configuration / SectionUpdates.cs / 1 / SectionUpdates.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Configuration { using System.Collections; // // A collection of updates to the sections that have the same location attributes. // internal class SectionUpdates { private string _name; // name of this section, for debugging private Hashtable _groups; // group name -> SectionUpdates private Hashtable _sections; // section name -> Update private int _cUnretrieved; // number of items not retrieved in update algorithm. private int _cMoved; // number of items moved (new or location attributes changed). private Update _sectionGroupUpdate; // update for this group private bool _isNew; // is the entire section new (all sections and subgroups)? internal SectionUpdates(string name) { _name = name; _groups = new Hashtable(); _sections = new Hashtable(); } internal bool IsNew { get {return _isNew;} set {_isNew = value;} } internal bool IsEmpty { get { return _groups.Count == 0 && _sections.Count == 0; } } // // Find the SectionUpdates for a configKey, and create it if it does not exist. // private SectionUpdates FindSectionUpdates(string configKey, bool isGroup) { string group, dummy; if (isGroup) { group = configKey; } else { BaseConfigurationRecord.SplitConfigKey(configKey, out group, out dummy); } Debug.Assert(String.IsNullOrEmpty(_name), "FindSectionUpdates assumes search is from root record"); SectionUpdates sectionUpdates = this; if (group.Length != 0) { // find the SectionUpdates for the group string [] groups = group.Split(BaseConfigurationRecord.ConfigPathSeparatorParams); foreach (string groupPart in groups) { SectionUpdates sectionUpdatesChild = (SectionUpdates) sectionUpdates._groups[groupPart]; if (sectionUpdatesChild == null) { sectionUpdatesChild = new SectionUpdates(groupPart); sectionUpdates._groups[groupPart] = sectionUpdatesChild; } sectionUpdates = sectionUpdatesChild; } } return sectionUpdates; } // // Recursively check whether this group has all new updates. // An update is new if all sections are new and all subgroups are new. // internal void CompleteUpdates() { bool allSubgroupsAreNew = true; // call CompleteUpdates() for all children foreach (SectionUpdates sectionUpdates in _groups.Values) { sectionUpdates.CompleteUpdates(); if (!sectionUpdates.IsNew) { allSubgroupsAreNew = false; } } _isNew = allSubgroupsAreNew && _cMoved == _sections.Count; } // // Add one update. // internal void AddSection(Update update) { SectionUpdates sectionUpdates = FindSectionUpdates(update.ConfigKey, false); sectionUpdates._sections.Add(update.ConfigKey, update); // Maintain counts. sectionUpdates._cUnretrieved++; if (update.Moved) { sectionUpdates._cMoved++; } } // // Add a section group update. // internal void AddSectionGroup(Update update) { SectionUpdates sectionUpdates = FindSectionUpdates(update.ConfigKey, true); sectionUpdates._sectionGroupUpdate = update; } // // Retrieve an update if it has not yet been retrieved. // private Update GetUpdate(string configKey) { Update update = (Update) _sections[configKey]; if (update != null) { if (update.Retrieved) { update = null; } else { update.Retrieved = true; _cUnretrieved--; if (update.Moved) { _cMoved--; } } } return update; } // // Get the update for a section group. // internal DeclarationUpdate GetSectionGroupUpdate() { if (_sectionGroupUpdate != null && !_sectionGroupUpdate.Retrieved) { _sectionGroupUpdate.Retrieved = true; return (DeclarationUpdate) _sectionGroupUpdate; } return null; } internal DefinitionUpdate GetDefinitionUpdate(string configKey) { return (DefinitionUpdate) GetUpdate(configKey); } internal DeclarationUpdate GetDeclarationUpdate(string configKey) { return (DeclarationUpdate) GetUpdate(configKey); } internal SectionUpdates GetSectionUpdatesForGroup(string group) { return (SectionUpdates) _groups[group]; } // // Return true if this section group or any of its children have unretrieved sections. // internal bool HasUnretrievedSections() { if (_cUnretrieved > 0 || (_sectionGroupUpdate != null && !_sectionGroupUpdate.Retrieved)) { return true; } foreach (SectionUpdates sectionUpdates in _groups.Values) { if (sectionUpdates.HasUnretrievedSections()) { return true; } } return false; } // // Return true if this section group contains any new section groups, false otherwise. // internal bool HasNewSectionGroups() { foreach (SectionUpdates sectionUpdates in _groups.Values) { if (sectionUpdates.IsNew) return true; } return false; } // // Return a sorted list of the names of unretrieved sections in this group. // internal string[] GetUnretrievedSectionNames() { if (_cUnretrieved == 0) return null; string[] sectionNames = new string[_cUnretrieved]; int i = 0; foreach (Update update in _sections.Values) { if (!update.Retrieved) { sectionNames[i] = update.ConfigKey; i++; } } Array.Sort(sectionNames); return sectionNames; } // // Return a sorted list of the names of moved and unretrieved sections in this group. // internal string[] GetMovedSectionNames() { if (_cMoved == 0) return null; string[] sectionNames = new string[_cMoved]; int i = 0; foreach (Update update in _sections.Values) { if (update.Moved && !update.Retrieved) { sectionNames[i] = update.ConfigKey; i++; } } Array.Sort(sectionNames); return sectionNames; } // // Return a sorted list of the names of groups with unretrieved sections. // internal string[] GetUnretrievedGroupNames() { ArrayList unretrievedGroups = new ArrayList(); foreach (DictionaryEntry de in _groups) { string group = (string) de.Key; SectionUpdates sectionUpdates = (SectionUpdates) de.Value; if (sectionUpdates.HasUnretrievedSections()) { unretrievedGroups.Add(group); } } if (unretrievedGroups.Count == 0) return null; string[] groupNames = new string[unretrievedGroups.Count]; unretrievedGroups.CopyTo(groupNames); Array.Sort(groupNames); return groupNames; } // // Return a sorted list of the names of new section groups with unretrieved sections. // internal string[] GetNewGroupNames() { ArrayList newsGroups = new ArrayList(); foreach (DictionaryEntry de in _groups) { string group = (string) de.Key; SectionUpdates sectionUpdates = (SectionUpdates) de.Value; if (sectionUpdates.IsNew && sectionUpdates.HasUnretrievedSections()) { newsGroups.Add(group); } } if (newsGroups.Count == 0) return null; string[] groupNames = new string[newsGroups.Count]; newsGroups.CopyTo(groupNames); Array.Sort(groupNames); return groupNames; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Configuration { using System.Collections; // // A collection of updates to the sections that have the same location attributes. // internal class SectionUpdates { private string _name; // name of this section, for debugging private Hashtable _groups; // group name -> SectionUpdates private Hashtable _sections; // section name -> Update private int _cUnretrieved; // number of items not retrieved in update algorithm. private int _cMoved; // number of items moved (new or location attributes changed). private Update _sectionGroupUpdate; // update for this group private bool _isNew; // is the entire section new (all sections and subgroups)? internal SectionUpdates(string name) { _name = name; _groups = new Hashtable(); _sections = new Hashtable(); } internal bool IsNew { get {return _isNew;} set {_isNew = value;} } internal bool IsEmpty { get { return _groups.Count == 0 && _sections.Count == 0; } } // // Find the SectionUpdates for a configKey, and create it if it does not exist. // private SectionUpdates FindSectionUpdates(string configKey, bool isGroup) { string group, dummy; if (isGroup) { group = configKey; } else { BaseConfigurationRecord.SplitConfigKey(configKey, out group, out dummy); } Debug.Assert(String.IsNullOrEmpty(_name), "FindSectionUpdates assumes search is from root record"); SectionUpdates sectionUpdates = this; if (group.Length != 0) { // find the SectionUpdates for the group string [] groups = group.Split(BaseConfigurationRecord.ConfigPathSeparatorParams); foreach (string groupPart in groups) { SectionUpdates sectionUpdatesChild = (SectionUpdates) sectionUpdates._groups[groupPart]; if (sectionUpdatesChild == null) { sectionUpdatesChild = new SectionUpdates(groupPart); sectionUpdates._groups[groupPart] = sectionUpdatesChild; } sectionUpdates = sectionUpdatesChild; } } return sectionUpdates; } // // Recursively check whether this group has all new updates. // An update is new if all sections are new and all subgroups are new. // internal void CompleteUpdates() { bool allSubgroupsAreNew = true; // call CompleteUpdates() for all children foreach (SectionUpdates sectionUpdates in _groups.Values) { sectionUpdates.CompleteUpdates(); if (!sectionUpdates.IsNew) { allSubgroupsAreNew = false; } } _isNew = allSubgroupsAreNew && _cMoved == _sections.Count; } // // Add one update. // internal void AddSection(Update update) { SectionUpdates sectionUpdates = FindSectionUpdates(update.ConfigKey, false); sectionUpdates._sections.Add(update.ConfigKey, update); // Maintain counts. sectionUpdates._cUnretrieved++; if (update.Moved) { sectionUpdates._cMoved++; } } // // Add a section group update. // internal void AddSectionGroup(Update update) { SectionUpdates sectionUpdates = FindSectionUpdates(update.ConfigKey, true); sectionUpdates._sectionGroupUpdate = update; } // // Retrieve an update if it has not yet been retrieved. // private Update GetUpdate(string configKey) { Update update = (Update) _sections[configKey]; if (update != null) { if (update.Retrieved) { update = null; } else { update.Retrieved = true; _cUnretrieved--; if (update.Moved) { _cMoved--; } } } return update; } // // Get the update for a section group. // internal DeclarationUpdate GetSectionGroupUpdate() { if (_sectionGroupUpdate != null && !_sectionGroupUpdate.Retrieved) { _sectionGroupUpdate.Retrieved = true; return (DeclarationUpdate) _sectionGroupUpdate; } return null; } internal DefinitionUpdate GetDefinitionUpdate(string configKey) { return (DefinitionUpdate) GetUpdate(configKey); } internal DeclarationUpdate GetDeclarationUpdate(string configKey) { return (DeclarationUpdate) GetUpdate(configKey); } internal SectionUpdates GetSectionUpdatesForGroup(string group) { return (SectionUpdates) _groups[group]; } // // Return true if this section group or any of its children have unretrieved sections. // internal bool HasUnretrievedSections() { if (_cUnretrieved > 0 || (_sectionGroupUpdate != null && !_sectionGroupUpdate.Retrieved)) { return true; } foreach (SectionUpdates sectionUpdates in _groups.Values) { if (sectionUpdates.HasUnretrievedSections()) { return true; } } return false; } // // Return true if this section group contains any new section groups, false otherwise. // internal bool HasNewSectionGroups() { foreach (SectionUpdates sectionUpdates in _groups.Values) { if (sectionUpdates.IsNew) return true; } return false; } // // Return a sorted list of the names of unretrieved sections in this group. // internal string[] GetUnretrievedSectionNames() { if (_cUnretrieved == 0) return null; string[] sectionNames = new string[_cUnretrieved]; int i = 0; foreach (Update update in _sections.Values) { if (!update.Retrieved) { sectionNames[i] = update.ConfigKey; i++; } } Array.Sort(sectionNames); return sectionNames; } // // Return a sorted list of the names of moved and unretrieved sections in this group. // internal string[] GetMovedSectionNames() { if (_cMoved == 0) return null; string[] sectionNames = new string[_cMoved]; int i = 0; foreach (Update update in _sections.Values) { if (update.Moved && !update.Retrieved) { sectionNames[i] = update.ConfigKey; i++; } } Array.Sort(sectionNames); return sectionNames; } // // Return a sorted list of the names of groups with unretrieved sections. // internal string[] GetUnretrievedGroupNames() { ArrayList unretrievedGroups = new ArrayList(); foreach (DictionaryEntry de in _groups) { string group = (string) de.Key; SectionUpdates sectionUpdates = (SectionUpdates) de.Value; if (sectionUpdates.HasUnretrievedSections()) { unretrievedGroups.Add(group); } } if (unretrievedGroups.Count == 0) return null; string[] groupNames = new string[unretrievedGroups.Count]; unretrievedGroups.CopyTo(groupNames); Array.Sort(groupNames); return groupNames; } // // Return a sorted list of the names of new section groups with unretrieved sections. // internal string[] GetNewGroupNames() { ArrayList newsGroups = new ArrayList(); foreach (DictionaryEntry de in _groups) { string group = (string) de.Key; SectionUpdates sectionUpdates = (SectionUpdates) de.Value; if (sectionUpdates.IsNew && sectionUpdates.HasUnretrievedSections()) { newsGroups.Add(group); } } if (newsGroups.Count == 0) return null; string[] groupNames = new string[newsGroups.Count]; newsGroups.CopyTo(groupNames); Array.Sort(groupNames); return groupNames; } } } // 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
- PropertyGridView.cs
- ComPlusThreadInitializer.cs
- ToolConsole.cs
- TemplateBindingExtensionConverter.cs
- AsyncStreamReader.cs
- ThousandthOfEmRealDoubles.cs
- FixUpCollection.cs
- relpropertyhelper.cs
- NoResizeSelectionBorderGlyph.cs
- VirtualDirectoryMapping.cs
- AssemblyLoader.cs
- NetworkAddressChange.cs
- FrameworkElementFactoryMarkupObject.cs
- OleDbParameterCollection.cs
- HTTPRemotingHandler.cs
- IndexerNameAttribute.cs
- DataProtection.cs
- BookmarkScope.cs
- EntityDataSource.cs
- BaseComponentEditor.cs
- wgx_exports.cs
- ViewGenerator.cs
- Cursors.cs
- TextTreeInsertElementUndoUnit.cs
- UpdatePanelControlTrigger.cs
- AsyncCompletedEventArgs.cs
- TextWriter.cs
- WebPartsPersonalizationAuthorization.cs
- UrlPath.cs
- ControlCachePolicy.cs
- RegularExpressionValidator.cs
- DiscardableAttribute.cs
- AsyncOperationManager.cs
- StorageScalarPropertyMapping.cs
- RectAnimationUsingKeyFrames.cs
- DefaultValueTypeConverter.cs
- mongolianshape.cs
- Blend.cs
- XmlTypeMapping.cs
- ByteStack.cs
- FlowDocumentPaginator.cs
- ContentPosition.cs
- DbDataReader.cs
- SortKey.cs
- DoubleLinkListEnumerator.cs
- RsaElement.cs
- PropertyRef.cs
- SettingsProperty.cs
- OledbConnectionStringbuilder.cs
- StaticResourceExtension.cs
- ControlValuePropertyAttribute.cs
- DesignerAutoFormatStyle.cs
- System.Data_BID.cs
- Quaternion.cs
- ForwardPositionQuery.cs
- AlphaSortedEnumConverter.cs
- WeakEventTable.cs
- QilTypeChecker.cs
- ClientTarget.cs
- SafeRightsManagementSessionHandle.cs
- SqlBuffer.cs
- SQLUtility.cs
- SocketInformation.cs
- DataGridViewColumnStateChangedEventArgs.cs
- BitmapMetadataBlob.cs
- MailAddress.cs
- SignatureResourcePool.cs
- InvokePattern.cs
- HttpListenerException.cs
- XPathEmptyIterator.cs
- WindowInteropHelper.cs
- WebPartZoneCollection.cs
- CodeCompiler.cs
- ContractMapping.cs
- ClassValidator.cs
- ItemsControlAutomationPeer.cs
- ObjectReaderCompiler.cs
- ProxyDataContractResolver.cs
- Events.cs
- SemanticKeyElement.cs
- ButtonBase.cs
- cookiecontainer.cs
- WhereaboutsReader.cs
- LambdaCompiler.Binary.cs
- AnimatedTypeHelpers.cs
- TextEditorMouse.cs
- AccessText.cs
- FamilyMapCollection.cs
- DataFormats.cs
- StorageMappingItemCollection.cs
- RelativeSource.cs
- DocumentViewerAutomationPeer.cs
- ListControl.cs
- MarshalDirectiveException.cs
- Int16Animation.cs
- FacetValueContainer.cs
- AtomServiceDocumentSerializer.cs
- ToolStripRenderEventArgs.cs
- ListBoxAutomationPeer.cs
- XmlUtilWriter.cs