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
- HierarchicalDataBoundControlAdapter.cs
- RectValueSerializer.cs
- ArrangedElementCollection.cs
- HtmlEmptyTagControlBuilder.cs
- FixedPosition.cs
- MouseGestureValueSerializer.cs
- QueryContinueDragEvent.cs
- AbandonedMutexException.cs
- DbProviderServices.cs
- NamespaceList.cs
- Atom10ItemFormatter.cs
- AuthenticationConfig.cs
- GestureRecognizer.cs
- XmlToDatasetMap.cs
- SignatureToken.cs
- X509AsymmetricSecurityKey.cs
- IpcPort.cs
- parserscommon.cs
- CodeBlockBuilder.cs
- MdiWindowListStrip.cs
- MergeExecutor.cs
- WebPartHeaderCloseVerb.cs
- LineBreakRecord.cs
- DbParameterHelper.cs
- ZoneLinkButton.cs
- Identity.cs
- QueryOperationResponseOfT.cs
- RelatedImageListAttribute.cs
- WebHttpDispatchOperationSelector.cs
- DataGridTextBox.cs
- ADRole.cs
- SettingsPropertyCollection.cs
- PolyQuadraticBezierSegment.cs
- CharAnimationUsingKeyFrames.cs
- ThreadExceptionEvent.cs
- URLEditor.cs
- ExpandoClass.cs
- DrawingContextWalker.cs
- XMLSyntaxException.cs
- ToolStripSeparator.cs
- WeakEventManager.cs
- SplitterPanel.cs
- CompressedStack.cs
- ListView.cs
- ImageField.cs
- AtomPub10ServiceDocumentFormatter.cs
- TreeNode.cs
- HttpHeaderCollection.cs
- AssemblyNameProxy.cs
- EdmItemCollection.cs
- InputMethodStateTypeInfo.cs
- ToolTip.cs
- CriticalHandle.cs
- ScriptResourceInfo.cs
- SiteMapDataSourceView.cs
- DetailsViewRowCollection.cs
- StyleXamlTreeBuilder.cs
- MouseBinding.cs
- CodeDOMUtility.cs
- AppDomainShutdownMonitor.cs
- ViewBase.cs
- DependencyPropertyKind.cs
- PolicyManager.cs
- QueryCreatedEventArgs.cs
- TextRangeBase.cs
- OdbcEnvironment.cs
- TemplateControl.cs
- Simplifier.cs
- ISessionStateStore.cs
- EvidenceBase.cs
- SystemGatewayIPAddressInformation.cs
- Internal.cs
- LinkDescriptor.cs
- UpdateManifestForBrowserApplication.cs
- HttpListener.cs
- XmlArrayAttribute.cs
- Application.cs
- TableCell.cs
- WorkflowPageSetupDialog.cs
- PersonalizationStateInfo.cs
- CharEntityEncoderFallback.cs
- ColumnCollection.cs
- EntityDataSourceQueryBuilder.cs
- ListBox.cs
- EventHandlerList.cs
- EmulateRecognizeCompletedEventArgs.cs
- Pen.cs
- TypeUsageBuilder.cs
- DataGridViewHitTestInfo.cs
- OleDbSchemaGuid.cs
- TypeSystem.cs
- DeviceContext.cs
- DataGridCell.cs
- MimeWriter.cs
- TokenBasedSet.cs
- TypeConverter.cs
- XmlElementAttribute.cs
- Encoder.cs
- AuthenticatedStream.cs
- FirewallWrapper.cs