Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / 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
- HostingPreferredMapPath.cs
- TemplatedMailWebEventProvider.cs
- PasswordBoxAutomationPeer.cs
- ArglessEventHandlerProxy.cs
- __ConsoleStream.cs
- XmlCharType.cs
- AuthenticationConfig.cs
- RijndaelManaged.cs
- XsltCompileContext.cs
- SqlMethodAttribute.cs
- WindowsToolbar.cs
- SqlError.cs
- Color.cs
- StrongNameUtility.cs
- KeyTime.cs
- VersionedStreamOwner.cs
- WebPartConnectVerb.cs
- SingleTagSectionHandler.cs
- Assembly.cs
- ClientConfigPaths.cs
- TextAction.cs
- WebPartTransformerAttribute.cs
- NewArrayExpression.cs
- GraphicsState.cs
- MetadataItemEmitter.cs
- NamespaceInfo.cs
- GPRECT.cs
- EnumBuilder.cs
- KnownBoxes.cs
- DataGridCellAutomationPeer.cs
- CharAnimationUsingKeyFrames.cs
- PropertyPath.cs
- SrgsOneOf.cs
- SqlAliaser.cs
- AdapterUtil.cs
- WriteStateInfoBase.cs
- EntityModelSchemaGenerator.cs
- QuaternionAnimation.cs
- RoleServiceManager.cs
- LocatorBase.cs
- HandlerFactoryWrapper.cs
- Byte.cs
- StoreAnnotationsMap.cs
- DefaultHttpHandler.cs
- MulticastNotSupportedException.cs
- EncryptedType.cs
- PersonalizableAttribute.cs
- ObjectParameter.cs
- ClientConfigurationHost.cs
- CallbackCorrelationInitializer.cs
- WindowsTokenRoleProvider.cs
- DownloadProgressEventArgs.cs
- SamlAssertionKeyIdentifierClause.cs
- SqlDataSourceSelectingEventArgs.cs
- AttributeSetAction.cs
- SystemWebSectionGroup.cs
- SqlDesignerDataSourceView.cs
- MD5CryptoServiceProvider.cs
- AttachedPropertyBrowsableForTypeAttribute.cs
- DataGridTable.cs
- HtmlInputReset.cs
- XPathNodeHelper.cs
- PropertyDescriptors.cs
- SystemIPGlobalProperties.cs
- TimeZone.cs
- CreateCardRequest.cs
- PropertyReferenceExtension.cs
- ToolboxItem.cs
- TextElementEnumerator.cs
- TabItemWrapperAutomationPeer.cs
- BooleanSwitch.cs
- TextMetrics.cs
- DataBoundControlActionList.cs
- ArrayTypeMismatchException.cs
- DbExpressionVisitor_TResultType.cs
- IndexerNameAttribute.cs
- DataPointer.cs
- SHA512CryptoServiceProvider.cs
- LogArchiveSnapshot.cs
- HMACSHA512.cs
- httpstaticobjectscollection.cs
- SystemIcmpV6Statistics.cs
- XmlAnyElementAttributes.cs
- UnsafeNativeMethods.cs
- DataTemplateSelector.cs
- GridViewRow.cs
- ErrorInfoXmlDocument.cs
- MarkupWriter.cs
- TransactionState.cs
- ToolZoneDesigner.cs
- CapabilitiesAssignment.cs
- WsatStrings.cs
- EventPropertyMap.cs
- DiscoveryInnerClientAdhocCD1.cs
- KeyFrames.cs
- FixedSchema.cs
- SessionPageStateSection.cs
- OverflowException.cs
- Rijndael.cs
- WebPartCloseVerb.cs