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 / ProcessingInstructionAction.cs / 1 / ProcessingInstructionAction.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 ProcessingInstructionAction : ContainerAction { private const int NameEvaluated = 2; private const int NameReady = 3; private Avt nameAvt; // Compile time precalculated AVT private string name; private const char CharX = 'X'; private const char Charx = 'x'; private const char CharM = 'M'; private const char Charm = 'm'; private const char CharL = 'L'; private const char Charl = 'l'; internal ProcessingInstructionAction() {} internal override void Compile(Compiler compiler) { CompileAttributes(compiler); CheckRequiredAttribute(compiler, this.nameAvt, Keywords.s_Name); if(this.nameAvt.IsConstant) { this.name = this.nameAvt.Evaluate(null, null); this.nameAvt = null; if (! IsProcessingInstructionName(this.name)) { // For Now: set to null to ignore action late; this.name = null; } } if (compiler.Recurse()) { CompileTemplate(compiler); compiler.ToParent(); } } 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 { 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.nameAvt == null) { frame.StoredOutput = this.name; if(this.name == null) { // name was static but was bad; frame.Finished(); break; } } else { frame.StoredOutput = this.nameAvt.Evaluate(processor, frame); if (! IsProcessingInstructionName(frame.StoredOutput)) { frame.Finished(); break; } } goto case NameReady; case NameReady: Debug.Assert(frame.StoredOutput != null); if (processor.BeginEvent(XPathNodeType.ProcessingInstruction, string.Empty, frame.StoredOutput, string.Empty, false) == false) { // Come back later frame.State = NameReady; break; } processor.PushActionFrame(frame); frame.State = ProcessingChildren; break; // Allow children to run case ProcessingChildren: if (processor.EndEvent(XPathNodeType.ProcessingInstruction) == false) { frame.State = ProcessingChildren; break; } frame.Finished(); break; default: Debug.Fail("Invalid ElementAction execution state"); frame.Finished(); break; } } internal static bool IsProcessingInstructionName(string name) { if (name == null) { return false; } int nameLength = name.Length; int position = 0; XmlCharType xmlCharType = XmlCharType.Instance; while (position < nameLength && xmlCharType.IsWhiteSpace(name[position])) { position ++; } if (position >= nameLength) { return false; } if (position < nameLength && ! xmlCharType.IsStartNCNameChar(name[position])) { return false; } while (position < nameLength && xmlCharType.IsNCNameChar(name[position])) { position ++; } while (position < nameLength && xmlCharType.IsWhiteSpace(name[position])) { position ++; } if (position < nameLength) { return false; } if (nameLength == 3 && (name[0] == CharX || name[0] == Charx) && (name[1] == CharM || name[1] == Charm) && (name[2] == CharL || name[2] == Charl) ) { return false; } return true; } } } // 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 ProcessingInstructionAction : ContainerAction { private const int NameEvaluated = 2; private const int NameReady = 3; private Avt nameAvt; // Compile time precalculated AVT private string name; private const char CharX = 'X'; private const char Charx = 'x'; private const char CharM = 'M'; private const char Charm = 'm'; private const char CharL = 'L'; private const char Charl = 'l'; internal ProcessingInstructionAction() {} internal override void Compile(Compiler compiler) { CompileAttributes(compiler); CheckRequiredAttribute(compiler, this.nameAvt, Keywords.s_Name); if(this.nameAvt.IsConstant) { this.name = this.nameAvt.Evaluate(null, null); this.nameAvt = null; if (! IsProcessingInstructionName(this.name)) { // For Now: set to null to ignore action late; this.name = null; } } if (compiler.Recurse()) { CompileTemplate(compiler); compiler.ToParent(); } } 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 { 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.nameAvt == null) { frame.StoredOutput = this.name; if(this.name == null) { // name was static but was bad; frame.Finished(); break; } } else { frame.StoredOutput = this.nameAvt.Evaluate(processor, frame); if (! IsProcessingInstructionName(frame.StoredOutput)) { frame.Finished(); break; } } goto case NameReady; case NameReady: Debug.Assert(frame.StoredOutput != null); if (processor.BeginEvent(XPathNodeType.ProcessingInstruction, string.Empty, frame.StoredOutput, string.Empty, false) == false) { // Come back later frame.State = NameReady; break; } processor.PushActionFrame(frame); frame.State = ProcessingChildren; break; // Allow children to run case ProcessingChildren: if (processor.EndEvent(XPathNodeType.ProcessingInstruction) == false) { frame.State = ProcessingChildren; break; } frame.Finished(); break; default: Debug.Fail("Invalid ElementAction execution state"); frame.Finished(); break; } } internal static bool IsProcessingInstructionName(string name) { if (name == null) { return false; } int nameLength = name.Length; int position = 0; XmlCharType xmlCharType = XmlCharType.Instance; while (position < nameLength && xmlCharType.IsWhiteSpace(name[position])) { position ++; } if (position >= nameLength) { return false; } if (position < nameLength && ! xmlCharType.IsStartNCNameChar(name[position])) { return false; } while (position < nameLength && xmlCharType.IsNCNameChar(name[position])) { position ++; } while (position < nameLength && xmlCharType.IsWhiteSpace(name[position])) { position ++; } if (position < nameLength) { return false; } if (nameLength == 3 && (name[0] == CharX || name[0] == Charx) && (name[1] == CharM || name[1] == Charm) && (name[2] == CharL || name[2] == Charl) ) { return false; } return true; } } } // 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
- UserControl.cs
- NamespaceMapping.cs
- UnsafeNativeMethods.cs
- ChoiceConverter.cs
- WebPartActionVerb.cs
- StylusShape.cs
- MetabaseSettingsIis7.cs
- ClientSession.cs
- EntityContainerEntitySetDefiningQuery.cs
- BamlCollectionHolder.cs
- LinqDataSourceHelper.cs
- AuthenticatedStream.cs
- EncryptedPackageFilter.cs
- CodeDelegateInvokeExpression.cs
- DesignerSerializationOptionsAttribute.cs
- IPHostEntry.cs
- ProxyAttribute.cs
- CapabilitiesAssignment.cs
- TextPointer.cs
- MsdtcClusterUtils.cs
- ApplicationGesture.cs
- FunctionDefinition.cs
- WsdlInspector.cs
- EllipticalNodeOperations.cs
- AssemblySettingAttributes.cs
- LookupNode.cs
- WeakEventManager.cs
- SafeProcessHandle.cs
- BooleanConverter.cs
- ObsoleteAttribute.cs
- TransformProviderWrapper.cs
- CounterCreationData.cs
- TextControlDesigner.cs
- BaseProcessor.cs
- EncodingNLS.cs
- MarkupObject.cs
- formatter.cs
- _TimerThread.cs
- EncoderFallback.cs
- LongAverageAggregationOperator.cs
- GetPageCompletedEventArgs.cs
- BridgeDataRecord.cs
- RectangleF.cs
- ControlBuilder.cs
- ScrollChangedEventArgs.cs
- UrlAuthFailedErrorFormatter.cs
- WindowsNonControl.cs
- ScalarConstant.cs
- DnsEndpointIdentity.cs
- WindowsSolidBrush.cs
- CallbackHandler.cs
- FontUnit.cs
- SystemThemeKey.cs
- XamlTreeBuilder.cs
- SHA512Managed.cs
- PrintPageEvent.cs
- RSAPKCS1SignatureDeformatter.cs
- SHA256Managed.cs
- TreeViewBindingsEditorForm.cs
- DatePickerTextBox.cs
- Set.cs
- GridView.cs
- ColumnCollection.cs
- TimeZone.cs
- TabletDevice.cs
- DiscoveryClientReferences.cs
- RayHitTestParameters.cs
- ErrorFormatter.cs
- WebBrowser.cs
- FixedTextView.cs
- ClipboardProcessor.cs
- ManipulationPivot.cs
- FontInfo.cs
- TypeFieldSchema.cs
- Schema.cs
- SafeEventLogWriteHandle.cs
- SEHException.cs
- RouteValueDictionary.cs
- SystemIPGlobalStatistics.cs
- Matrix3D.cs
- EdmToObjectNamespaceMap.cs
- TextEditorContextMenu.cs
- GeometryDrawing.cs
- URLBuilder.cs
- _SSPISessionCache.cs
- BinaryConverter.cs
- RandomDelaySendsAsyncResult.cs
- StateMachineWorkflowInstance.cs
- MobileCapabilities.cs
- GridViewEditEventArgs.cs
- EpmCustomContentWriterNodeData.cs
- Int32AnimationBase.cs
- BitmapEffectInput.cs
- HttpFileCollectionWrapper.cs
- ListViewCancelEventArgs.cs
- ProtocolsConfiguration.cs
- WindowsHyperlink.cs
- TextBoxAutomationPeer.cs
- DataBoundControlHelper.cs
- StaticTextPointer.cs