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
- EdmPropertyAttribute.cs
- TextSimpleMarkerProperties.cs
- Ports.cs
- DictionaryEditChange.cs
- SqlDeflator.cs
- Form.cs
- PeekCompletedEventArgs.cs
- EntityDesignerUtils.cs
- SQLBinary.cs
- _NegoState.cs
- RegexStringValidatorAttribute.cs
- Walker.cs
- DSASignatureDeformatter.cs
- CaseStatement.cs
- ProjectionPathSegment.cs
- ClientFormsIdentity.cs
- TextAdaptor.cs
- SecurityState.cs
- WindowsStartMenu.cs
- PositiveTimeSpanValidator.cs
- HtmlToClrEventProxy.cs
- FileDialog.cs
- MutexSecurity.cs
- Html32TextWriter.cs
- METAHEADER.cs
- RoleManagerModule.cs
- DynamicRenderer.cs
- AQNBuilder.cs
- Soap12FormatExtensions.cs
- DateTimeEditor.cs
- SecurityTokenException.cs
- XsltLibrary.cs
- ScrollBar.cs
- Matrix3DValueSerializer.cs
- TranslateTransform3D.cs
- DocumentGridPage.cs
- FileLevelControlBuilderAttribute.cs
- FastEncoder.cs
- CircleEase.cs
- GroupByExpressionRewriter.cs
- KnownTypesHelper.cs
- EmissiveMaterial.cs
- ClientUIRequest.cs
- CheckBox.cs
- PreviewKeyDownEventArgs.cs
- InputDevice.cs
- SamlDoNotCacheCondition.cs
- EpmCustomContentWriterNodeData.cs
- FlowDecision.cs
- ProviderCommandInfoUtils.cs
- ResponseStream.cs
- FontSource.cs
- DynamicValidator.cs
- Attributes.cs
- ObjectMemberMapping.cs
- GridItem.cs
- Vector3D.cs
- DetailsViewActionList.cs
- LinqDataSourceValidationException.cs
- CustomValidator.cs
- DetailsViewCommandEventArgs.cs
- ResourceFallbackManager.cs
- RecordsAffectedEventArgs.cs
- CombinedGeometry.cs
- Transactions.cs
- ContextStaticAttribute.cs
- DataGridItemCollection.cs
- DuplicateWaitObjectException.cs
- XmlExtensionFunction.cs
- GridViewAutomationPeer.cs
- HttpPostedFile.cs
- CodeMemberMethod.cs
- NetworkInformationException.cs
- ImageDrawing.cs
- DataReaderContainer.cs
- SID.cs
- InputBuffer.cs
- PagesSection.cs
- StringSource.cs
- EventDescriptorCollection.cs
- HostingPreferredMapPath.cs
- Blend.cs
- SerializationInfoEnumerator.cs
- FormViewAutoFormat.cs
- RtType.cs
- SqlMethodTransformer.cs
- TransformerConfigurationWizardBase.cs
- SqlInfoMessageEvent.cs
- SoapDocumentServiceAttribute.cs
- UIPermission.cs
- GridViewDeletedEventArgs.cs
- AddingNewEventArgs.cs
- DoubleAnimationUsingPath.cs
- SerializableAttribute.cs
- ExtensionFile.cs
- TableLayoutStyle.cs
- PageCodeDomTreeGenerator.cs
- ApplicationHost.cs
- DatePickerDateValidationErrorEventArgs.cs
- ScrollChangedEventArgs.cs