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 / DocumentOrderComparer.cs / 1 / DocumentOrderComparer.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Xml; using System.Xml.XPath; using System.Diagnostics; namespace System.Xml.Xsl.Runtime { ////// IComparer implementation that orders navigators based on ComparePosition. When ComparePosition returns /// XmlNodeOrder.Unknown, a stable order between documents is maintained by an ordered list mapping each root node /// to an ordering index. /// internal class DocumentOrderComparer : IComparer{ private List roots; /// /// Return: /// -1 if navThis is positioned before navThat /// 0 if navThis has the same position as navThat /// 1 if navThis is positioned after navThat /// public int Compare(XPathNavigator navThis, XPathNavigator navThat) { switch (navThis.ComparePosition(navThat)) { case XmlNodeOrder.Before: return -1; case XmlNodeOrder.Same: return 0; case XmlNodeOrder.After: return 1; } // Use this.roots to impose stable ordering if (this.roots == null) this.roots = new List(); Debug.Assert(GetDocumentIndex(navThis) != GetDocumentIndex(navThat)); return GetDocumentIndex(navThis) < GetDocumentIndex(navThat) ? -1 : 1; } /// /// Map navigator's document to a unique index. /// When consecutive calls are made to GetIndexOfNavigator for navThis and navThat, it is not possible /// for them to return the same index. navThis compared to navThat is always XmlNodeOrder.Unknown. /// Therefore, no matter where navThis is inserted in the list, navThat will never be inserted just /// before navThis, and therefore will never have the same index. /// public int GetDocumentIndex(XPathNavigator nav) { XPathNavigator navRoot; // Use this.roots to impose stable ordering if (this.roots == null) this.roots = new List(); // Position navigator to root navRoot = nav.Clone(); navRoot.MoveToRoot(); for (int idx = 0; idx < this.roots.Count; idx++) { if (navRoot.IsSamePosition(this.roots[idx])) { // navigator's document was previously mapped to a unique index return idx; } } // Add navigator to this.roots mapping this.roots.Add(navRoot); return this.roots.Count - 1; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Xml; using System.Xml.XPath; using System.Diagnostics; namespace System.Xml.Xsl.Runtime { ////// IComparer implementation that orders navigators based on ComparePosition. When ComparePosition returns /// XmlNodeOrder.Unknown, a stable order between documents is maintained by an ordered list mapping each root node /// to an ordering index. /// internal class DocumentOrderComparer : IComparer{ private List roots; /// /// Return: /// -1 if navThis is positioned before navThat /// 0 if navThis has the same position as navThat /// 1 if navThis is positioned after navThat /// public int Compare(XPathNavigator navThis, XPathNavigator navThat) { switch (navThis.ComparePosition(navThat)) { case XmlNodeOrder.Before: return -1; case XmlNodeOrder.Same: return 0; case XmlNodeOrder.After: return 1; } // Use this.roots to impose stable ordering if (this.roots == null) this.roots = new List(); Debug.Assert(GetDocumentIndex(navThis) != GetDocumentIndex(navThat)); return GetDocumentIndex(navThis) < GetDocumentIndex(navThat) ? -1 : 1; } /// /// Map navigator's document to a unique index. /// When consecutive calls are made to GetIndexOfNavigator for navThis and navThat, it is not possible /// for them to return the same index. navThis compared to navThat is always XmlNodeOrder.Unknown. /// Therefore, no matter where navThis is inserted in the list, navThat will never be inserted just /// before navThis, and therefore will never have the same index. /// public int GetDocumentIndex(XPathNavigator nav) { XPathNavigator navRoot; // Use this.roots to impose stable ordering if (this.roots == null) this.roots = new List(); // Position navigator to root navRoot = nav.Clone(); navRoot.MoveToRoot(); for (int idx = 0; idx < this.roots.Count; idx++) { if (navRoot.IsSamePosition(this.roots[idx])) { // navigator's document was previously mapped to a unique index return idx; } } // Add navigator to this.roots mapping this.roots.Add(navRoot); return this.roots.Count - 1; } } } // 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
- _UriTypeConverter.cs
- View.cs
- ArrangedElement.cs
- UnsafeNativeMethods.cs
- ImportCatalogPart.cs
- TypeSource.cs
- PageParser.cs
- WebControlsSection.cs
- ThicknessAnimationBase.cs
- CodeDirectionExpression.cs
- SimpleTextLine.cs
- IxmlLineInfo.cs
- EventlogProvider.cs
- OpenTypeLayoutCache.cs
- LoginCancelEventArgs.cs
- AuthorizationContext.cs
- RuleRefElement.cs
- ToolStripDropDownItem.cs
- StyleXamlTreeBuilder.cs
- IdentityNotMappedException.cs
- elementinformation.cs
- RegexCompiler.cs
- AlternateView.cs
- MenuStrip.cs
- OleDbPropertySetGuid.cs
- DataColumnMapping.cs
- EventLogPermissionEntryCollection.cs
- TextAction.cs
- Duration.cs
- Stack.cs
- IDQuery.cs
- TextServicesManager.cs
- GPPOINTF.cs
- ProgressPage.cs
- UnsafeNativeMethodsMilCoreApi.cs
- ImageCodecInfoPrivate.cs
- PolyQuadraticBezierSegment.cs
- JpegBitmapEncoder.cs
- ErrorEventArgs.cs
- ExtensionDataReader.cs
- XmlReflectionImporter.cs
- RegistrySecurity.cs
- Attributes.cs
- Calendar.cs
- ToolStripControlHost.cs
- AndCondition.cs
- StringResourceManager.cs
- CharacterBuffer.cs
- DefaultHttpHandler.cs
- PeerContact.cs
- MemberAccessException.cs
- PointCollection.cs
- ToolStripLocationCancelEventArgs.cs
- InternalControlCollection.cs
- ShapingEngine.cs
- CellPartitioner.cs
- WorkflowQueue.cs
- HorizontalAlignConverter.cs
- JsonFormatGeneratorStatics.cs
- DescriptionCreator.cs
- DesignTimeXamlWriter.cs
- rsa.cs
- ToolboxItemCollection.cs
- GlyphTypeface.cs
- ExpressionDumper.cs
- IncrementalReadDecoders.cs
- TreeViewHitTestInfo.cs
- ContentElementAutomationPeer.cs
- HotSpot.cs
- TableRowGroup.cs
- Misc.cs
- EntitySetBaseCollection.cs
- DynamicFilter.cs
- AssociatedControlConverter.cs
- HashJoinQueryOperatorEnumerator.cs
- Rectangle.cs
- Transactions.cs
- ToolStripDropDownClosingEventArgs.cs
- KoreanLunisolarCalendar.cs
- XmlResolver.cs
- SqlDataSource.cs
- BatchParser.cs
- GeneralTransform3DCollection.cs
- ResponseStream.cs
- CodeExporter.cs
- ClassicBorderDecorator.cs
- DependencyPropertyConverter.cs
- FormViewActionList.cs
- DispatcherOperation.cs
- DecoratedNameAttribute.cs
- LocalValueEnumerator.cs
- ValueChangedEventManager.cs
- OpenFileDialog.cs
- UnionCqlBlock.cs
- TitleStyle.cs
- FontFaceLayoutInfo.cs
- DataGridColumnHeader.cs
- Mapping.cs
- MLangCodePageEncoding.cs
- SafeFileMapViewHandle.cs