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
- ProviderConnectionPointCollection.cs
- SelectorAutomationPeer.cs
- ProfileManager.cs
- PolyQuadraticBezierSegment.cs
- Point3DAnimation.cs
- LiteralDesigner.cs
- MdiWindowListItemConverter.cs
- RuntimeArgument.cs
- NonVisualControlAttribute.cs
- XmlNamespaceMapping.cs
- DataSourceView.cs
- XmlIlGenerator.cs
- AttachmentCollection.cs
- OdbcDataReader.cs
- PreProcessInputEventArgs.cs
- XmlElementAttribute.cs
- SqlTypesSchemaImporter.cs
- SequentialUshortCollection.cs
- ModelFactory.cs
- XmlIncludeAttribute.cs
- Walker.cs
- DirectoryObjectSecurity.cs
- XmlSchemaAnyAttribute.cs
- LayoutEditorPart.cs
- FocusChangedEventArgs.cs
- Rect3D.cs
- DocumentGrid.cs
- xml.cs
- ModelUIElement3D.cs
- Utils.cs
- XmlSchemaCollection.cs
- DetailsViewDeleteEventArgs.cs
- XmlSchemaAll.cs
- SwitchElementsCollection.cs
- DataViewSetting.cs
- MethodAccessException.cs
- MarkupProperty.cs
- LazyTextWriterCreator.cs
- CaseInsensitiveOrdinalStringComparer.cs
- TcpChannelListener.cs
- SolidColorBrush.cs
- HtmlObjectListAdapter.cs
- ClrProviderManifest.cs
- RoutedUICommand.cs
- AttributeEmitter.cs
- CodeIdentifiers.cs
- PageContent.cs
- CodeIdentifier.cs
- ObsoleteAttribute.cs
- IPAddressCollection.cs
- SharedUtils.cs
- securitymgrsite.cs
- FontUnit.cs
- QuinticEase.cs
- WindowsListViewGroupSubsetLink.cs
- PageBuildProvider.cs
- CompilerCollection.cs
- Codec.cs
- InvokeHandlers.cs
- CompilerTypeWithParams.cs
- VoiceChangeEventArgs.cs
- ToolStripDropDownMenu.cs
- ErrorEventArgs.cs
- ClientData.cs
- QuadraticBezierSegment.cs
- OleDbWrapper.cs
- CodeSnippetExpression.cs
- RegexStringValidatorAttribute.cs
- WebReferencesBuildProvider.cs
- TrackingExtract.cs
- PropertyEmitter.cs
- FontSource.cs
- Privilege.cs
- SecurityElementBase.cs
- WebPartConnectVerb.cs
- Crypto.cs
- EventLogPermissionEntry.cs
- QueryOperationResponseOfT.cs
- RemotingSurrogateSelector.cs
- PrintingPermissionAttribute.cs
- MenuItemCollection.cs
- WmlTextViewAdapter.cs
- StorageEntitySetMapping.cs
- FastEncoder.cs
- ProjectionPlan.cs
- _IPv6Address.cs
- SingleObjectCollection.cs
- FrameworkPropertyMetadata.cs
- SettingsPropertyIsReadOnlyException.cs
- DataGridViewCellConverter.cs
- Polygon.cs
- GeneralTransform3DCollection.cs
- EntryPointNotFoundException.cs
- EventMap.cs
- ObjectContextServiceProvider.cs
- ModelUIElement3D.cs
- NumberFunctions.cs
- TreeBuilderBamlTranslator.cs
- BrowserDefinitionCollection.cs
- DataGridViewCell.cs