Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / XmlUtils / System / Xml / Xsl / XsltOld / ElementAction.cs / 1 / ElementAction.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- namespace System.Xml.Xsl.XsltOld { using Res = System.Xml.Utils.Res; using System; using System.Diagnostics; using System.Xml; using System.Xml.XPath; internal class ElementAction : ContainerAction { private const int NameDone = 2; private Avt nameAvt; private Avt nsAvt; private bool empty; private InputScopeManager manager; // Compile time precalculated AVTs private string name; private string nsUri; private PrefixQName qname; // When we not have AVTs at all we can do this. null otherwise. internal ElementAction() {} private static PrefixQName CreateElementQName(string name, string nsUri, InputScopeManager manager) { if (nsUri == Keywords.s_XmlnsNamespace) { throw XsltException.Create(Res.Xslt_ReservedNS, nsUri); } PrefixQName qname = new PrefixQName(); qname.SetQName(name); if (nsUri == null) { qname.Namespace = manager.ResolveXmlNamespace(qname.Prefix); } else { qname.Namespace = nsUri; } return qname; } internal override void Compile(Compiler compiler) { CompileAttributes(compiler); CheckRequiredAttribute(compiler, this.nameAvt, Keywords.s_Name); this.name = PrecalculateAvt(ref this.nameAvt); this.nsUri = PrecalculateAvt(ref this.nsAvt ); // if both name and ns are not AVT we can calculate qname at compile time and will not need namespace manager anymore if (this.nameAvt == null && this.nsAvt == null) { if(this.name != Keywords.s_Xmlns) { this.qname = CreateElementQName(this.name, this.nsUri, compiler.CloneScopeManager()); } } else { this.manager = compiler.CloneScopeManager(); } if (compiler.Recurse()) { Debug.Assert(this.empty == false); CompileTemplate(compiler); compiler.ToParent(); } this.empty = (this.containedActions == null) ; } internal override bool CompileAttribute(Compiler compiler) { string name = compiler.Input.LocalName; string value = compiler.Input.Value; if (Keywords.Equals(name, compiler.Atoms.Name)) { this.nameAvt = Avt.CompileAvt(compiler, value); } else if (Keywords.Equals(name, compiler.Atoms.Namespace)) { this.nsAvt = Avt.CompileAvt(compiler, value); } else if (Keywords.Equals(name, compiler.Atoms.UseAttributeSets)) { AddAction(compiler.CreateUseAttributeSetsAction()); } else { return false; } return true; } internal override void Execute(Processor processor, ActionFrame frame) { Debug.Assert(processor != null && frame != null); switch (frame.State) { case Initialized: if(this.qname != null) { frame.CalulatedName = this.qname; } else { frame.CalulatedName = CreateElementQName( this.nameAvt == null ? this.name : this.nameAvt.Evaluate(processor, frame), this.nsAvt == null ? this.nsUri : this.nsAvt .Evaluate(processor, frame), this.manager ); } goto case NameDone; case NameDone: { PrefixQName qname = frame.CalulatedName; if (processor.BeginEvent(XPathNodeType.Element, qname.Prefix, qname.Name, qname.Namespace, this.empty) == false) { // Come back later frame.State = NameDone; break; } if (! this.empty) { processor.PushActionFrame(frame); frame.State = ProcessingChildren; break; // Allow children to run } else { goto case ProcessingChildren; } } case ProcessingChildren: if (processor.EndEvent(XPathNodeType.Element) == false) { frame.State = ProcessingChildren; break; } frame.Finished(); break; default: Debug.Fail("Invalid ElementAction execution state"); break; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- namespace System.Xml.Xsl.XsltOld { using Res = System.Xml.Utils.Res; using System; using System.Diagnostics; using System.Xml; using System.Xml.XPath; internal class ElementAction : ContainerAction { private const int NameDone = 2; private Avt nameAvt; private Avt nsAvt; private bool empty; private InputScopeManager manager; // Compile time precalculated AVTs private string name; private string nsUri; private PrefixQName qname; // When we not have AVTs at all we can do this. null otherwise. internal ElementAction() {} private static PrefixQName CreateElementQName(string name, string nsUri, InputScopeManager manager) { if (nsUri == Keywords.s_XmlnsNamespace) { throw XsltException.Create(Res.Xslt_ReservedNS, nsUri); } PrefixQName qname = new PrefixQName(); qname.SetQName(name); if (nsUri == null) { qname.Namespace = manager.ResolveXmlNamespace(qname.Prefix); } else { qname.Namespace = nsUri; } return qname; } internal override void Compile(Compiler compiler) { CompileAttributes(compiler); CheckRequiredAttribute(compiler, this.nameAvt, Keywords.s_Name); this.name = PrecalculateAvt(ref this.nameAvt); this.nsUri = PrecalculateAvt(ref this.nsAvt ); // if both name and ns are not AVT we can calculate qname at compile time and will not need namespace manager anymore if (this.nameAvt == null && this.nsAvt == null) { if(this.name != Keywords.s_Xmlns) { this.qname = CreateElementQName(this.name, this.nsUri, compiler.CloneScopeManager()); } } else { this.manager = compiler.CloneScopeManager(); } if (compiler.Recurse()) { Debug.Assert(this.empty == false); CompileTemplate(compiler); compiler.ToParent(); } this.empty = (this.containedActions == null) ; } internal override bool CompileAttribute(Compiler compiler) { string name = compiler.Input.LocalName; string value = compiler.Input.Value; if (Keywords.Equals(name, compiler.Atoms.Name)) { this.nameAvt = Avt.CompileAvt(compiler, value); } else if (Keywords.Equals(name, compiler.Atoms.Namespace)) { this.nsAvt = Avt.CompileAvt(compiler, value); } else if (Keywords.Equals(name, compiler.Atoms.UseAttributeSets)) { AddAction(compiler.CreateUseAttributeSetsAction()); } else { return false; } return true; } internal override void Execute(Processor processor, ActionFrame frame) { Debug.Assert(processor != null && frame != null); switch (frame.State) { case Initialized: if(this.qname != null) { frame.CalulatedName = this.qname; } else { frame.CalulatedName = CreateElementQName( this.nameAvt == null ? this.name : this.nameAvt.Evaluate(processor, frame), this.nsAvt == null ? this.nsUri : this.nsAvt .Evaluate(processor, frame), this.manager ); } goto case NameDone; case NameDone: { PrefixQName qname = frame.CalulatedName; if (processor.BeginEvent(XPathNodeType.Element, qname.Prefix, qname.Name, qname.Namespace, this.empty) == false) { // Come back later frame.State = NameDone; break; } if (! this.empty) { processor.PushActionFrame(frame); frame.State = ProcessingChildren; break; // Allow children to run } else { goto case ProcessingChildren; } } case ProcessingChildren: if (processor.EndEvent(XPathNodeType.Element) == false) { frame.State = ProcessingChildren; break; } frame.Finished(); break; default: Debug.Fail("Invalid ElementAction execution state"); break; } } } } // 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
- DataGridViewRowHeaderCell.cs
- HostSecurityManager.cs
- TextBox.cs
- ScriptModule.cs
- DependencySource.cs
- DataControlFieldCollection.cs
- BatchParser.cs
- sqlcontext.cs
- Compiler.cs
- BitmapCacheBrush.cs
- WebBrowserSiteBase.cs
- DataGridViewRowCancelEventArgs.cs
- SymmetricKey.cs
- DecimalAnimation.cs
- WindowsPrincipal.cs
- ScopedMessagePartSpecification.cs
- SystemThemeKey.cs
- Brush.cs
- LineSegment.cs
- FileDialogCustomPlacesCollection.cs
- TraceInternal.cs
- XmlSchemaSequence.cs
- TextBoxAutomationPeer.cs
- PageFunction.cs
- QilXmlWriter.cs
- Light.cs
- TabItemWrapperAutomationPeer.cs
- XpsFixedDocumentReaderWriter.cs
- Version.cs
- ArrangedElement.cs
- DbParameterHelper.cs
- ItemContainerProviderWrapper.cs
- DataGridColumnCollectionEditor.cs
- SchemaTableOptionalColumn.cs
- _ServiceNameStore.cs
- DataReceivedEventArgs.cs
- MdiWindowListItemConverter.cs
- Compilation.cs
- BordersPage.cs
- ServiceKnownTypeAttribute.cs
- WebReferencesBuildProvider.cs
- ClockGroup.cs
- SerializationInfoEnumerator.cs
- ComPlusContractBehavior.cs
- TextDecorationLocationValidation.cs
- DoubleCollectionConverter.cs
- ObjectStateEntryOriginalDbUpdatableDataRecord.cs
- XPathDocumentBuilder.cs
- RawStylusInputReport.cs
- BigInt.cs
- Debug.cs
- MimeFormImporter.cs
- WebChannelFactory.cs
- DataGridTableCollection.cs
- WinFormsComponentEditor.cs
- DtrList.cs
- WorkflowInstanceExtensionCollection.cs
- Model3DGroup.cs
- HyperLinkField.cs
- NavigationProgressEventArgs.cs
- ReadWriteObjectLock.cs
- ToolbarAUtomationPeer.cs
- FlowDocumentView.cs
- LinqDataSourceDisposeEventArgs.cs
- CngUIPolicy.cs
- BufferBuilder.cs
- XmlException.cs
- ModelPerspective.cs
- QilName.cs
- ObjectConverter.cs
- Binding.cs
- ProcessHostServerConfig.cs
- WebBrowserEvent.cs
- EntityException.cs
- MasterPageCodeDomTreeGenerator.cs
- DocumentStream.cs
- KeyNotFoundException.cs
- StylusButtonEventArgs.cs
- WebBrowserHelper.cs
- SystemDiagnosticsSection.cs
- TemplateEditingVerb.cs
- MemoryFailPoint.cs
- BrowserCapabilitiesFactoryBase.cs
- CompilerResults.cs
- wgx_render.cs
- SplitterPanel.cs
- DataSourceProvider.cs
- TextParagraphView.cs
- ToolStripGrip.cs
- AutomationAttributeInfo.cs
- GenericUriParser.cs
- Assert.cs
- WebPartMovingEventArgs.cs
- SqlBooleanMismatchVisitor.cs
- Win32Exception.cs
- CustomDictionarySources.cs
- ConfigXmlWhitespace.cs
- ParameterCollection.cs
- LogSwitch.cs
- EventWaitHandleSecurity.cs