Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Sys / System / IO / compression / DeflateStreamAsyncResult.cs / 1305376 / DeflateStreamAsyncResult.cs
namespace System.IO.Compression { using System.Threading; internal class DeflateStreamAsyncResult : IAsyncResult { public byte[] buffer; public int offset; public int count; // disable csharp compiler warning #0414: field assigned unused value #pragma warning disable 0414 public bool isWrite; #pragma warning restore 0414 private object m_AsyncObject; // Caller's async object. private object m_AsyncState; // Caller's state object. private AsyncCallback m_AsyncCallback; // Caller's callback method. private object m_Result; // Final IO result to be returned byt the End*() method. internal bool m_CompletedSynchronously; // true if the operation completed synchronously. private int m_InvokedCallback; // 0 is callback is not called private int m_Completed; // 0 if not completed >0 otherwise. private object m_Event; // lazy allocated event to be returned in the IAsyncResult for the client to wait on public DeflateStreamAsyncResult(object asyncObject, object asyncState, AsyncCallback asyncCallback, byte[] buffer, int offset, int count) { this.buffer = buffer; this.offset = offset; this.count = count; m_CompletedSynchronously = true; m_AsyncObject = asyncObject; m_AsyncState = asyncState; m_AsyncCallback = asyncCallback; } // Interface method to return the caller's state object. public object AsyncState { get { return m_AsyncState; } } // Interface property to return a WaitHandle that can be waited on for I/O completion. // This property implements lazy event creation. // the event object is only created when this property is accessed, // since we're internally only using callbacks, as long as the user is using // callbacks as well we will not create an event at all. public WaitHandle AsyncWaitHandle { get { // save a copy of the completion status int savedCompleted = m_Completed; if (m_Event == null) { // lazy allocation of the event: // if this property is never accessed this object is never created Interlocked.CompareExchange(ref m_Event, new ManualResetEvent(savedCompleted != 0), null); } ManualResetEvent castedEvent = (ManualResetEvent)m_Event; if (savedCompleted == 0 && m_Completed != 0) { // if, while the event was created in the reset state, // the IO operation completed, set the event here. castedEvent.Set(); } return castedEvent; } } // Interface property, returning synchronous completion status. public bool CompletedSynchronously { get { return m_CompletedSynchronously; } } // Interface property, returning completion status. public bool IsCompleted { get { return m_Completed != 0; } } // Internal property for setting the IO result. internal object Result { get { return m_Result; } } internal void Close() { if (m_Event != null) { ((ManualResetEvent)m_Event).Close(); } } internal void InvokeCallback(bool completedSynchronously, object result) { Complete(completedSynchronously, result); } internal void InvokeCallback(object result) { Complete(result); } // Internal method for setting completion. // As a side effect, we'll signal the WaitHandle event and clean up. private void Complete(bool completedSynchronously, object result) { m_CompletedSynchronously = completedSynchronously; Complete(result); } private void Complete(object result) { m_Result = result; // Set IsCompleted and the event only after the usercallback method. Interlocked.Increment(ref m_Completed); if (m_Event != null) { ((ManualResetEvent)m_Event).Set(); } if (Interlocked.Increment(ref m_InvokedCallback) == 1) { if (m_AsyncCallback != null) { m_AsyncCallback(this); } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. namespace System.IO.Compression { using System.Threading; internal class DeflateStreamAsyncResult : IAsyncResult { public byte[] buffer; public int offset; public int count; // disable csharp compiler warning #0414: field assigned unused value #pragma warning disable 0414 public bool isWrite; #pragma warning restore 0414 private object m_AsyncObject; // Caller's async object. private object m_AsyncState; // Caller's state object. private AsyncCallback m_AsyncCallback; // Caller's callback method. private object m_Result; // Final IO result to be returned byt the End*() method. internal bool m_CompletedSynchronously; // true if the operation completed synchronously. private int m_InvokedCallback; // 0 is callback is not called private int m_Completed; // 0 if not completed >0 otherwise. private object m_Event; // lazy allocated event to be returned in the IAsyncResult for the client to wait on public DeflateStreamAsyncResult(object asyncObject, object asyncState, AsyncCallback asyncCallback, byte[] buffer, int offset, int count) { this.buffer = buffer; this.offset = offset; this.count = count; m_CompletedSynchronously = true; m_AsyncObject = asyncObject; m_AsyncState = asyncState; m_AsyncCallback = asyncCallback; } // Interface method to return the caller's state object. public object AsyncState { get { return m_AsyncState; } } // Interface property to return a WaitHandle that can be waited on for I/O completion. // This property implements lazy event creation. // the event object is only created when this property is accessed, // since we're internally only using callbacks, as long as the user is using // callbacks as well we will not create an event at all. public WaitHandle AsyncWaitHandle { get { // save a copy of the completion status int savedCompleted = m_Completed; if (m_Event == null) { // lazy allocation of the event: // if this property is never accessed this object is never created Interlocked.CompareExchange(ref m_Event, new ManualResetEvent(savedCompleted != 0), null); } ManualResetEvent castedEvent = (ManualResetEvent)m_Event; if (savedCompleted == 0 && m_Completed != 0) { // if, while the event was created in the reset state, // the IO operation completed, set the event here. castedEvent.Set(); } return castedEvent; } } // Interface property, returning synchronous completion status. public bool CompletedSynchronously { get { return m_CompletedSynchronously; } } // Interface property, returning completion status. public bool IsCompleted { get { return m_Completed != 0; } } // Internal property for setting the IO result. internal object Result { get { return m_Result; } } internal void Close() { if (m_Event != null) { ((ManualResetEvent)m_Event).Close(); } } internal void InvokeCallback(bool completedSynchronously, object result) { Complete(completedSynchronously, result); } internal void InvokeCallback(object result) { Complete(result); } // Internal method for setting completion. // As a side effect, we'll signal the WaitHandle event and clean up. private void Complete(bool completedSynchronously, object result) { m_CompletedSynchronously = completedSynchronously; Complete(result); } private void Complete(object result) { m_Result = result; // Set IsCompleted and the event only after the usercallback method. Interlocked.Increment(ref m_Completed); if (m_Event != null) { ((ManualResetEvent)m_Event).Set(); } if (Interlocked.Increment(ref m_InvokedCallback) == 1) { if (m_AsyncCallback != null) { m_AsyncCallback(this); } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- CompensateDesigner.cs
- clipboard.cs
- Selection.cs
- FrameworkContentElement.cs
- GeometryGroup.cs
- PopupControlService.cs
- VSWCFServiceContractGenerator.cs
- XmlSchemaInclude.cs
- DelegatingConfigHost.cs
- X509Certificate2Collection.cs
- EnumerableCollectionView.cs
- Exceptions.cs
- ClientSettingsStore.cs
- HttpDictionary.cs
- ItemsPresenter.cs
- SystemNetHelpers.cs
- HeaderCollection.cs
- PanelStyle.cs
- ComponentEditorPage.cs
- PtsHelper.cs
- XmlAttributeCache.cs
- TextElementEnumerator.cs
- ComponentSerializationService.cs
- Msmq4PoisonHandler.cs
- ResourceAssociationTypeEnd.cs
- CaseCqlBlock.cs
- DependsOnAttribute.cs
- CurrentTimeZone.cs
- NativeMethods.cs
- EntityDataSourceEntityTypeFilterItem.cs
- DataGridTableCollection.cs
- DescriptionCreator.cs
- ContentFilePart.cs
- MenuAdapter.cs
- COM2ColorConverter.cs
- DesignerVerb.cs
- Monitor.cs
- PrintControllerWithStatusDialog.cs
- ChannelEndpointElementCollection.cs
- DropDownList.cs
- ToolStripScrollButton.cs
- ObjectStateManager.cs
- XmlHierarchicalDataSourceView.cs
- BreadCrumbTextConverter.cs
- ColumnReorderedEventArgs.cs
- InsufficientMemoryException.cs
- ActivationServices.cs
- AlignmentYValidation.cs
- FactoryGenerator.cs
- CapabilitiesUse.cs
- ToolStripDropDown.cs
- DataReceivedEventArgs.cs
- DataGridViewRowHeightInfoPushedEventArgs.cs
- MSAAEventDispatcher.cs
- XamlPointCollectionSerializer.cs
- TemplateParser.cs
- XamlFilter.cs
- BitmapData.cs
- CryptoConfig.cs
- DataGridViewCheckBoxCell.cs
- BamlStream.cs
- LinqTreeNodeEvaluator.cs
- ReflectionTypeLoadException.cs
- _ConnectionGroup.cs
- TripleDESCryptoServiceProvider.cs
- WorkItem.cs
- SkipQueryOptionExpression.cs
- Emitter.cs
- ExceptionTrace.cs
- RadioButton.cs
- NativeMethods.cs
- InputEventArgs.cs
- TrustManagerMoreInformation.cs
- VisualStyleRenderer.cs
- ReverseInheritProperty.cs
- SqlWriter.cs
- ControlLocalizer.cs
- XamlRtfConverter.cs
- DataPagerFieldCommandEventArgs.cs
- ListenDesigner.cs
- HttpCacheParams.cs
- BindingSource.cs
- HttpRuntimeSection.cs
- PropertyMetadata.cs
- ToolStripSystemRenderer.cs
- _Events.cs
- assertwrapper.cs
- FileDialog.cs
- RangeBaseAutomationPeer.cs
- XmlCharCheckingWriter.cs
- WebConvert.cs
- WebPartConnectionsCancelEventArgs.cs
- DataBindEngine.cs
- RuleAction.cs
- WebScriptMetadataMessageEncoderFactory.cs
- HtmlShim.cs
- PreviewPageInfo.cs
- InputElement.cs
- _HelperAsyncResults.cs
- WebRequestModulesSection.cs