Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / XmlUtils / System / Xml / Xsl / XsltOld / ElementAction.cs / 1305376 / 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 == XmlReservedNs.NsXmlNs) { 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, "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 != "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 (Ref.Equal(name, compiler.Atoms.Name)) { this.nameAvt = Avt.CompileAvt(compiler, value); } else if (Ref.Equal(name, compiler.Atoms.Namespace)) { this.nsAvt = Avt.CompileAvt(compiler, value); } else if (Ref.Equal(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 == XmlReservedNs.NsXmlNs) { 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, "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 != "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 (Ref.Equal(name, compiler.Atoms.Name)) { this.nameAvt = Avt.CompileAvt(compiler, value); } else if (Ref.Equal(name, compiler.Atoms.Namespace)) { this.nsAvt = Avt.CompileAvt(compiler, value); } else if (Ref.Equal(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
- EventPropertyMap.cs
- _HTTPDateParse.cs
- SoapReflectionImporter.cs
- IDictionary.cs
- NativeCompoundFileAPIs.cs
- GroupItemAutomationPeer.cs
- BypassElement.cs
- SafeFindHandle.cs
- CaseInsensitiveHashCodeProvider.cs
- ConnectorEditor.cs
- Effect.cs
- WebException.cs
- DeadCharTextComposition.cs
- EnumMemberAttribute.cs
- CaseKeyBox.xaml.cs
- BitmapDownload.cs
- VectorAnimation.cs
- AsymmetricKeyExchangeFormatter.cs
- SessionPageStateSection.cs
- ClassHandlersStore.cs
- IPEndPoint.cs
- OciHandle.cs
- SelectionPattern.cs
- UnsafeNetInfoNativeMethods.cs
- Point3DCollection.cs
- ExpressionBuilder.cs
- FlowLayoutPanelDesigner.cs
- WinEventQueueItem.cs
- ManifestSignedXml.cs
- RefreshInfo.cs
- IItemProperties.cs
- GeneralTransformCollection.cs
- IIS7UserPrincipal.cs
- EncryptedType.cs
- InputLanguageSource.cs
- SectionRecord.cs
- AutomationProperty.cs
- CodeDomConfigurationHandler.cs
- MimeMapping.cs
- DataContract.cs
- DataSourceView.cs
- SpecularMaterial.cs
- mda.cs
- HtmlInputText.cs
- GraphicsState.cs
- FlowDocumentScrollViewer.cs
- LateBoundBitmapDecoder.cs
- TransmissionStrategy.cs
- Attributes.cs
- QilGeneratorEnv.cs
- WebDisplayNameAttribute.cs
- ReferenceConverter.cs
- Margins.cs
- SecUtil.cs
- CoordinationService.cs
- WsdlBuildProvider.cs
- ConditionalAttribute.cs
- ZipIOEndOfCentralDirectoryBlock.cs
- FastPropertyAccessor.cs
- Transform.cs
- HtmlShimManager.cs
- DbConnectionPoolIdentity.cs
- TiffBitmapDecoder.cs
- PathFigure.cs
- SHA256Managed.cs
- FactoryGenerator.cs
- WebBrowserNavigatedEventHandler.cs
- DocumentManager.cs
- WebPartAuthorizationEventArgs.cs
- Helper.cs
- IxmlLineInfo.cs
- Fx.cs
- HttpApplicationStateWrapper.cs
- UpDownBase.cs
- XmlAnyAttributeAttribute.cs
- Brush.cs
- RegisteredHiddenField.cs
- RuleSettings.cs
- InvariantComparer.cs
- KeySplineConverter.cs
- JsonFaultDetail.cs
- ProvidePropertyAttribute.cs
- CustomError.cs
- BevelBitmapEffect.cs
- HierarchicalDataBoundControlAdapter.cs
- DataProtection.cs
- SocketException.cs
- HandlerMappingMemo.cs
- ChildTable.cs
- HitTestFilterBehavior.cs
- RawStylusInputReport.cs
- ClassValidator.cs
- StyleTypedPropertyAttribute.cs
- RowUpdatedEventArgs.cs
- MetadataItemEmitter.cs
- AutoGeneratedFieldProperties.cs
- RIPEMD160.cs
- XmlSchemaAttributeGroupRef.cs
- HitTestParameters.cs
- ToolboxItemCollection.cs