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
- SaveFileDialog.cs
- TabControlAutomationPeer.cs
- WebContext.cs
- CachedFontFace.cs
- CounterCreationData.cs
- MachineKeySection.cs
- ServiceDesigner.cs
- CustomErrorsSection.cs
- CallSiteHelpers.cs
- BamlReader.cs
- GCHandleCookieTable.cs
- ValueExpressions.cs
- ClientBuildManagerCallback.cs
- PlacementWorkspace.cs
- NameValueSectionHandler.cs
- XmlnsDefinitionAttribute.cs
- MLangCodePageEncoding.cs
- DesignColumnCollection.cs
- UInt32Storage.cs
- PageAsyncTaskManager.cs
- Bind.cs
- StoreAnnotationsMap.cs
- QueueProcessor.cs
- RelatedCurrencyManager.cs
- MultiAsyncResult.cs
- Schema.cs
- RadioButton.cs
- SQLBinary.cs
- coordinatorfactory.cs
- TempEnvironment.cs
- Inline.cs
- GeneralTransform3DGroup.cs
- XPathSelectionIterator.cs
- Triplet.cs
- SystemIPv6InterfaceProperties.cs
- InvalidDataException.cs
- PointAnimation.cs
- TokenBasedSetEnumerator.cs
- ACL.cs
- TraceContextRecord.cs
- DropShadowEffect.cs
- FileInfo.cs
- PathSegment.cs
- FlowDocumentFormatter.cs
- PkcsMisc.cs
- Preprocessor.cs
- SequenceDesignerAccessibleObject.cs
- ResourceFallbackManager.cs
- PartitionerStatic.cs
- PageTheme.cs
- FastEncoderWindow.cs
- Object.cs
- AssemblyHash.cs
- ControlParser.cs
- FileDialog.cs
- NetCodeGroup.cs
- CategoryGridEntry.cs
- PeerToPeerException.cs
- XPathDocument.cs
- ContentFilePart.cs
- AlignmentYValidation.cs
- PlanCompilerUtil.cs
- HebrewCalendar.cs
- HttpProtocolReflector.cs
- RepeaterItemEventArgs.cs
- ObjectIDGenerator.cs
- PropertyOverridesDialog.cs
- DesignTimeParseData.cs
- RC2CryptoServiceProvider.cs
- CompositeScriptReferenceEventArgs.cs
- ExcludePathInfo.cs
- DPCustomTypeDescriptor.cs
- SemaphoreFullException.cs
- PropertyGridCommands.cs
- TreeNodeStyle.cs
- DoubleCollectionValueSerializer.cs
- Setter.cs
- SrgsElementFactory.cs
- DesignerVerb.cs
- WebControlsSection.cs
- PrinterSettings.cs
- PipelineDeploymentState.cs
- DashStyle.cs
- DispatcherOperation.cs
- WebPartUserCapability.cs
- TextParagraphProperties.cs
- SelectorItemAutomationPeer.cs
- MD5.cs
- FolderLevelBuildProviderCollection.cs
- XamlToRtfParser.cs
- DetailsViewPagerRow.cs
- AuthenticatingEventArgs.cs
- ActivationArguments.cs
- ReadOnlyDictionary.cs
- RawTextInputReport.cs
- TdsValueSetter.cs
- BoundField.cs
- BinaryObjectWriter.cs
- XmlWriter.cs
- CacheChildrenQuery.cs