Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / XmlUtils / System / Xml / Xsl / XsltOld / OutputScopeManager.cs / 1305376 / OutputScopeManager.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- namespace System.Xml.Xsl.XsltOld { using Res = System.Xml.Utils.Res; using System; using System.Globalization; using System.Diagnostics; using System.Xml; internal class OutputScopeManager { private const int STACK_INCREMENT = 10; private HWStack elementScopesStack; private string defaultNS; private OutKeywords atoms; private XmlNameTable nameTable; private int prefixIndex; internal string DefaultNamespace { get { return this.defaultNS; } } internal OutputScope CurrentElementScope { [System.Runtime.TargetedPatchingOptOutAttribute("Performance critical to inline across NGen image boundaries")] get { Debug.Assert(this.elementScopesStack.Peek() != null); // We adding rootElementScope to garantee this return (OutputScope) this.elementScopesStack.Peek(); } } internal XmlSpace XmlSpace { get { return CurrentElementScope.Space; } } internal string XmlLang { get { return CurrentElementScope.Lang; } } internal OutputScopeManager(XmlNameTable nameTable, OutKeywords atoms) { Debug.Assert(nameTable != null); Debug.Assert(atoms != null); this.elementScopesStack = new HWStack(STACK_INCREMENT); this.nameTable = nameTable; this.atoms = atoms; this.defaultNS = this.atoms.Empty; // We always adding rootElementScope to garantee that CurrentElementScope != null // This context is active between PI and first element for example OutputScope rootElementScope = (OutputScope) this.elementScopesStack.Push(); if(rootElementScope == null) { rootElementScope = new OutputScope(); this.elementScopesStack.AddToTop(rootElementScope); } rootElementScope.Init(string.Empty, string.Empty, string.Empty, /*space:*/XmlSpace.None, /*lang:*/string.Empty, /*mixed:*/false); } internal void PushNamespace(string prefix, string nspace) { Debug.Assert(prefix != null); Debug.Assert(nspace != null); CurrentElementScope.AddNamespace(prefix, nspace, this.defaultNS); if (prefix == null || prefix.Length == 0) { this.defaultNS = nspace; } } internal void PushScope(string name, string nspace, string prefix) { Debug.Assert(name != null); Debug.Assert(nspace != null); Debug.Assert(prefix != null); OutputScope parentScope = CurrentElementScope; OutputScope elementScope = (OutputScope) this.elementScopesStack.Push(); if (elementScope == null) { elementScope = new OutputScope(); this.elementScopesStack.AddToTop(elementScope); } Debug.Assert(elementScope != null); elementScope.Init(name, nspace, prefix, parentScope.Space, parentScope.Lang, parentScope.Mixed); } internal void PopScope() { OutputScope elementScope = (OutputScope) this.elementScopesStack.Pop(); Debug.Assert(elementScope != null); // We adding rootElementScope to garantee this for (NamespaceDecl scope = elementScope.Scopes; scope != null; scope = scope.Next) { this.defaultNS = scope.PrevDefaultNsUri; } } internal string ResolveNamespace(string prefix) { bool thisScope; return ResolveNamespace(prefix, out thisScope); } internal string ResolveNamespace(string prefix, out bool thisScope) { Debug.Assert(prefix != null); thisScope = true; if (prefix == null || prefix.Length == 0) { return this.defaultNS; } else { if (Ref.Equal(prefix, this.atoms.Xml)) { return this.atoms.XmlNamespace; } else if (Ref.Equal(prefix, this.atoms.Xmlns)) { return this.atoms.XmlnsNamespace; } for (int i = this.elementScopesStack.Length - 1; i >= 0; i --) { Debug.Assert(this.elementScopesStack[i] is OutputScope); OutputScope elementScope = (OutputScope) this.elementScopesStack[i]; string nspace = elementScope.ResolveAtom(prefix); if (nspace != null) { thisScope = (i == this.elementScopesStack.Length - 1); return nspace; } } } return null; } internal bool FindPrefix(string nspace, out string prefix) { Debug.Assert(nspace != null); for (int i = this.elementScopesStack.Length - 1; 0 <= i; i--) { Debug.Assert(this.elementScopesStack[i] is OutputScope); OutputScope elementScope = (OutputScope) this.elementScopesStack[i]; string pfx = null; if (elementScope.FindPrefix(nspace, out pfx)) { string testNspace = ResolveNamespace(pfx); if(testNspace != null && Ref.Equal(testNspace, nspace)) { prefix = pfx; return true; } else { break; } } } prefix = null; return false; } internal string GeneratePrefix(string format) { string prefix; do { prefix = String.Format(CultureInfo.InvariantCulture, format, this.prefixIndex ++); }while(this.nameTable.Get(prefix) != null); return this.nameTable.Add(prefix); } } } // 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.Globalization; using System.Diagnostics; using System.Xml; internal class OutputScopeManager { private const int STACK_INCREMENT = 10; private HWStack elementScopesStack; private string defaultNS; private OutKeywords atoms; private XmlNameTable nameTable; private int prefixIndex; internal string DefaultNamespace { get { return this.defaultNS; } } internal OutputScope CurrentElementScope { [System.Runtime.TargetedPatchingOptOutAttribute("Performance critical to inline across NGen image boundaries")] get { Debug.Assert(this.elementScopesStack.Peek() != null); // We adding rootElementScope to garantee this return (OutputScope) this.elementScopesStack.Peek(); } } internal XmlSpace XmlSpace { get { return CurrentElementScope.Space; } } internal string XmlLang { get { return CurrentElementScope.Lang; } } internal OutputScopeManager(XmlNameTable nameTable, OutKeywords atoms) { Debug.Assert(nameTable != null); Debug.Assert(atoms != null); this.elementScopesStack = new HWStack(STACK_INCREMENT); this.nameTable = nameTable; this.atoms = atoms; this.defaultNS = this.atoms.Empty; // We always adding rootElementScope to garantee that CurrentElementScope != null // This context is active between PI and first element for example OutputScope rootElementScope = (OutputScope) this.elementScopesStack.Push(); if(rootElementScope == null) { rootElementScope = new OutputScope(); this.elementScopesStack.AddToTop(rootElementScope); } rootElementScope.Init(string.Empty, string.Empty, string.Empty, /*space:*/XmlSpace.None, /*lang:*/string.Empty, /*mixed:*/false); } internal void PushNamespace(string prefix, string nspace) { Debug.Assert(prefix != null); Debug.Assert(nspace != null); CurrentElementScope.AddNamespace(prefix, nspace, this.defaultNS); if (prefix == null || prefix.Length == 0) { this.defaultNS = nspace; } } internal void PushScope(string name, string nspace, string prefix) { Debug.Assert(name != null); Debug.Assert(nspace != null); Debug.Assert(prefix != null); OutputScope parentScope = CurrentElementScope; OutputScope elementScope = (OutputScope) this.elementScopesStack.Push(); if (elementScope == null) { elementScope = new OutputScope(); this.elementScopesStack.AddToTop(elementScope); } Debug.Assert(elementScope != null); elementScope.Init(name, nspace, prefix, parentScope.Space, parentScope.Lang, parentScope.Mixed); } internal void PopScope() { OutputScope elementScope = (OutputScope) this.elementScopesStack.Pop(); Debug.Assert(elementScope != null); // We adding rootElementScope to garantee this for (NamespaceDecl scope = elementScope.Scopes; scope != null; scope = scope.Next) { this.defaultNS = scope.PrevDefaultNsUri; } } internal string ResolveNamespace(string prefix) { bool thisScope; return ResolveNamespace(prefix, out thisScope); } internal string ResolveNamespace(string prefix, out bool thisScope) { Debug.Assert(prefix != null); thisScope = true; if (prefix == null || prefix.Length == 0) { return this.defaultNS; } else { if (Ref.Equal(prefix, this.atoms.Xml)) { return this.atoms.XmlNamespace; } else if (Ref.Equal(prefix, this.atoms.Xmlns)) { return this.atoms.XmlnsNamespace; } for (int i = this.elementScopesStack.Length - 1; i >= 0; i --) { Debug.Assert(this.elementScopesStack[i] is OutputScope); OutputScope elementScope = (OutputScope) this.elementScopesStack[i]; string nspace = elementScope.ResolveAtom(prefix); if (nspace != null) { thisScope = (i == this.elementScopesStack.Length - 1); return nspace; } } } return null; } internal bool FindPrefix(string nspace, out string prefix) { Debug.Assert(nspace != null); for (int i = this.elementScopesStack.Length - 1; 0 <= i; i--) { Debug.Assert(this.elementScopesStack[i] is OutputScope); OutputScope elementScope = (OutputScope) this.elementScopesStack[i]; string pfx = null; if (elementScope.FindPrefix(nspace, out pfx)) { string testNspace = ResolveNamespace(pfx); if(testNspace != null && Ref.Equal(testNspace, nspace)) { prefix = pfx; return true; } else { break; } } } prefix = null; return false; } internal string GeneratePrefix(string format) { string prefix; do { prefix = String.Format(CultureInfo.InvariantCulture, format, this.prefixIndex ++); }while(this.nameTable.Get(prefix) != null); return this.nameTable.Add(prefix); } } } // 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
- SafeCoTaskMem.cs
- Overlapped.cs
- UnsafeNativeMethods.cs
- DynamicValidatorEventArgs.cs
- LogicalTreeHelper.cs
- RichTextBoxContextMenu.cs
- ArithmeticException.cs
- DataColumnChangeEvent.cs
- PingOptions.cs
- DataGridViewCellConverter.cs
- ListViewItemCollectionEditor.cs
- PathSegment.cs
- oledbmetadatacolumnnames.cs
- PageCodeDomTreeGenerator.cs
- EventToken.cs
- NTAccount.cs
- TableParaClient.cs
- DataServices.cs
- AsyncOperationManager.cs
- DependencyPropertyChangedEventArgs.cs
- ToolBar.cs
- DataGridColumn.cs
- CodeDirectoryCompiler.cs
- assemblycache.cs
- BatchParser.cs
- InstanceKeyCollisionException.cs
- SizeConverter.cs
- InlineCollection.cs
- WithParamAction.cs
- SafeUserTokenHandle.cs
- MimeXmlReflector.cs
- TypeInfo.cs
- DesignTimeResourceProviderFactoryAttribute.cs
- OutOfMemoryException.cs
- SafeArrayTypeMismatchException.cs
- SamlSubject.cs
- TextDpi.cs
- GridViewColumnHeader.cs
- FontFamily.cs
- TouchEventArgs.cs
- NativeMethods.cs
- SoundPlayerAction.cs
- HiddenFieldPageStatePersister.cs
- WebPart.cs
- ChtmlMobileTextWriter.cs
- CapiNative.cs
- CompareValidator.cs
- XmlSchemaImporter.cs
- HttpWriter.cs
- HitTestParameters.cs
- CodeAttributeArgumentCollection.cs
- PerformanceCountersBase.cs
- SourceFilter.cs
- Property.cs
- AnnotationDocumentPaginator.cs
- FormatConvertedBitmap.cs
- ObjectStateEntryDbDataRecord.cs
- RuntimeConfig.cs
- TextLineResult.cs
- UnsafeNativeMethods.cs
- PackWebRequestFactory.cs
- XmlMtomReader.cs
- TypefaceMap.cs
- AncestorChangedEventArgs.cs
- InfoCardMetadataExchangeClient.cs
- AnimationTimeline.cs
- Relationship.cs
- HashHelper.cs
- NamedPipeProcessProtocolHandler.cs
- ConnectionPoolManager.cs
- HttpProxyCredentialType.cs
- CatalogZoneBase.cs
- IISMapPath.cs
- DataObject.cs
- AnnotationHighlightLayer.cs
- SafeProcessHandle.cs
- ParentQuery.cs
- AxHostDesigner.cs
- StringBuilder.cs
- Matrix.cs
- DataServiceContext.cs
- FullTrustAssembliesSection.cs
- PatternMatcher.cs
- TemplateBindingExtension.cs
- HyperLinkField.cs
- MetadataPropertyAttribute.cs
- AdornerDecorator.cs
- NativeCppClassAttribute.cs
- DoubleLink.cs
- PointKeyFrameCollection.cs
- XDRSchema.cs
- AbandonedMutexException.cs
- KnownTypesHelper.cs
- SelectionPatternIdentifiers.cs
- SystemColors.cs
- LicenseContext.cs
- ConvertersCollection.cs
- ZipFileInfoCollection.cs
- OutputCacheSettings.cs
- EngineSiteSapi.cs