Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / untmp / whidbey / QFE / ndp / fx / src / Xml / System / Xml / XPath / Internal / precedingsibling.cs / 1 / precedingsibling.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- namespace MS.Internal.Xml.XPath { using System; using System.Xml; using System.Xml.XPath; using System.Diagnostics; using System.Collections.Generic; // This class can be rewritten much more efficient. // Algorithm could be like one for FollowingSibling: // - Build InputArrays: pares (first, sentinel) // -- Cash all input nodes as sentinel // -- Add firts node of its parent for each input node. // -- Sort these pares by first nodes. // - Advance algorithm will look like: // -- For each row in InputArays we will output first node + all its following nodes which are < sentinel // -- Before outputing each node in row #I we will internal class PreSiblingQuery : CacheAxisQuery { public PreSiblingQuery(Query qyInput, string name, string prefix, XPathNodeType typeTest) : base (qyInput, name, prefix, typeTest) {} protected PreSiblingQuery(PreSiblingQuery other) : base(other) {} private bool NotVisited(XPathNavigator nav, ListparentStk){ XPathNavigator nav1 = nav.Clone(); nav1.MoveToParent(); for (int i = 0; i < parentStk.Count; i++) { if (nav1.IsSamePosition(parentStk[i])) { return false; } } parentStk.Add(nav1); return true; } public override object Evaluate(XPathNodeIterator context) { base.Evaluate(context); // Fill up base.outputBuffer List parentStk = new List (); Stack inputStk = new Stack (); while ((currentNode = qyInput.Advance()) != null) { inputStk.Push(currentNode.Clone()); } while (inputStk.Count != 0) { XPathNavigator input = inputStk.Pop(); if (input.NodeType == XPathNodeType.Attribute || input.NodeType == XPathNodeType.Namespace) { continue; } if (NotVisited(input, parentStk)) { XPathNavigator prev = input.Clone(); if (prev.MoveToParent()) { bool test = prev.MoveToFirstChild(); Debug.Assert(test, "We just moved to parent, how we can not have first child?"); while (!prev.IsSamePosition(input)) { if (matches(prev)) { Insert(outputBuffer, prev); } if (!prev.MoveToNext()) { Debug.Fail("We managed to miss sentinel node (input)"); break; } } } } } return this; } public override XPathNodeIterator Clone() { return new PreSiblingQuery(this); } public override QueryProps Properties { get { return base.Properties | QueryProps.Reverse; } } } } // 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
- DbConnectionOptions.cs
- StringArrayConverter.cs
- SystemResources.cs
- UpDownBase.cs
- Peer.cs
- X509SecurityToken.cs
- TextServicesHost.cs
- SchemaCollectionCompiler.cs
- PTUtility.cs
- SQLDecimal.cs
- GroupBox.cs
- WizardStepBase.cs
- DependencyPropertyKey.cs
- GridLength.cs
- FullTextBreakpoint.cs
- DNS.cs
- VirtualPath.cs
- ToolStripItemGlyph.cs
- PatternMatcher.cs
- OletxTransactionManager.cs
- Base64Stream.cs
- ConfigurationValue.cs
- TogglePattern.cs
- InvalidWMPVersionException.cs
- DataObjectFieldAttribute.cs
- CodeDelegateInvokeExpression.cs
- CLSCompliantAttribute.cs
- EncryptedPackageFilter.cs
- GridViewCellAutomationPeer.cs
- XpsException.cs
- SystemInformation.cs
- PropertyGridEditorPart.cs
- BasicKeyConstraint.cs
- DeviceFilterDictionary.cs
- Documentation.cs
- CornerRadius.cs
- ProcessHost.cs
- DataRecordInternal.cs
- AdPostCacheSubstitution.cs
- LinqMaximalSubtreeNominator.cs
- MemoryPressure.cs
- ColorKeyFrameCollection.cs
- AsymmetricSignatureDeformatter.cs
- SqlEnums.cs
- Int16Converter.cs
- MarkupExtensionReturnTypeAttribute.cs
- DrawingImage.cs
- ClientFormsIdentity.cs
- OutOfProcStateClientManager.cs
- TextureBrush.cs
- bindurihelper.cs
- ObjectCloneHelper.cs
- SafeJobHandle.cs
- ColumnMapProcessor.cs
- Win32Exception.cs
- UnsupportedPolicyOptionsException.cs
- RectangleF.cs
- OracleBoolean.cs
- XmlDataDocument.cs
- IDReferencePropertyAttribute.cs
- SizeChangedInfo.cs
- ProfessionalColors.cs
- ArraySegment.cs
- WebHttpBehavior.cs
- ArrayEditor.cs
- ReversePositionQuery.cs
- LineServicesCallbacks.cs
- SpecularMaterial.cs
- EntityDataSourceState.cs
- DocumentViewer.cs
- MetaData.cs
- XmlQueryTypeFactory.cs
- BinHexEncoder.cs
- LabelAutomationPeer.cs
- NativeMethods.cs
- EventLogPermissionHolder.cs
- XslCompiledTransform.cs
- PropertyValidationContext.cs
- BoundField.cs
- TextProperties.cs
- PolyQuadraticBezierSegment.cs
- DynamicMethod.cs
- DocumentPageViewAutomationPeer.cs
- SingleAnimation.cs
- CatalogPartCollection.cs
- dataprotectionpermission.cs
- ControlCachePolicy.cs
- EntityContainerEmitter.cs
- ForeignKeyConstraint.cs
- DataTableMappingCollection.cs
- SignatureDescription.cs
- FunctionParameter.cs
- DocumentPageViewAutomationPeer.cs
- CategoriesDocumentFormatter.cs
- CodePropertyReferenceExpression.cs
- SystemNetworkInterface.cs
- ImageKeyConverter.cs
- BinaryCommonClasses.cs
- ItemType.cs
- JapaneseLunisolarCalendar.cs