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
- DisplayMemberTemplateSelector.cs
- EntityDataSourceStatementEditor.cs
- DataKey.cs
- XmlEntityReference.cs
- BamlReader.cs
- InternalCache.cs
- Int64AnimationUsingKeyFrames.cs
- _HeaderInfoTable.cs
- UserControl.cs
- RegexBoyerMoore.cs
- ToolboxBitmapAttribute.cs
- EUCJPEncoding.cs
- DirectoryInfo.cs
- UpDownBase.cs
- ISAPIWorkerRequest.cs
- VBIdentifierTrimConverter.cs
- UpDownBase.cs
- HwndAppCommandInputProvider.cs
- StylusShape.cs
- OleDbTransaction.cs
- AdornerDecorator.cs
- DependencyPropertyDescriptor.cs
- TableAutomationPeer.cs
- UrlPropertyAttribute.cs
- HideDisabledControlAdapter.cs
- CapabilitiesRule.cs
- RemoteWebConfigurationHostStream.cs
- MgmtConfigurationRecord.cs
- wgx_commands.cs
- AuthenticateEventArgs.cs
- Ray3DHitTestResult.cs
- RoleManagerSection.cs
- APCustomTypeDescriptor.cs
- WeakReferenceList.cs
- ThreadAbortException.cs
- PagerStyle.cs
- ClassDataContract.cs
- MethodExpr.cs
- FontWeightConverter.cs
- ByteAnimationUsingKeyFrames.cs
- ObjectDataSource.cs
- LocatorBase.cs
- FatalException.cs
- EncoderFallback.cs
- VectorConverter.cs
- FastEncoder.cs
- MarkupWriter.cs
- ExpressionWriter.cs
- AndMessageFilter.cs
- WmpBitmapEncoder.cs
- UniformGrid.cs
- DataGridViewColumnStateChangedEventArgs.cs
- CTreeGenerator.cs
- TemplateKeyConverter.cs
- XmlFormatMapping.cs
- DefaultParameterValueAttribute.cs
- RequestValidator.cs
- CompiledQueryCacheKey.cs
- StringOutput.cs
- ValidatingPropertiesEventArgs.cs
- METAHEADER.cs
- BindingValueChangedEventArgs.cs
- BaseAppDomainProtocolHandler.cs
- AttributeXamlType.cs
- URI.cs
- XmlChildNodes.cs
- XmlSchemaSimpleContent.cs
- PriorityRange.cs
- Parameter.cs
- ConnectionStringsSection.cs
- DropShadowBitmapEffect.cs
- Predicate.cs
- DesigntimeLicenseContextSerializer.cs
- HitTestParameters3D.cs
- TypeSource.cs
- PathGradientBrush.cs
- ObjectSecurityT.cs
- RSAPKCS1KeyExchangeDeformatter.cs
- PenThreadWorker.cs
- RowTypeElement.cs
- Roles.cs
- DispatcherProcessingDisabled.cs
- IEnumerable.cs
- _TLSstream.cs
- BmpBitmapDecoder.cs
- DataGridAutoFormat.cs
- SmtpReplyReaderFactory.cs
- QilChoice.cs
- RegexGroup.cs
- XmlSchema.cs
- SafeTimerHandle.cs
- ShaperBuffers.cs
- ListViewUpdatedEventArgs.cs
- DataTable.cs
- GlyphShapingProperties.cs
- ImageSourceConverter.cs
- safesecurityhelperavalon.cs
- DynamicValueConverter.cs
- RegexRunnerFactory.cs
- PeerReferralPolicy.cs