Code:
/ DotNET / DotNET / 8.0 / untmp / WIN_WINDOWS / lh_tools_devdiv_wpf / Windows / wcp / Framework / System / Windows / TemplateNameScope.cs / 1 / TemplateNameScope.cs
/****************************************************************************\
*
* File: TemplateNameScope.cs
*
* Used to store mapping information for names occuring
* within the template content section.
*
* Copyright (C) 2005 by Microsoft Corporation. All rights reserved.
*
\***************************************************************************/
using System;
using System.Diagnostics;
using MS.Internal;
using MS.Utility;
using System.Collections.Generic;
using System.Collections.Specialized;
using System.Collections;
using System.Windows.Markup;
namespace System.Windows
{
//+-----------------------------------------------------------------------------
//
// Class TemplateNameScope
//
// This class implements the name scope that is used for template content
// (i.e. that which is applied to each templated parent, not the template itself).
// During apply (except for FEF-based templates), this is the INameScope to which the BamlRecordReader
// calls. We take those opportunities to hook up FEs and FCEs (e.g.
// with the TemplatedParent pointer). After apply, this services
// FindName requests.
//
//+-----------------------------------------------------------------------------
internal class TemplateNameScope : INameScope
{
#region Constructors
// This constructor builds a name scope that just supports lookup.
// This is used for FEF-based templates.
internal TemplateNameScope(DependencyObject templatedParent)
: this( templatedParent, null, null, null )
{
}
internal TemplateNameScope(
DependencyObject templatedParent,
List affectedChildren,
UncommonField templatedNonFeChildrenField,
FrameworkTemplate frameworkTemplate )
{
Debug.Assert(templatedParent == null || (templatedParent is FrameworkElement || templatedParent is FrameworkContentElement),
"Templates are only supported on FE/FCE containers.");
_affectedChildren = affectedChildren;
_templatedNonFeChildrenField = templatedNonFeChildrenField;
_frameworkTemplate = frameworkTemplate;
_templatedParent = templatedParent;
_isTemplatedParentAnFE = true;
}
#endregion Constructors
#region INameScope
///
/// Registers the name - element combination
///
/// Name of the element
/// Element where name is defined
void INameScope.RegisterName(string name, object scopedElement)
{
FrameworkElement fe;
FrameworkContentElement fce;
Helper.DowncastToFEorFCE( scopedElement as DependencyObject,
out fe, out fce,
false /*throwIfNeither*/ );
int childIndex;
// First, though, do we actually have a templated parent? If not,
// then we'll just set the properties directly on the element
// (this is the serialization scenario).
if( _templatedParent == null )
{
// No, we don't have a templated parent. Loop through
// the shared values (assuming this is an FE/FCE), and set them
// directly onto the element.
if( fe != null || fce != null )
{
SetTemplateParentValues( name, scopedElement );
}
}
// We have a templated parent, but is this not a FE/FCE?
else if (fe == null && fce == null)
{
// All we need to do is update the _templatedNonFeChildren list
Hashtable nonFeChildren = _templatedNonFeChildrenField.GetValue(_templatedParent);
if (nonFeChildren == null)
{
nonFeChildren = new Hashtable(1);
_templatedNonFeChildrenField.SetValue(_templatedParent, nonFeChildren);
}
nonFeChildren[name] = scopedElement;
}
// Otherwise, we need to hook this FE/FCE up to the template.
else
{
// Update the list on the templated parent of the named FE/FCEs.
_affectedChildren.Add(scopedElement as DependencyObject);
// Update the TemplatedParent, IsTemplatedParentAnFE, and TemplateChildIndex.
if( fe != null )
{
fe._templatedParent = _templatedParent;
fe.IsTemplatedParentAnFE = _isTemplatedParentAnFE;
childIndex = fe.TemplateChildIndex = (int) _frameworkTemplate._childIndexFromChildName[name];
}
else
{
fce._templatedParent = _templatedParent;
fce.IsTemplatedParentAnFE = _isTemplatedParentAnFE;
childIndex = fce.TemplateChildIndex = (int) _frameworkTemplate._childIndexFromChildName[name];
}
// Make updates for the Loaded/Unloaded event listeners (if they're set).
HybridDictionary templateChildLoadedDictionary = _frameworkTemplate._TemplateChildLoadedDictionary;
FrameworkTemplate.TemplateChildLoadedFlags templateChildLoadedFlags
= templateChildLoadedDictionary[ childIndex ] as FrameworkTemplate.TemplateChildLoadedFlags;
if( templateChildLoadedFlags != null )
{
if( templateChildLoadedFlags.HasLoadedChangedHandler || templateChildLoadedFlags.HasUnloadedChangedHandler )
{
BroadcastEventHelper.AddHasLoadedChangeHandlerFlagInAncestry((fe != null) ? (DependencyObject)fe : (DependencyObject)fce);
}
}
// Establish databinding instance data.
StyleHelper.CreateInstanceDataForChild(
StyleHelper.TemplateDataField,
_templatedParent,
(fe!=null) ? (DependencyObject)fe : (DependencyObject)fce,
childIndex,
_frameworkTemplate.HasInstanceValues,
ref _frameworkTemplate.ChildRecordFromChildIndex);
}
}
///
/// Unregisters the name - element combination
///
/// Name of the element
void INameScope.UnregisterName(string name)
{
Debug.Assert(false, "Should never be trying to unregister via this interface for templates");
}
///
/// Find the element given name
///
object INameScope.FindName(string name)
{
FrameworkObject fo = new FrameworkObject(_templatedParent);
// _templatedParent is null if template.LoadContent() was responsible
Debug.Assert(_templatedParent == null || fo.IsFE);
if (fo.IsFE)
{
return StyleHelper.FindNameInTemplateContent(fo.FE, name, fo.FE.TemplateInternal);
}
else
{
return null;
}
}
#endregion INameScope
//+---------------------------------------------------------------------------------------------------------------
//
// SetTemplateParentValues
//
// This method takes the "template parent values" (those that look like local values in the template), which
// are ordinarily shared, and sets them as local values on the FE/FCE that was just created. This is used
// during serialization.
//
//+----------------------------------------------------------------------------------------------------------------
private void SetTemplateParentValues( string name, object element )
{
FrameworkTemplate.SetTemplateParentValues( name, element, _frameworkTemplate, ref _provideValueServiceProvider );
}
#region Data
// This is a HybridDictionary of Name->FE(FCE) mappings
private List _affectedChildren;
// This is the table of Name->NonFE mappings
private UncommonField _templatedNonFeChildrenField;
// The templated parent we're instantiating for
private DependencyObject _templatedParent;
// The template we're instantiating
private FrameworkTemplate _frameworkTemplate;
// Is templated parent an FE or an FCE?
private bool _isTemplatedParentAnFE;
ProvideValueServiceProvider _provideValueServiceProvider;
#endregion Data
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- GeneralTransform3DCollection.cs
- indexingfiltermarshaler.cs
- PenContexts.cs
- GeometryDrawing.cs
- WindowsClientCredential.cs
- OdbcDataAdapter.cs
- OleDbCommandBuilder.cs
- AtlasWeb.Designer.cs
- MultiSelectRootGridEntry.cs
- XamlStyleSerializer.cs
- FormView.cs
- FormClosingEvent.cs
- InnerItemCollectionView.cs
- VirtualPathProvider.cs
- FixedSOMLineCollection.cs
- SecurityHeaderTokenResolver.cs
- Drawing.cs
- Models.cs
- NavigationService.cs
- OTFRasterizer.cs
- Socket.cs
- StylusLogic.cs
- Vector3dCollection.cs
- LinqDataSourceView.cs
- ApplyTemplatesAction.cs
- ClientBuildManagerCallback.cs
- Int32CollectionValueSerializer.cs
- SQLBinaryStorage.cs
- MimeTypeAttribute.cs
- ConfigurationManagerInternal.cs
- EdmMember.cs
- ProcessHostConfigUtils.cs
- TransformerConfigurationWizardBase.cs
- XmlObjectSerializerWriteContextComplex.cs
- EmptyEnumerator.cs
- AuthStoreRoleProvider.cs
- IconConverter.cs
- DataServiceRequest.cs
- PanelStyle.cs
- XPathScanner.cs
- TitleStyle.cs
- UncommonField.cs
- RMEnrollmentPage2.cs
- FormsAuthenticationUserCollection.cs
- DataGridComponentEditor.cs
- WebException.cs
- Thumb.cs
- SendActivity.cs
- CngAlgorithmGroup.cs
- XmlLanguage.cs
- DockEditor.cs
- DBSchemaTable.cs
- Executor.cs
- UriTemplateHelpers.cs
- FlowDocument.cs
- XmlAttributeCollection.cs
- CheckBoxPopupAdapter.cs
- Registry.cs
- Menu.cs
- XmlUTF8TextWriter.cs
- XsltFunctions.cs
- Grid.cs
- TTSVoice.cs
- AppModelKnownContentFactory.cs
- BooleanAnimationUsingKeyFrames.cs
- ViewBox.cs
- ArrayElementGridEntry.cs
- SingleAnimation.cs
- PackWebResponse.cs
- TreeBuilderXamlTranslator.cs
- ValidatorCompatibilityHelper.cs
- RtfToken.cs
- JournalEntry.cs
- AsymmetricSignatureDeformatter.cs
- storepermission.cs
- HttpFileCollectionBase.cs
- SerializationException.cs
- ConnectionPoint.cs
- PathGeometry.cs
- ToolStripContainerActionList.cs
- XpsColorContext.cs
- LoginCancelEventArgs.cs
- SearchExpression.cs
- WriteTimeStream.cs
- ExpandCollapseProviderWrapper.cs
- TypeExtensionConverter.cs
- StretchValidation.cs
- ReadOnlyHierarchicalDataSourceView.cs
- SimpleHandlerFactory.cs
- KeyboardDevice.cs
- IImplicitResourceProvider.cs
- DataGridColumnHeaderItemAutomationPeer.cs
- EnvironmentPermission.cs
- SqlCommandSet.cs
- TimeSpanStorage.cs
- DocumentSignatureManager.cs
- MessageTransmitTraceRecord.cs
- MetadataExporter.cs
- XmlResolver.cs
- _SingleItemRequestCache.cs