Code:
/ DotNET / DotNET / 8.0 / untmp / WIN_WINDOWS / lh_tools_devdiv_wpf / Windows / wcp / Core / System / Windows / EventHandlersStore.cs / 1 / EventHandlersStore.cs
using System;
using System.Collections;
using System.Collections.Generic;
using System.Diagnostics;
using MS.Utility;
using MS.Internal.PresentationCore;
using SR=MS.Internal.PresentationCore.SR;
using SRID=MS.Internal.PresentationCore.SRID;
namespace System.Windows
{
///
/// Container for the event handlers
///
///
/// EventHandlersStore is a hashtable
/// of handlers for a given
/// EventPrivateKey or RoutedEvent
///
//CASRemoval:[StrongNameIdentityPermission(SecurityAction.LinkDemand, PublicKey = Microsoft.Internal.BuildInfo.WCP_PUBLIC_KEY_STRING)]
[FriendAccessAllowed] // Built into Core, also used by Framework.
internal class EventHandlersStore
{
#region Construction
///
/// Constructor for EventHandlersStore
///
public EventHandlersStore()
{
_entries = new FrugalMap();
}
///
/// Copy constructor for EventHandlersStore
///
public EventHandlersStore(EventHandlersStore source)
{
_entries = source._entries;
}
#endregion Construction
#region ExternalAPI
///
/// Adds a Clr event handler for the
/// given EventPrivateKey to the store
///
///
/// Private key for the event
///
///
/// Event handler
///
public void Add(EventPrivateKey key, Delegate handler)
{
if (key == null)
{
throw new ArgumentNullException("key");
}
if (handler == null)
{
throw new ArgumentNullException("handler");
}
// Get the entry corresponding to the given key
Delegate existingDelegate = (Delegate)this[key];
if (existingDelegate == null)
{
_entries[key.GlobalIndex] = handler;
}
else
{
_entries[key.GlobalIndex] = Delegate.Combine(existingDelegate, handler);
}
}
///
/// Removes an instance of the specified
/// Clr event handler for the given
/// EventPrivateKey from the store
///
///
/// Private key for the event
///
///
/// Event handler
///
///
/// NOTE: This method does nothing if no
/// matching handler instances are found
/// in the store
///
public void Remove(EventPrivateKey key, Delegate handler)
{
if (key == null)
{
throw new ArgumentNullException("key");
}
if (handler == null)
{
throw new ArgumentNullException("handler");
}
// Get the entry corresponding to the given key
Delegate existingDelegate = (Delegate) this[key];
if (existingDelegate != null)
{
existingDelegate = Delegate.Remove(existingDelegate, handler);
if (existingDelegate == null)
{
// last handler for this event was removed -- reclaim space in
// underlying FrugalMap by setting value to DependencyProperty.UnsetValue
_entries[key.GlobalIndex] = DependencyProperty.UnsetValue;
}
else
{
_entries[key.GlobalIndex] = existingDelegate;
}
}
}
///
/// Gets all the handlers for the given EventPrivateKey
///
///
/// Private key for the event
///
///
/// Combined delegate or null if no match found
///
///
/// This method is not exposing a security risk for the reason
/// that the EventPrivateKey for the events will themselves be
/// private to the declaring class. This will be enforced via fxcop rules.
///
public Delegate Get(EventPrivateKey key)
{
if (key == null)
{
throw new ArgumentNullException("key");
}
// Return the handlers corresponding to the given key
return (Delegate)this[key];
}
#endregion ExternalAPI
#region Operations
///
/// Adds a routed event handler for the given
/// RoutedEvent to the store
///
public void AddRoutedEventHandler(
RoutedEvent routedEvent,
Delegate handler,
bool handledEventsToo)
{
if (routedEvent == null)
{
throw new ArgumentNullException("routedEvent");
}
if (handler == null)
{
throw new ArgumentNullException("handler");
}
if (!routedEvent.IsLegalHandler(handler))
{
throw new ArgumentException(SR.Get(SRID.HandlerTypeIllegal));
}
// Create a new RoutedEventHandler
RoutedEventHandlerInfo routedEventHandlerInfo =
new RoutedEventHandlerInfo(handler, handledEventsToo);
// Get the entry corresponding to the given RoutedEvent
FrugalObjectList handlers = (FrugalObjectList)this[routedEvent];
if (handlers == null)
{
_entries[routedEvent.GlobalIndex] = handlers = new FrugalObjectList(1);
}
// Add the RoutedEventHandlerInfo to the list
handlers.Add(routedEventHandlerInfo);
}
///
/// Removes an instance of the specified
/// routed event handler for the given
/// RoutedEvent from the store
///
///
/// NOTE: This method does nothing if no
/// matching handler instances are found
/// in the store
///
public void RemoveRoutedEventHandler(RoutedEvent routedEvent, Delegate handler)
{
if (routedEvent == null)
{
throw new ArgumentNullException("routedEvent");
}
if (handler == null)
{
throw new ArgumentNullException("handler");
}
if (!routedEvent.IsLegalHandler(handler))
{
throw new ArgumentException(SR.Get(SRID.HandlerTypeIllegal));
}
// Get the entry corresponding to the given RoutedEvent
FrugalObjectList handlers = (FrugalObjectList)this[routedEvent];
if (handlers != null && handlers.Count > 0)
{
if ((handlers.Count == 1) && (handlers[0].Handler == handler))
{
// this is the only handler for this event and it's being removed
// reclaim space in underlying FrugalMap by setting value to
// DependencyProperty.UnsetValue
_entries[routedEvent.GlobalIndex] = DependencyProperty.UnsetValue;
}
else
{
// When a matching instance is found remove it
for (int i = 0; i < handlers.Count; i++)
{
if (handlers[i].Handler == handler)
{
handlers.RemoveAt(i);
break;
}
}
}
}
}
///
/// Determines whether the given
/// RoutedEvent exists in the store.
///
///
/// the RoutedEvent of the event.
///
public bool Contains(RoutedEvent routedEvent)
{
if (routedEvent == null)
{
throw new ArgumentNullException("routedEvent");
}
FrugalObjectList handlers = (FrugalObjectList)this[routedEvent];
return handlers != null && handlers.Count != 0;
}
private static void OnEventHandlersIterationCallback(ArrayList list, int key, object value)
{
RoutedEvent routedEvent = GlobalEventManager.EventFromGlobalIndex(key) as RoutedEvent;
if (routedEvent != null && ((FrugalObjectList)value).Count > 0)
{
list.Add(routedEvent);
}
}
///
/// Get all the event handlers in this store for the given routed event
///
public RoutedEventHandlerInfo[] GetRoutedEventHandlers(RoutedEvent routedEvent)
{
if (routedEvent == null)
{
throw new ArgumentNullException("routedEvent");
}
FrugalObjectList handlers = this[routedEvent];
if (handlers != null)
{
return handlers.ToArray();
}
return null;
}
// Returns Handlers for the given key
internal FrugalObjectList this[RoutedEvent key]
{
get
{
Debug.Assert(key != null, "Search key cannot be null");
object list = _entries[key.GlobalIndex];
if (list == DependencyProperty.UnsetValue)
{
return null;
}
else
{
return (FrugalObjectList)list;
}
}
}
internal Delegate this[EventPrivateKey key]
{
get
{
Debug.Assert(key != null, "Search key cannot be null");
object existingDelegate = _entries[key.GlobalIndex];
if (existingDelegate == DependencyProperty.UnsetValue)
{
return null;
}
else
{
return (Delegate)existingDelegate;
}
}
}
internal int Count
{
get
{
return _entries.Count;
}
}
#endregion Operations
#region Data
// Map of EventPrivateKey/RoutedEvent to Delegate/FrugalObjectList (respectively)
private FrugalMap _entries;
private static FrugalMapIterationCallback _iterationCallback = new FrugalMapIterationCallback(OnEventHandlersIterationCallback);
#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
- Mappings.cs
- DesignerInterfaces.cs
- DriveNotFoundException.cs
- XpsManager.cs
- FunctionQuery.cs
- DiscoveryClientDuplexChannel.cs
- DataServiceQueryOfT.cs
- CalendarButtonAutomationPeer.cs
- QuadraticBezierSegment.cs
- _LoggingObject.cs
- PagerSettings.cs
- MemoryRecordBuffer.cs
- DataGridViewCellFormattingEventArgs.cs
- ToolStripItemRenderEventArgs.cs
- AppDomainCompilerProxy.cs
- JoinElimination.cs
- ColorComboBox.cs
- Bezier.cs
- PrinterResolution.cs
- Native.cs
- FontNamesConverter.cs
- ByteAnimationBase.cs
- UrlMapping.cs
- StatusBarPanel.cs
- FileDialog_Vista.cs
- NativeWindow.cs
- BuildProviderCollection.cs
- TabItem.cs
- TextServicesCompartmentContext.cs
- shaperfactoryquerycachekey.cs
- ADRoleFactoryConfiguration.cs
- UrlPath.cs
- X509SecurityTokenAuthenticator.cs
- XPathChildIterator.cs
- BitmapInitialize.cs
- TypeDescriptionProviderAttribute.cs
- DataGridViewCellConverter.cs
- DataBindingExpressionBuilder.cs
- HandlerFactoryCache.cs
- TreeView.cs
- KerberosReceiverSecurityToken.cs
- AlignmentXValidation.cs
- RelatedEnd.cs
- ProcessInputEventArgs.cs
- Input.cs
- UTF32Encoding.cs
- ColorMatrix.cs
- PrintingPermissionAttribute.cs
- ConfigXmlText.cs
- ResourceProviderFactory.cs
- InvokeAction.cs
- BitmapFrameDecode.cs
- AppLevelCompilationSectionCache.cs
- ReferenceTypeElement.cs
- CoTaskMemHandle.cs
- StackSpiller.cs
- MD5CryptoServiceProvider.cs
- CompositeScriptReference.cs
- StyleSelector.cs
- SafeArchiveContext.cs
- ScriptRegistrationManager.cs
- QueryResponse.cs
- TcpTransportBindingElement.cs
- ProtocolElementCollection.cs
- TextBlock.cs
- IOThreadTimer.cs
- WebBrowserEvent.cs
- ThreadPoolTaskScheduler.cs
- LinqDataSourceHelper.cs
- CompiledQuery.cs
- InkCanvasInnerCanvas.cs
- DataGridTable.cs
- SystemFonts.cs
- basemetadatamappingvisitor.cs
- WebPartConnectionsCloseVerb.cs
- ReadOnlyDataSource.cs
- TextFindEngine.cs
- HtmlInputControl.cs
- WebPartCloseVerb.cs
- NameSpaceEvent.cs
- RequestStatusBarUpdateEventArgs.cs
- EnterpriseServicesHelper.cs
- XappLauncher.cs
- Multiply.cs
- ToolStripActionList.cs
- IsolationInterop.cs
- UriSchemeKeyedCollection.cs
- FixedStringLookup.cs
- RulePatternOps.cs
- CodeTypeConstructor.cs
- CompressionTransform.cs
- ZipIOZip64EndOfCentralDirectoryBlock.cs
- RegexGroupCollection.cs
- Scripts.cs
- ControlPager.cs
- ContentPosition.cs
- DocumentGrid.cs
- ZoneMembershipCondition.cs
- SerializationHelper.cs
- AvTraceDetails.cs