Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / WinForms / Managed / System / WinForms / ApplicationContext.cs / 1305376 / ApplicationContext.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Windows.Forms { using System; using System.Diagnostics; using System.ComponentModel; ////// /// ApplicationContext provides contextual information about an application /// thread. Specifically this allows an application author to redifine what /// circurmstances cause a message loop to exit. By default the application /// context listens to the close event on the mainForm, then exits the /// thread's message loop. /// public class ApplicationContext : IDisposable { Form mainForm; object userData; ////// /// Creates a new ApplicationContext with no mainForm. /// public ApplicationContext() : this(null) { } ////// /// Creates a new ApplicationContext with the specified mainForm. /// If OnMainFormClosed is not overriden, the thread's message /// loop will be terminated when mainForm is closed. /// public ApplicationContext(Form mainForm) { this.MainForm = mainForm; } ///~ApplicationContext() { Dispose(false); } /// /// /// Determines the mainForm for this context. This may be changed /// at anytime. /// If OnMainFormClosed is not overriden, the thread's message /// loop will be terminated when mainForm is closed. /// public Form MainForm { get { return mainForm; } set { EventHandler onClose = new EventHandler(OnMainFormDestroy); if (mainForm != null) { mainForm.HandleDestroyed -= onClose; } mainForm = value; if (mainForm != null) { mainForm.HandleDestroyed += onClose; } } } ///[ SRCategory(SR.CatData), Localizable(false), Bindable(true), SRDescription(SR.ControlTagDescr), DefaultValue(null), TypeConverter(typeof(StringConverter)), ] public object Tag { get { return userData; } set { userData = value; } } /// /// /// Is raised when the thread's message loop should be terminated. /// This is raised by calling ExitThread. /// public event EventHandler ThreadExit; ////// /// Disposes the context. This should dispose the mainForm. This is /// called immediately after the thread's message loop is terminated. /// Application will dispose all forms on this thread by default. /// public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } ///protected virtual void Dispose(bool disposing) { if (disposing) { if (mainForm != null) { if (!mainForm.IsDisposed) { mainForm.Dispose(); } mainForm = null; } } } /// /// /// Causes the thread's message loop to be terminated. This /// will call ExitThreadCore. /// public void ExitThread() { ExitThreadCore(); } ////// /// Causes the thread's message loop to be terminated. /// protected virtual void ExitThreadCore() { if (ThreadExit != null) { ThreadExit(this, EventArgs.Empty); } } ////// /// Called when the mainForm is closed. The default implementation /// of this will call ExitThreadCore. /// protected virtual void OnMainFormClosed(object sender, EventArgs e) { ExitThreadCore(); } ////// Called when the mainForm is closed. The default implementation /// of this will call ExitThreadCore. /// private void OnMainFormDestroy(object sender, EventArgs e) { Form form = (Form)sender; if (!form.RecreatingHandle) { form.HandleDestroyed -= new EventHandler(OnMainFormDestroy); OnMainFormClosed(sender, e); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Windows.Forms { using System; using System.Diagnostics; using System.ComponentModel; ////// /// ApplicationContext provides contextual information about an application /// thread. Specifically this allows an application author to redifine what /// circurmstances cause a message loop to exit. By default the application /// context listens to the close event on the mainForm, then exits the /// thread's message loop. /// public class ApplicationContext : IDisposable { Form mainForm; object userData; ////// /// Creates a new ApplicationContext with no mainForm. /// public ApplicationContext() : this(null) { } ////// /// Creates a new ApplicationContext with the specified mainForm. /// If OnMainFormClosed is not overriden, the thread's message /// loop will be terminated when mainForm is closed. /// public ApplicationContext(Form mainForm) { this.MainForm = mainForm; } ///~ApplicationContext() { Dispose(false); } /// /// /// Determines the mainForm for this context. This may be changed /// at anytime. /// If OnMainFormClosed is not overriden, the thread's message /// loop will be terminated when mainForm is closed. /// public Form MainForm { get { return mainForm; } set { EventHandler onClose = new EventHandler(OnMainFormDestroy); if (mainForm != null) { mainForm.HandleDestroyed -= onClose; } mainForm = value; if (mainForm != null) { mainForm.HandleDestroyed += onClose; } } } ///[ SRCategory(SR.CatData), Localizable(false), Bindable(true), SRDescription(SR.ControlTagDescr), DefaultValue(null), TypeConverter(typeof(StringConverter)), ] public object Tag { get { return userData; } set { userData = value; } } /// /// /// Is raised when the thread's message loop should be terminated. /// This is raised by calling ExitThread. /// public event EventHandler ThreadExit; ////// /// Disposes the context. This should dispose the mainForm. This is /// called immediately after the thread's message loop is terminated. /// Application will dispose all forms on this thread by default. /// public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } ///protected virtual void Dispose(bool disposing) { if (disposing) { if (mainForm != null) { if (!mainForm.IsDisposed) { mainForm.Dispose(); } mainForm = null; } } } /// /// /// Causes the thread's message loop to be terminated. This /// will call ExitThreadCore. /// public void ExitThread() { ExitThreadCore(); } ////// /// Causes the thread's message loop to be terminated. /// protected virtual void ExitThreadCore() { if (ThreadExit != null) { ThreadExit(this, EventArgs.Empty); } } ////// /// Called when the mainForm is closed. The default implementation /// of this will call ExitThreadCore. /// protected virtual void OnMainFormClosed(object sender, EventArgs e) { ExitThreadCore(); } ////// Called when the mainForm is closed. The default implementation /// of this will call ExitThreadCore. /// private void OnMainFormDestroy(object sender, EventArgs e) { Form form = (Form)sender; if (!form.RecreatingHandle) { form.HandleDestroyed -= new EventHandler(OnMainFormDestroy); OnMainFormClosed(sender, e); } } } } // 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
- ImageUrlEditor.cs
- ConstructorExpr.cs
- SafeReversePInvokeHandle.cs
- RuntimeConfig.cs
- SafeCryptHandles.cs
- IdentitySection.cs
- LateBoundBitmapDecoder.cs
- TargetFrameworkUtil.cs
- HtmlInputPassword.cs
- SqlBooleanMismatchVisitor.cs
- Library.cs
- ListBox.cs
- UIElement.cs
- OleDbError.cs
- ReachUIElementCollectionSerializer.cs
- StrongNameHelpers.cs
- StatusStrip.cs
- RC2.cs
- ConfigXmlText.cs
- WizardForm.cs
- IntSecurity.cs
- ActionItem.cs
- DefaultShape.cs
- Vector3D.cs
- ImageDrawing.cs
- Condition.cs
- FixedSOMPage.cs
- WmlPanelAdapter.cs
- CurrencyWrapper.cs
- GridViewDeleteEventArgs.cs
- InstanceKey.cs
- ReferenceService.cs
- CreateUserWizard.cs
- Image.cs
- SafeFileMapViewHandle.cs
- UndoEngine.cs
- PersonalizablePropertyEntry.cs
- CalendarData.cs
- MethodBody.cs
- FileClassifier.cs
- CachedFontFamily.cs
- PKCS1MaskGenerationMethod.cs
- HtmlButton.cs
- ColorIndependentAnimationStorage.cs
- XmlIgnoreAttribute.cs
- PropertyManager.cs
- Rect.cs
- DbTransaction.cs
- SpecialNameAttribute.cs
- DbConnectionHelper.cs
- CodeChecksumPragma.cs
- StylusCollection.cs
- ObjectViewListener.cs
- WebControl.cs
- CellPartitioner.cs
- Accessible.cs
- LineInfo.cs
- WebPartMinimizeVerb.cs
- BufferModesCollection.cs
- SimpleLine.cs
- ListBoxItem.cs
- CodeConstructor.cs
- Validator.cs
- TableItemStyle.cs
- XmlImplementation.cs
- NoneExcludedImageIndexConverter.cs
- XmlSchemaValidator.cs
- HttpChannelListener.cs
- DataServiceRequestOfT.cs
- _NegotiateClient.cs
- GridViewSelectEventArgs.cs
- WindowCollection.cs
- PartialTrustVisibleAssembliesSection.cs
- GridErrorDlg.cs
- MessageQueueTransaction.cs
- QuestionEventArgs.cs
- BitStream.cs
- WeakRefEnumerator.cs
- WindowsTitleBar.cs
- CompiledXpathExpr.cs
- IndexOutOfRangeException.cs
- PtsHelper.cs
- DeadCharTextComposition.cs
- CreateUserWizard.cs
- ControlIdConverter.cs
- log.cs
- XmlSerializerFactory.cs
- MessageDesigner.cs
- ApplicationDirectory.cs
- CompositeCollection.cs
- TabControlCancelEvent.cs
- FtpCachePolicyElement.cs
- XmlCharCheckingReader.cs
- sitestring.cs
- HtmlTableCellCollection.cs
- ServerValidateEventArgs.cs
- SettingsPropertyIsReadOnlyException.cs
- SecurityIdentifierElement.cs
- ConnectionConsumerAttribute.cs
- PolyQuadraticBezierSegment.cs