Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / WinForms / Managed / System / WinForms / Command.cs / 1 / Command.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* */ namespace System.Windows.Forms { using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System; using System.ComponentModel; using System.Windows.Forms; using System.Drawing; using Microsoft.Win32; ////// internal class Command : WeakReference { private static Command[] cmds; private static int icmdTry; private static object internalSyncObject = new object(); private const int idMin = 0x00100; private const int idLim = 0x10000; internal int id; public Command(ICommandExecutor target) : base(target, false) { AssignID(this); } public virtual int ID { get { return id; } } [SuppressMessage("Microsoft.Reliability", "CA2001:AvoidCallingProblematicMethods")] protected static void AssignID(Command cmd) { lock(internalSyncObject) { int icmd; if (null == cmds) { cmds = new Command[20]; icmd = 0; } else { Debug.Assert(cmds.Length > 0, "why is cmds.Length zero?"); Debug.Assert(icmdTry >= 0, "why is icmdTry negative?"); int icmdLim = cmds.Length; if (icmdTry >= icmdLim) icmdTry = 0; // First look for an empty slot (starting at icmdTry). for (icmd = icmdTry; icmd < icmdLim; icmd++) if (null == cmds[icmd]) goto FindSlotComplete; for (icmd = 0; icmd < icmdTry; icmd++) if (null == cmds[icmd]) goto FindSlotComplete; // All slots have Command objects in them. Look for a command // with a null referent. for (icmd = 0; icmd < icmdLim; icmd++) if (null == cmds[icmd].Target) goto FindSlotComplete; // Grow the array. icmd = cmds.Length; icmdLim = Math.Min(idLim - idMin, 2 * icmd); if (icmdLim <= icmd) { // Already at maximal size. Do a garbage collect and look again. GC.Collect(); for (icmd = 0; icmd < icmdLim; icmd++) { if (null == cmds[icmd] || null == cmds[icmd].Target) goto FindSlotComplete; } throw new ArgumentException(SR.GetString(SR.CommandIdNotAllocated)); } else { Command[] newCmds = new Command[icmdLim]; Array.Copy(cmds, 0, newCmds, 0, icmd); cmds = newCmds; } } FindSlotComplete: cmd.id = icmd + idMin; Debug.Assert(cmd.id >= idMin && cmd.id < idLim, "generated command id out of range"); cmds[icmd] = cmd; icmdTry = icmd + 1; } } public static bool DispatchID(int id) { Command cmd = GetCommandFromID(id); if (null == cmd) return false; return cmd.Invoke(); } protected static void Dispose(Command cmd) { lock (internalSyncObject) { if (cmd.id >= idMin) { cmd.Target = null; if (cmds[cmd.id - idMin] == cmd) cmds[cmd.id - idMin] = null; cmd.id = 0; } } } public virtual void Dispose() { if (id >= idMin) Dispose(this); } public static Command GetCommandFromID(int id) { lock (internalSyncObject) { if (null == cmds) return null; int i = id - idMin; if (i < 0 || i >= cmds.Length) return null; return cmds[i]; } } public virtual bool Invoke() { object target = Target; if (!(target is ICommandExecutor)) return false; ((ICommandExecutor)target).Execute(); return true; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* */ namespace System.Windows.Forms { using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System; using System.ComponentModel; using System.Windows.Forms; using System.Drawing; using Microsoft.Win32; ////// internal class Command : WeakReference { private static Command[] cmds; private static int icmdTry; private static object internalSyncObject = new object(); private const int idMin = 0x00100; private const int idLim = 0x10000; internal int id; public Command(ICommandExecutor target) : base(target, false) { AssignID(this); } public virtual int ID { get { return id; } } [SuppressMessage("Microsoft.Reliability", "CA2001:AvoidCallingProblematicMethods")] protected static void AssignID(Command cmd) { lock(internalSyncObject) { int icmd; if (null == cmds) { cmds = new Command[20]; icmd = 0; } else { Debug.Assert(cmds.Length > 0, "why is cmds.Length zero?"); Debug.Assert(icmdTry >= 0, "why is icmdTry negative?"); int icmdLim = cmds.Length; if (icmdTry >= icmdLim) icmdTry = 0; // First look for an empty slot (starting at icmdTry). for (icmd = icmdTry; icmd < icmdLim; icmd++) if (null == cmds[icmd]) goto FindSlotComplete; for (icmd = 0; icmd < icmdTry; icmd++) if (null == cmds[icmd]) goto FindSlotComplete; // All slots have Command objects in them. Look for a command // with a null referent. for (icmd = 0; icmd < icmdLim; icmd++) if (null == cmds[icmd].Target) goto FindSlotComplete; // Grow the array. icmd = cmds.Length; icmdLim = Math.Min(idLim - idMin, 2 * icmd); if (icmdLim <= icmd) { // Already at maximal size. Do a garbage collect and look again. GC.Collect(); for (icmd = 0; icmd < icmdLim; icmd++) { if (null == cmds[icmd] || null == cmds[icmd].Target) goto FindSlotComplete; } throw new ArgumentException(SR.GetString(SR.CommandIdNotAllocated)); } else { Command[] newCmds = new Command[icmdLim]; Array.Copy(cmds, 0, newCmds, 0, icmd); cmds = newCmds; } } FindSlotComplete: cmd.id = icmd + idMin; Debug.Assert(cmd.id >= idMin && cmd.id < idLim, "generated command id out of range"); cmds[icmd] = cmd; icmdTry = icmd + 1; } } public static bool DispatchID(int id) { Command cmd = GetCommandFromID(id); if (null == cmd) return false; return cmd.Invoke(); } protected static void Dispose(Command cmd) { lock (internalSyncObject) { if (cmd.id >= idMin) { cmd.Target = null; if (cmds[cmd.id - idMin] == cmd) cmds[cmd.id - idMin] = null; cmd.id = 0; } } } public virtual void Dispose() { if (id >= idMin) Dispose(this); } public static Command GetCommandFromID(int id) { lock (internalSyncObject) { if (null == cmds) return null; int i = id - idMin; if (i < 0 || i >= cmds.Length) return null; return cmds[i]; } } public virtual bool Invoke() { object target = Target; if (!(target is ICommandExecutor)) return false; ((ICommandExecutor)target).Execute(); return true; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- MultiByteCodec.cs
- ConditionChanges.cs
- WindowPatternIdentifiers.cs
- ScriptingWebServicesSectionGroup.cs
- CoTaskMemHandle.cs
- BaseTemplatedMobileComponentEditor.cs
- Int16AnimationUsingKeyFrames.cs
- ConfigurationUtility.cs
- AnonymousIdentificationSection.cs
- OleDbCommand.cs
- ProcessHostServerConfig.cs
- MsmqIntegrationBindingElement.cs
- HtmlProps.cs
- PixelShader.cs
- EventWaitHandle.cs
- SatelliteContractVersionAttribute.cs
- RawStylusInputCustomData.cs
- WSTrustDec2005.cs
- MediaScriptCommandRoutedEventArgs.cs
- XmlSerializerVersionAttribute.cs
- Underline.cs
- CellTreeNodeVisitors.cs
- XmlBindingWorker.cs
- PluggableProtocol.cs
- TextEffectCollection.cs
- SQLDoubleStorage.cs
- SystemInformation.cs
- DataGridViewToolTip.cs
- AssociationSetMetadata.cs
- StateItem.cs
- MsmqChannelFactory.cs
- ServiceReference.cs
- AesCryptoServiceProvider.cs
- SqlException.cs
- RenderDataDrawingContext.cs
- FontDriver.cs
- HandlerWithFactory.cs
- ProcessHostServerConfig.cs
- DataGridViewRowCollection.cs
- UnsafeNativeMethodsTablet.cs
- DocComment.cs
- ToolStripItemTextRenderEventArgs.cs
- ObjectStateEntryBaseUpdatableDataRecord.cs
- CorePropertiesFilter.cs
- Tokenizer.cs
- SqlErrorCollection.cs
- ParallelQuery.cs
- SqlBinder.cs
- EffectiveValueEntry.cs
- CodeStatementCollection.cs
- DeviceFilterDictionary.cs
- XamlPoint3DCollectionSerializer.cs
- ComponentResourceManager.cs
- Header.cs
- HtmlAnchor.cs
- ColumnResizeUndoUnit.cs
- DivideByZeroException.cs
- InvokeProviderWrapper.cs
- GifBitmapEncoder.cs
- WithParamAction.cs
- InheritanceContextChangedEventManager.cs
- ContextProperty.cs
- DataControlFieldCollection.cs
- ToolboxComponentsCreatingEventArgs.cs
- ThreadInterruptedException.cs
- ToolStripPanelRenderEventArgs.cs
- SurrogateEncoder.cs
- DynamicValueConverter.cs
- EnumerableRowCollection.cs
- DataFormat.cs
- HashCodeCombiner.cs
- ManagedCodeMarkers.cs
- ImageIndexConverter.cs
- MetaTable.cs
- GeneralTransform3DGroup.cs
- Timer.cs
- Header.cs
- ImageSourceValueSerializer.cs
- DataGridViewComboBoxEditingControl.cs
- DataObjectAttribute.cs
- XmlUtil.cs
- ApplicationActivator.cs
- DateTimeSerializationSection.cs
- CroppedBitmap.cs
- CacheHelper.cs
- TemplatePropertyEntry.cs
- RangeValidator.cs
- WorkflowRuntime.cs
- Vector3dCollection.cs
- HwndTarget.cs
- ExtendLockCommand.cs
- ResolveMatchesMessageCD1.cs
- AutomationPeer.cs
- CompositeFontFamily.cs
- CalendarKeyboardHelper.cs
- SymmetricKeyWrap.cs
- _AuthenticationState.cs
- TextParagraphView.cs
- RenamedEventArgs.cs
- EmulateRecognizeCompletedEventArgs.cs