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 / Xslt / KeyMatchBuilder.cs / 1 / KeyMatchBuilder.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- using System; using System.Diagnostics; using System.Collections; using System.Collections.Generic; using System.Xml; using System.Xml.XPath; using MS.Internal.Xml; using System.Xml.Xsl.XPath; using System.Xml.Xsl.Qil; namespace System.Xml.Xsl.Xslt { internal class KeyMatchBuilder : XPathBuilder, XPathPatternParser.IPatternBuilder { private int depth = 0; PathConvertor convertor; public KeyMatchBuilder(IXPathEnvironment env) : base(env) { convertor = new PathConvertor(env.Factory); } public override void StartBuild() { Debug.Assert(0 <= depth && depth <= 1, "this shouldn't happen"); if (depth == 0) { base.StartBuild(); } depth ++; } public override QilNode EndBuild(QilNode result) { depth --; Debug.Assert(0 <= depth && depth <= 1, "this shouldn't happen"); if (result == null) { // special door to clean builder state in exception handlers return base.EndBuild(result); } if (depth == 0) { Debug.Assert(base.numFixupLast == 0); Debug.Assert(base.numFixupPosition == 0); result = convertor.ConvertReletive2Absolute(result, base.fixupCurrent); result = base.EndBuild(result); } return result; } // -------------------------------------- GetPredicateBuilder() --------------------------------------- public virtual IXPathBuilderGetPredicateBuilder(QilNode ctx) { return this; } // This code depends on particula shapes that XPathBuilder generates. // It works only on pathes. // ToDo: We can do better here. internal class PathConvertor : QilReplaceVisitor { new XPathQilFactory f; QilNode fixup; public PathConvertor(XPathQilFactory f) : base (f.BaseFactory) { this.f = f; } public QilNode ConvertReletive2Absolute(QilNode node, QilNode fixup) { Debug.Assert(node != null); Debug.Assert(fixup != null); this.fixup = fixup; return this.Visit(node); } // transparantly passing through Union and DocOrder protected override QilNode Visit(QilNode n) { if ( n.NodeType == QilNodeType.Union || n.NodeType == QilNodeType.DocOrderDistinct || n.NodeType == QilNodeType.Filter || n.NodeType == QilNodeType.Loop ) { return base.Visit(n); } return n; } // Filers that travers Content being converted to global travers: // Filter($j= ... Filter($i = Content(fixup), ...)) -> Filter($j= ... Filter($i = Loop($j = DesendentOrSelf(Root(fixup)), Content($j), ...))) protected override QilNode VisitLoop(QilLoop n) { if (n.Variable.Binding.NodeType == QilNodeType.Root || n.Variable.Binding.NodeType == QilNodeType.Deref) { // This is absolute path already. We shouldn't touch it return n; } if (n.Variable.Binding.NodeType == QilNodeType.Content) { // This is "begin" of reletive path. Let's rewrite it as absolute: QilUnary content = (QilUnary)n.Variable.Binding; Debug.Assert(content.Child == this.fixup, "Unexpected content node"); QilIterator it = f.For(f.DescendantOrSelf(f.Root(this.fixup))); content.Child = it; n.Variable.Binding = f.Loop(it, content); return n; } n.Variable.Binding = Visit(n.Variable.Binding); return n; } protected override QilNode VisitFilter(QilLoop n) { return VisitLoop(n); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- using System; using System.Diagnostics; using System.Collections; using System.Collections.Generic; using System.Xml; using System.Xml.XPath; using MS.Internal.Xml; using System.Xml.Xsl.XPath; using System.Xml.Xsl.Qil; namespace System.Xml.Xsl.Xslt { internal class KeyMatchBuilder : XPathBuilder, XPathPatternParser.IPatternBuilder { private int depth = 0; PathConvertor convertor; public KeyMatchBuilder(IXPathEnvironment env) : base(env) { convertor = new PathConvertor(env.Factory); } public override void StartBuild() { Debug.Assert(0 <= depth && depth <= 1, "this shouldn't happen"); if (depth == 0) { base.StartBuild(); } depth ++; } public override QilNode EndBuild(QilNode result) { depth --; Debug.Assert(0 <= depth && depth <= 1, "this shouldn't happen"); if (result == null) { // special door to clean builder state in exception handlers return base.EndBuild(result); } if (depth == 0) { Debug.Assert(base.numFixupLast == 0); Debug.Assert(base.numFixupPosition == 0); result = convertor.ConvertReletive2Absolute(result, base.fixupCurrent); result = base.EndBuild(result); } return result; } // -------------------------------------- GetPredicateBuilder() --------------------------------------- public virtual IXPathBuilderGetPredicateBuilder(QilNode ctx) { return this; } // This code depends on particula shapes that XPathBuilder generates. // It works only on pathes. // ToDo: We can do better here. internal class PathConvertor : QilReplaceVisitor { new XPathQilFactory f; QilNode fixup; public PathConvertor(XPathQilFactory f) : base (f.BaseFactory) { this.f = f; } public QilNode ConvertReletive2Absolute(QilNode node, QilNode fixup) { Debug.Assert(node != null); Debug.Assert(fixup != null); this.fixup = fixup; return this.Visit(node); } // transparantly passing through Union and DocOrder protected override QilNode Visit(QilNode n) { if ( n.NodeType == QilNodeType.Union || n.NodeType == QilNodeType.DocOrderDistinct || n.NodeType == QilNodeType.Filter || n.NodeType == QilNodeType.Loop ) { return base.Visit(n); } return n; } // Filers that travers Content being converted to global travers: // Filter($j= ... Filter($i = Content(fixup), ...)) -> Filter($j= ... Filter($i = Loop($j = DesendentOrSelf(Root(fixup)), Content($j), ...))) protected override QilNode VisitLoop(QilLoop n) { if (n.Variable.Binding.NodeType == QilNodeType.Root || n.Variable.Binding.NodeType == QilNodeType.Deref) { // This is absolute path already. We shouldn't touch it return n; } if (n.Variable.Binding.NodeType == QilNodeType.Content) { // This is "begin" of reletive path. Let's rewrite it as absolute: QilUnary content = (QilUnary)n.Variable.Binding; Debug.Assert(content.Child == this.fixup, "Unexpected content node"); QilIterator it = f.For(f.DescendantOrSelf(f.Root(this.fixup))); content.Child = it; n.Variable.Binding = f.Loop(it, content); return n; } n.Variable.Binding = Visit(n.Variable.Binding); return n; } protected override QilNode VisitFilter(QilLoop n) { return VisitLoop(n); } } } } // 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
- DependencyObjectCodeDomSerializer.cs
- BaseTypeViewSchema.cs
- ProgressiveCrcCalculatingStream.cs
- ObjectParameter.cs
- TextElement.cs
- TabControlCancelEvent.cs
- EntityDataSourceMemberPath.cs
- GCHandleCookieTable.cs
- BridgeDataReader.cs
- TagMapCollection.cs
- TitleStyle.cs
- NameValueSectionHandler.cs
- JsonServiceDocumentSerializer.cs
- SchemaNames.cs
- XmlAttributeCache.cs
- StringExpressionSet.cs
- AssemblySettingAttributes.cs
- AttachmentCollection.cs
- Storyboard.cs
- LinkClickEvent.cs
- VisualBasicHelper.cs
- XmlWrappingReader.cs
- SecurityToken.cs
- AttachedPropertyInfo.cs
- FixedPageAutomationPeer.cs
- IconConverter.cs
- GridItemCollection.cs
- RuntimeHelpers.cs
- AppDomainUnloadedException.cs
- ReadOnlyHierarchicalDataSourceView.cs
- ITextView.cs
- FileDialog.cs
- ADMembershipUser.cs
- MsmqVerifier.cs
- ExceptionRoutedEventArgs.cs
- XDRSchema.cs
- MetadataArtifactLoaderCompositeResource.cs
- UrlMapping.cs
- DependentList.cs
- ItemCheckedEvent.cs
- DrawingGroup.cs
- DefaultWorkflowLoaderService.cs
- PackageStore.cs
- BrowserCapabilitiesCompiler.cs
- RtfToken.cs
- QueryAccessibilityHelpEvent.cs
- NavigatorInput.cs
- CompilerError.cs
- DataControlExtensions.cs
- X509ThumbprintKeyIdentifierClause.cs
- HwndHost.cs
- DirectoryRootQuery.cs
- CompatibleComparer.cs
- HitTestParameters.cs
- MethodBuilder.cs
- SvcMapFileSerializer.cs
- DocumentReference.cs
- PropertyRecord.cs
- UpdatePanelTriggerCollection.cs
- Table.cs
- MetadataArtifactLoaderResource.cs
- ImmutableCollection.cs
- TriggerCollection.cs
- ButtonBase.cs
- StubHelpers.cs
- SqlUserDefinedAggregateAttribute.cs
- WindowsPrincipal.cs
- GrammarBuilderBase.cs
- WindowsSlider.cs
- DefaultPerformanceCounters.cs
- COM2FontConverter.cs
- Matrix3D.cs
- IndentedWriter.cs
- XmlWriterDelegator.cs
- ApplicationSettingsBase.cs
- LinkLabelLinkClickedEvent.cs
- VirtualDirectoryMappingCollection.cs
- Compensation.cs
- RequestChannelBinder.cs
- KeyValuePair.cs
- FtpWebRequest.cs
- UTF7Encoding.cs
- arabicshape.cs
- Vector.cs
- SetIndexBinder.cs
- ExpressionPrinter.cs
- baseaxisquery.cs
- RemotingConfigParser.cs
- CatalogZone.cs
- InputLanguageEventArgs.cs
- DynamicEndpoint.cs
- ToolStripDropDownClosingEventArgs.cs
- ItemsControlAutomationPeer.cs
- OpCodes.cs
- Grant.cs
- BamlWriter.cs
- BamlRecordWriter.cs
- Tablet.cs
- DetailsViewPagerRow.cs
- BCLDebug.cs