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
- PersonalizationProviderHelper.cs
- JobStaple.cs
- SHA512Managed.cs
- ManagementException.cs
- SerializationAttributes.cs
- XsltInput.cs
- XslAst.cs
- ListViewEditEventArgs.cs
- DataTablePropertyDescriptor.cs
- XAMLParseException.cs
- ObjectQueryProvider.cs
- CollectionViewProxy.cs
- ListViewInsertedEventArgs.cs
- HostVisual.cs
- MobileTemplatedControlDesigner.cs
- UnicastIPAddressInformationCollection.cs
- CallInfo.cs
- MailSettingsSection.cs
- DefaultDialogButtons.cs
- PasswordPropertyTextAttribute.cs
- IdnElement.cs
- Types.cs
- SigningCredentials.cs
- Camera.cs
- ElementInit.cs
- SplitterCancelEvent.cs
- TextCharacters.cs
- BrushValueSerializer.cs
- DirectionalLight.cs
- TrustLevelCollection.cs
- NetWebProxyFinder.cs
- MimeReflector.cs
- ServiceAuthorizationManager.cs
- TaskSchedulerException.cs
- TextDocumentView.cs
- WinFormsSecurity.cs
- CategoryValueConverter.cs
- CellParagraph.cs
- Queue.cs
- MULTI_QI.cs
- MLangCodePageEncoding.cs
- Size3D.cs
- AssemblyBuilder.cs
- UxThemeWrapper.cs
- Wizard.cs
- CaseExpr.cs
- behaviorssection.cs
- AppDomainManager.cs
- MetafileHeader.cs
- WindowsUserNameCachingSecurityTokenAuthenticator.cs
- RowToParametersTransformer.cs
- PrintPreviewControl.cs
- SerializationAttributes.cs
- SuppressMessageAttribute.cs
- ContainerVisual.cs
- InvokeHandlers.cs
- ExceptionHelpers.cs
- SingleAnimation.cs
- SqlPersistenceWorkflowInstanceDescription.cs
- SqlInternalConnection.cs
- TypedTableGenerator.cs
- DataBindingCollectionConverter.cs
- DataDocumentXPathNavigator.cs
- CompilationRelaxations.cs
- LinqDataSourceDisposeEventArgs.cs
- WebServiceTypeData.cs
- DataServiceQueryException.cs
- NameValueConfigurationCollection.cs
- AccessDataSource.cs
- Token.cs
- QilInvokeLateBound.cs
- ProgressiveCrcCalculatingStream.cs
- GeneralTransform.cs
- PngBitmapEncoder.cs
- XmlObjectSerializer.cs
- VirtualDirectoryMapping.cs
- ConfigurationConverterBase.cs
- figurelength.cs
- SystemIcmpV4Statistics.cs
- HttpUnhandledOperationInvoker.cs
- WindowsFormsEditorServiceHelper.cs
- DataBindingsDialog.cs
- ValueTypeFieldReference.cs
- WindowsTokenRoleProvider.cs
- SqlWebEventProvider.cs
- LineUtil.cs
- GroupBox.cs
- ToolStripLocationCancelEventArgs.cs
- DataViewListener.cs
- ActivityTypeCodeDomSerializer.cs
- MenuItemStyleCollection.cs
- TargetControlTypeCache.cs
- BoundingRectTracker.cs
- MetadataAssemblyHelper.cs
- MsmqActivation.cs
- FontDifferentiator.cs
- ConfigurationSectionGroupCollection.cs
- Popup.cs
- EntityDataSourceContextCreatedEventArgs.cs
- PointIndependentAnimationStorage.cs