Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / XmlUtils / System / Xml / Xsl / Runtime / SiblingIterators.cs / 1 / SiblingIterators.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- using System; using System.Xml; using System.Xml.XPath; using System.Xml.Schema; using System.Diagnostics; using System.Collections; using System.ComponentModel; namespace System.Xml.Xsl.Runtime { ////// Iterate over all following-sibling content nodes. /// [EditorBrowsable(EditorBrowsableState.Never)] public struct FollowingSiblingIterator { private XmlNavigatorFilter filter; private XPathNavigator navCurrent; ////// Initialize the FollowingSiblingIterator. /// public void Create(XPathNavigator context, XmlNavigatorFilter filter) { this.navCurrent = XmlQueryRuntime.SyncToNavigator(this.navCurrent, context); this.filter = filter; } ////// Position the iterator on the next following-sibling node. Return true if such a node exists and /// set Current property. Otherwise, return false (Current property is undefined). /// public bool MoveNext() { return this.filter.MoveToFollowingSibling(this.navCurrent); } ////// Return the current result navigator. This is only defined after MoveNext() has returned true. /// public XPathNavigator Current { get { return this.navCurrent; } } } ////// Iterate over child following-sibling nodes. This is a simple variation on the ContentMergeIterator, so use containment /// to reuse its code (can't use inheritance with structures). /// [EditorBrowsable(EditorBrowsableState.Never)] public struct FollowingSiblingMergeIterator { private ContentMergeIterator wrapped; ////// Initialize the FollowingSiblingMergeIterator. /// public void Create(XmlNavigatorFilter filter) { this.wrapped.Create(filter); } ////// Position this iterator to the next content or sibling node. Return IteratorResult.NoMoreNodes if there are /// no more content or sibling nodes. Return IteratorResult.NeedInputNode if the next input node needs to be /// fetched first. Return IteratorResult.HaveCurrent if the Current property is set to the next node in the /// iteration. /// public IteratorResult MoveNext(XPathNavigator navigator) { return this.wrapped.MoveNext(navigator, false); } ////// Return the current result navigator. This is only defined after MoveNext() has returned IteratorResult.HaveCurrent. /// public XPathNavigator Current { get { return this.wrapped.Current; } } } ////// Iterate over all preceding nodes according to XPath preceding axis rules, returning nodes in reverse /// document order. /// [EditorBrowsable(EditorBrowsableState.Never)] public struct PrecedingSiblingIterator { private XmlNavigatorFilter filter; private XPathNavigator navCurrent; ////// Initialize the PrecedingSiblingIterator. /// public void Create(XPathNavigator context, XmlNavigatorFilter filter) { this.navCurrent = XmlQueryRuntime.SyncToNavigator(this.navCurrent, context); this.filter = filter; } ////// Return true if the Current property is set to the next Preceding node in reverse document order. /// public bool MoveNext() { return this.filter.MoveToPreviousSibling(this.navCurrent); } ////// Return the current result navigator. This is only defined after MoveNext() has returned true. /// public XPathNavigator Current { get { return this.navCurrent; } } } ////// Iterate over all preceding-sibling content nodes in document order. /// [EditorBrowsable(EditorBrowsableState.Never)] public struct PrecedingSiblingDocOrderIterator { private XmlNavigatorFilter filter; private XPathNavigator navCurrent, navEnd; private bool needFirst, useCompPos; ////// Initialize the PrecedingSiblingDocOrderIterator. /// public void Create(XPathNavigator context, XmlNavigatorFilter filter) { this.filter = filter; this.navCurrent = XmlQueryRuntime.SyncToNavigator(this.navCurrent, context); this.navEnd = XmlQueryRuntime.SyncToNavigator(this.navEnd, context); this.needFirst = true; // If the context node will be filtered out, then use ComparePosition to // determine when the context node has been passed by. Otherwise, IsSamePosition // is sufficient to determine when the context node has been reached. this.useCompPos = this.filter.IsFiltered(context); } ////// Position the iterator on the next preceding-sibling node. Return true if such a node exists and /// set Current property. Otherwise, return false (Current property is undefined). /// public bool MoveNext() { if (this.needFirst) { // Get first matching preceding-sibling node if (!this.navCurrent.MoveToParent()) return false; if (!this.filter.MoveToContent(this.navCurrent)) return false; this.needFirst = false; } else { // Get next matching preceding-sibling node if (!this.filter.MoveToFollowingSibling(this.navCurrent)) return false; } // Accept matching sibling only if it precedes navEnd in document order if (this.useCompPos) return (this.navCurrent.ComparePosition(this.navEnd) == XmlNodeOrder.Before); if (this.navCurrent.IsSamePosition(this.navEnd)) { // Found the original context node, so iteration is complete. If MoveNext // is called again, use ComparePosition so that false will continue to be // returned. this.useCompPos = true; return false; } return true; } ////// Return the current result navigator. This is only defined after MoveNext() has returned true. /// public XPathNavigator Current { get { return this.navCurrent; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- using System; using System.Xml; using System.Xml.XPath; using System.Xml.Schema; using System.Diagnostics; using System.Collections; using System.ComponentModel; namespace System.Xml.Xsl.Runtime { ////// Iterate over all following-sibling content nodes. /// [EditorBrowsable(EditorBrowsableState.Never)] public struct FollowingSiblingIterator { private XmlNavigatorFilter filter; private XPathNavigator navCurrent; ////// Initialize the FollowingSiblingIterator. /// public void Create(XPathNavigator context, XmlNavigatorFilter filter) { this.navCurrent = XmlQueryRuntime.SyncToNavigator(this.navCurrent, context); this.filter = filter; } ////// Position the iterator on the next following-sibling node. Return true if such a node exists and /// set Current property. Otherwise, return false (Current property is undefined). /// public bool MoveNext() { return this.filter.MoveToFollowingSibling(this.navCurrent); } ////// Return the current result navigator. This is only defined after MoveNext() has returned true. /// public XPathNavigator Current { get { return this.navCurrent; } } } ////// Iterate over child following-sibling nodes. This is a simple variation on the ContentMergeIterator, so use containment /// to reuse its code (can't use inheritance with structures). /// [EditorBrowsable(EditorBrowsableState.Never)] public struct FollowingSiblingMergeIterator { private ContentMergeIterator wrapped; ////// Initialize the FollowingSiblingMergeIterator. /// public void Create(XmlNavigatorFilter filter) { this.wrapped.Create(filter); } ////// Position this iterator to the next content or sibling node. Return IteratorResult.NoMoreNodes if there are /// no more content or sibling nodes. Return IteratorResult.NeedInputNode if the next input node needs to be /// fetched first. Return IteratorResult.HaveCurrent if the Current property is set to the next node in the /// iteration. /// public IteratorResult MoveNext(XPathNavigator navigator) { return this.wrapped.MoveNext(navigator, false); } ////// Return the current result navigator. This is only defined after MoveNext() has returned IteratorResult.HaveCurrent. /// public XPathNavigator Current { get { return this.wrapped.Current; } } } ////// Iterate over all preceding nodes according to XPath preceding axis rules, returning nodes in reverse /// document order. /// [EditorBrowsable(EditorBrowsableState.Never)] public struct PrecedingSiblingIterator { private XmlNavigatorFilter filter; private XPathNavigator navCurrent; ////// Initialize the PrecedingSiblingIterator. /// public void Create(XPathNavigator context, XmlNavigatorFilter filter) { this.navCurrent = XmlQueryRuntime.SyncToNavigator(this.navCurrent, context); this.filter = filter; } ////// Return true if the Current property is set to the next Preceding node in reverse document order. /// public bool MoveNext() { return this.filter.MoveToPreviousSibling(this.navCurrent); } ////// Return the current result navigator. This is only defined after MoveNext() has returned true. /// public XPathNavigator Current { get { return this.navCurrent; } } } ////// Iterate over all preceding-sibling content nodes in document order. /// [EditorBrowsable(EditorBrowsableState.Never)] public struct PrecedingSiblingDocOrderIterator { private XmlNavigatorFilter filter; private XPathNavigator navCurrent, navEnd; private bool needFirst, useCompPos; ////// Initialize the PrecedingSiblingDocOrderIterator. /// public void Create(XPathNavigator context, XmlNavigatorFilter filter) { this.filter = filter; this.navCurrent = XmlQueryRuntime.SyncToNavigator(this.navCurrent, context); this.navEnd = XmlQueryRuntime.SyncToNavigator(this.navEnd, context); this.needFirst = true; // If the context node will be filtered out, then use ComparePosition to // determine when the context node has been passed by. Otherwise, IsSamePosition // is sufficient to determine when the context node has been reached. this.useCompPos = this.filter.IsFiltered(context); } ////// Position the iterator on the next preceding-sibling node. Return true if such a node exists and /// set Current property. Otherwise, return false (Current property is undefined). /// public bool MoveNext() { if (this.needFirst) { // Get first matching preceding-sibling node if (!this.navCurrent.MoveToParent()) return false; if (!this.filter.MoveToContent(this.navCurrent)) return false; this.needFirst = false; } else { // Get next matching preceding-sibling node if (!this.filter.MoveToFollowingSibling(this.navCurrent)) return false; } // Accept matching sibling only if it precedes navEnd in document order if (this.useCompPos) return (this.navCurrent.ComparePosition(this.navEnd) == XmlNodeOrder.Before); if (this.navCurrent.IsSamePosition(this.navEnd)) { // Found the original context node, so iteration is complete. If MoveNext // is called again, use ComparePosition so that false will continue to be // returned. this.useCompPos = true; return false; } return true; } ////// Return the current result navigator. This is only defined after MoveNext() has returned true. /// public XPathNavigator Current { get { return this.navCurrent; } } } } // 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
- UserInitiatedNavigationPermission.cs
- Accessible.cs
- _CacheStreams.cs
- ImageListImage.cs
- ServiceDebugBehavior.cs
- Operator.cs
- AudioFileOut.cs
- TraceListeners.cs
- Stylus.cs
- PathFigureCollectionConverter.cs
- TableCell.cs
- EncodingConverter.cs
- XslTransform.cs
- BCLDebug.cs
- Setter.cs
- SecurityChannelListener.cs
- PageSetupDialog.cs
- TextElementEnumerator.cs
- RuntimeHelpers.cs
- XsdDuration.cs
- UnhandledExceptionEventArgs.cs
- Localizer.cs
- DataSourceSerializationException.cs
- DateTimeConstantAttribute.cs
- SplitterPanel.cs
- ValidationHelpers.cs
- ChainOfResponsibility.cs
- TextureBrush.cs
- PrimaryKeyTypeConverter.cs
- GraphicsPath.cs
- IgnoreSectionHandler.cs
- ClipboardData.cs
- XPathNode.cs
- ApplicationActivator.cs
- SoapAttributeOverrides.cs
- DependsOnAttribute.cs
- ipaddressinformationcollection.cs
- SQLInt16Storage.cs
- DateTimeConstantAttribute.cs
- DataConnectionHelper.cs
- HtmlControl.cs
- SecurityPermission.cs
- Missing.cs
- fixedPageContentExtractor.cs
- ServiceTimeoutsBehavior.cs
- MeshGeometry3D.cs
- TimeEnumHelper.cs
- ParserContext.cs
- PrintPreviewDialog.cs
- SingleObjectCollection.cs
- UTF7Encoding.cs
- ValueChangedEventManager.cs
- TrackingStringDictionary.cs
- MetadataArtifactLoaderResource.cs
- PenLineCapValidation.cs
- SiteIdentityPermission.cs
- DataGridViewColumnCollectionEditor.cs
- IPCCacheManager.cs
- HttpListenerException.cs
- _IPv6Address.cs
- DragSelectionMessageFilter.cs
- MergePropertyDescriptor.cs
- NavigationHelper.cs
- UIElement.cs
- RIPEMD160Managed.cs
- ButtonChrome.cs
- LogAppendAsyncResult.cs
- TableSectionStyle.cs
- FeatureSupport.cs
- ComAdminWrapper.cs
- SharedConnectionInfo.cs
- TypedServiceChannelBuilder.cs
- ConsumerConnectionPointCollection.cs
- Exceptions.cs
- CustomAttributeBuilder.cs
- FlowchartDesignerCommands.cs
- CompatibleComparer.cs
- ConditionChanges.cs
- KnownBoxes.cs
- CodeRemoveEventStatement.cs
- CompositeScriptReferenceEventArgs.cs
- DrawToolTipEventArgs.cs
- EntityTypeEmitter.cs
- cryptoapiTransform.cs
- SafeFindHandle.cs
- SqlTrackingService.cs
- IntegerValidatorAttribute.cs
- MetadataArtifactLoaderResource.cs
- RequestFactory.cs
- HostedTransportConfigurationBase.cs
- OutputCacheProfile.cs
- XmlWriter.cs
- CharAnimationUsingKeyFrames.cs
- CancelEventArgs.cs
- DBConcurrencyException.cs
- HttpFileCollection.cs
- unsafeIndexingFilterStream.cs
- DataServicePagingProviderWrapper.cs
- ComboBox.cs
- Attributes.cs