Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / MS / Internal / AppModel / returneventsaver.cs / 1305600 / returneventsaver.cs
//----------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
// Description:
// This class provides a convenient way to persist/depersist the events on a PageFunction
//
// By calling the _Detach() method on a pagefunction,
// this class will build a list of the class & methods on that Pagefunction,
// as well as removing the current listener on the class when it's done.
//
// By passing in a pagefunction on the _Attach method, the class will reattach the
// saved list to the calling pagefunction
//
// History:
// 06/11/03: marka created
//
//---------------------------------------------------------------------------
using System;
using System.Windows.Navigation;
using System.Windows;
using System.Diagnostics;
using System.Collections;
using System.Reflection;
using System.IO;
using System.Security.Permissions;
using System.Security;
namespace MS.Internal.AppModel
{
[Serializable]
internal struct ReturnEventSaverInfo
{
internal ReturnEventSaverInfo(string delegateTypeName, string targetTypeName, string delegateMethodName, bool fSamePf)
{
_delegateTypeName = delegateTypeName;
_targetTypeName = targetTypeName;
_delegateMethodName = delegateMethodName;
_delegateInSamePF = fSamePf;
}
internal String _delegateTypeName;
internal String _targetTypeName;
internal String _delegateMethodName;
internal bool _delegateInSamePF; // Return Event handler comes from the same pagefunction, this is for non-generic workaround.
}
[Serializable]
internal class ReturnEventSaver
{
internal ReturnEventSaver()
{
}
///
/// Critical - sets the critical _returnList.
/// TreatAsSafe - _returnList is not exposed in any way.
///
[SecurityCritical, SecurityTreatAsSafe]
internal void _Detach(PageFunctionBase pf)
{
if (pf._Return != null && pf._Saver == null)
{
ReturnEventSaverInfo[] list = null;
Delegate[] delegates = null;
delegates = (pf._Return).GetInvocationList();
list = _returnList = new ReturnEventSaverInfo[delegates.Length];
for (int i = 0; i < delegates.Length; i++)
{
Delegate returnDelegate = delegates[i];
bool bSamePf = false;
if (returnDelegate.Target == pf)
{
// This is the Event Handler implemented by the same PF, use for NonGeneric handling.
bSamePf = true;
}
MethodInfo m = returnDelegate.Method;
ReturnEventSaverInfo info = new ReturnEventSaverInfo(
returnDelegate.GetType().AssemblyQualifiedName,
returnDelegate.Target.GetType().AssemblyQualifiedName,
m.Name, bSamePf);
list[i] = info;
}
//
// only save if there were delegates already attached.
// note that there will be cases where the Saver has already been pre-populated from a Load
// but no delegates have been created yet ( as the PF hasn`t called finish as yet)
//
// By only storing the saver once there are delegates - we avoid the problem of
// wiping out any newly restored saver
pf._Saver = this;
}
pf._DetachEvents();
}
//
// Attach the stored events to the supplied pagefunction.
//
// caller - the Calling Page's root element. We will reattach events *from* this page root element *to* the child
//
// child - the child PageFunction. Caller was originally attached to child, we're now reattaching *to* the child
//
///
/// Critical - Asserts ReflectionPermission to be able re-create delegate to private method.
/// TreatAsSafe - The delegate created is identical to the one that _Detach() received from
/// the application and saved. This is ensured by matching the type of the original target
/// object against the type of the new target. Thus we know that the application was able
/// to create a delegate over the exact method, and even if that method had a LinkDemand,
/// it was satisfied by the application.
///
[SecurityCritical, SecurityTreatAsSafe]
internal void _Attach(Object caller, PageFunctionBase child)
{
ReturnEventSaverInfo[] list = null;
list = _returnList;
if (list != null)
{
Debug.Assert(caller != null, "Caller should not be null");
for (int i = 0; i < list.Length; i++)
{
//
//
if (string.Compare(_returnList[i]._targetTypeName, caller.GetType().AssemblyQualifiedName, StringComparison.Ordinal) != 0)
{
throw new NotSupportedException(SR.Get(SRID.ReturnEventHandlerMustBeOnParentPage));
}
Delegate d;
try
{
new ReflectionPermission(ReflectionPermissionFlag.MemberAccess).Assert(); // BlessedAssert
d = Delegate.CreateDelegate(
Type.GetType(_returnList[i]._delegateTypeName),
caller,
_returnList[i]._delegateMethodName);
}
catch (Exception ex)
{
throw new NotSupportedException(SR.Get(SRID.ReturnEventHandlerMustBeOnParentPage), ex);
}
finally
{
ReflectionPermission.RevertAssert();
}
child._AddEventHandler(d);
}
}
}
///
/// Critical: contains metadata for delegates created under elevation.
///
[SecurityCritical]
private ReturnEventSaverInfo[] _returnList; // The list of delegates we want to persist and return later
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
//----------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
// Description:
// This class provides a convenient way to persist/depersist the events on a PageFunction
//
// By calling the _Detach() method on a pagefunction,
// this class will build a list of the class & methods on that Pagefunction,
// as well as removing the current listener on the class when it's done.
//
// By passing in a pagefunction on the _Attach method, the class will reattach the
// saved list to the calling pagefunction
//
// History:
// 06/11/03: marka created
//
//---------------------------------------------------------------------------
using System;
using System.Windows.Navigation;
using System.Windows;
using System.Diagnostics;
using System.Collections;
using System.Reflection;
using System.IO;
using System.Security.Permissions;
using System.Security;
namespace MS.Internal.AppModel
{
[Serializable]
internal struct ReturnEventSaverInfo
{
internal ReturnEventSaverInfo(string delegateTypeName, string targetTypeName, string delegateMethodName, bool fSamePf)
{
_delegateTypeName = delegateTypeName;
_targetTypeName = targetTypeName;
_delegateMethodName = delegateMethodName;
_delegateInSamePF = fSamePf;
}
internal String _delegateTypeName;
internal String _targetTypeName;
internal String _delegateMethodName;
internal bool _delegateInSamePF; // Return Event handler comes from the same pagefunction, this is for non-generic workaround.
}
[Serializable]
internal class ReturnEventSaver
{
internal ReturnEventSaver()
{
}
///
/// Critical - sets the critical _returnList.
/// TreatAsSafe - _returnList is not exposed in any way.
///
[SecurityCritical, SecurityTreatAsSafe]
internal void _Detach(PageFunctionBase pf)
{
if (pf._Return != null && pf._Saver == null)
{
ReturnEventSaverInfo[] list = null;
Delegate[] delegates = null;
delegates = (pf._Return).GetInvocationList();
list = _returnList = new ReturnEventSaverInfo[delegates.Length];
for (int i = 0; i < delegates.Length; i++)
{
Delegate returnDelegate = delegates[i];
bool bSamePf = false;
if (returnDelegate.Target == pf)
{
// This is the Event Handler implemented by the same PF, use for NonGeneric handling.
bSamePf = true;
}
MethodInfo m = returnDelegate.Method;
ReturnEventSaverInfo info = new ReturnEventSaverInfo(
returnDelegate.GetType().AssemblyQualifiedName,
returnDelegate.Target.GetType().AssemblyQualifiedName,
m.Name, bSamePf);
list[i] = info;
}
//
// only save if there were delegates already attached.
// note that there will be cases where the Saver has already been pre-populated from a Load
// but no delegates have been created yet ( as the PF hasn`t called finish as yet)
//
// By only storing the saver once there are delegates - we avoid the problem of
// wiping out any newly restored saver
pf._Saver = this;
}
pf._DetachEvents();
}
//
// Attach the stored events to the supplied pagefunction.
//
// caller - the Calling Page's root element. We will reattach events *from* this page root element *to* the child
//
// child - the child PageFunction. Caller was originally attached to child, we're now reattaching *to* the child
//
///
/// Critical - Asserts ReflectionPermission to be able re-create delegate to private method.
/// TreatAsSafe - The delegate created is identical to the one that _Detach() received from
/// the application and saved. This is ensured by matching the type of the original target
/// object against the type of the new target. Thus we know that the application was able
/// to create a delegate over the exact method, and even if that method had a LinkDemand,
/// it was satisfied by the application.
///
[SecurityCritical, SecurityTreatAsSafe]
internal void _Attach(Object caller, PageFunctionBase child)
{
ReturnEventSaverInfo[] list = null;
list = _returnList;
if (list != null)
{
Debug.Assert(caller != null, "Caller should not be null");
for (int i = 0; i < list.Length; i++)
{
//
//
if (string.Compare(_returnList[i]._targetTypeName, caller.GetType().AssemblyQualifiedName, StringComparison.Ordinal) != 0)
{
throw new NotSupportedException(SR.Get(SRID.ReturnEventHandlerMustBeOnParentPage));
}
Delegate d;
try
{
new ReflectionPermission(ReflectionPermissionFlag.MemberAccess).Assert(); // BlessedAssert
d = Delegate.CreateDelegate(
Type.GetType(_returnList[i]._delegateTypeName),
caller,
_returnList[i]._delegateMethodName);
}
catch (Exception ex)
{
throw new NotSupportedException(SR.Get(SRID.ReturnEventHandlerMustBeOnParentPage), ex);
}
finally
{
ReflectionPermission.RevertAssert();
}
child._AddEventHandler(d);
}
}
}
///
/// Critical: contains metadata for delegates created under elevation.
///
[SecurityCritical]
private ReturnEventSaverInfo[] _returnList; // The list of delegates we want to persist and return later
}
}
// 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
- HttpWebResponse.cs
- StreamGeometry.cs
- CacheSection.cs
- AnnotationAuthorChangedEventArgs.cs
- ObjectSecurity.cs
- CodeIterationStatement.cs
- Camera.cs
- SiteMapDataSourceView.cs
- HttpRuntime.cs
- XmlRootAttribute.cs
- AppearanceEditorPart.cs
- DataPagerFieldCollection.cs
- NativeObjectSecurity.cs
- SqlTrackingQuery.cs
- UriExt.cs
- DataGridViewColumnTypeEditor.cs
- FamilyMap.cs
- DbConnectionFactory.cs
- TypeConverterHelper.cs
- MasterPageBuildProvider.cs
- KnownTypeAttribute.cs
- VersionConverter.cs
- TextInfo.cs
- HttpModulesSection.cs
- StrokeDescriptor.cs
- ContentElementAutomationPeer.cs
- UIAgentRequest.cs
- ScrollItemPatternIdentifiers.cs
- DeobfuscatingStream.cs
- InputLanguageCollection.cs
- FlowDocumentPageViewerAutomationPeer.cs
- ObjectFactoryCodeDomTreeGenerator.cs
- MenuAdapter.cs
- DataObjectEventArgs.cs
- KnownBoxes.cs
- TypeUtils.cs
- NetworkInterface.cs
- PrintPreviewControl.cs
- CheckPair.cs
- Exception.cs
- translator.cs
- SoapAttributeAttribute.cs
- FileFormatException.cs
- QueryCursorEventArgs.cs
- BufferedStream2.cs
- TextTreeFixupNode.cs
- WebPartDisplayModeCancelEventArgs.cs
- TimeSpanStorage.cs
- CodePageEncoding.cs
- SHA256.cs
- DeviceFilterEditorDialog.cs
- XpsPackagingException.cs
- CompiledScopeCriteria.cs
- ScriptingProfileServiceSection.cs
- InheritanceContextChangedEventManager.cs
- MasterPageCodeDomTreeGenerator.cs
- LineUtil.cs
- WebPartAddingEventArgs.cs
- RuntimeVariablesExpression.cs
- SecurityHelper.cs
- RealProxy.cs
- login.cs
- CompilationRelaxations.cs
- NonClientArea.cs
- CodeTypeParameter.cs
- webclient.cs
- XmlSchemaType.cs
- ExpressionValueEditor.cs
- WebPartMenu.cs
- PrePostDescendentsWalker.cs
- WebPartAuthorizationEventArgs.cs
- FixedDocument.cs
- MDIControlStrip.cs
- followingquery.cs
- ReadOnlyCollectionBase.cs
- BamlBinaryWriter.cs
- SpeechAudioFormatInfo.cs
- QuadraticBezierSegment.cs
- ImplicitInputBrush.cs
- ModifiableIteratorCollection.cs
- TemplateControlCodeDomTreeGenerator.cs
- RequestTimeoutManager.cs
- ISAPIRuntime.cs
- Switch.cs
- HttpContextBase.cs
- TreeNodeCollection.cs
- PriorityItem.cs
- DataBoundLiteralControl.cs
- OutputCacheProfileCollection.cs
- SiteMapHierarchicalDataSourceView.cs
- GradientBrush.cs
- BoolExpr.cs
- BevelBitmapEffect.cs
- DataFormats.cs
- TTSEngineProxy.cs
- ValueProviderWrapper.cs
- InfoCardRSAOAEPKeyExchangeFormatter.cs
- FieldTemplateFactory.cs
- SqlTriggerContext.cs
- CounterCreationData.cs