Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Core / CSharp / MS / Internal / IO / Packaging / ResponseStream.cs / 1305600 / ResponseStream.cs
//------------------------------------------------------------------------------ // Microsoft Avalon // Copyright (c) Microsoft Corporation, 2001 // // File: ResponseStream.cs // // Description: Exists so that the gc lifetime for the container // and the webresponse are shared. // // This wrapper is returned for any PackWebResponse satisified // with a container. It ensures that the container lives until // the stream is closed because we are unaware of the lifetime of // the stream and the client is unaware of the existence of the // container. // // Container is never closed because it may be used by other // responses. // // History: 11/17/03 - brucemac - created // 12/11/03 - brucemac - adapted from ResponseStream // 15/10/04 - brucemac - adapted from ContainerResponseStream //----------------------------------------------------------------------------- using System; using System.Diagnostics; using System.IO; using System.IO.Packaging; // for PackWebResponse using MS.Utility; using System.Windows; namespace MS.Internal.IO.Packaging { ////// Wrap returned stream so we can release the webresponse container when the stream is closed /// internal class ResponseStream : Stream { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- ////// Wraps PackWebResponse to ensure correct lifetime handling and stream length functionality /// /// stream to read from (baseStream) /// response /// stream under the package /// container to hold on to internal ResponseStream(Stream s, PackWebResponse response, Stream owningStream, Package container) { Debug.Assert(container != null, "Logic error: use other constructor for full package request streams"); Debug.Assert(owningStream != null, "Logic error: use other constructor for full package request streams"); Init(s, response, owningStream, container); } ////// Wraps stream returned by PackWebResponse to ensure correct lifetime handlingy /// /// stream to read from (baseStream) /// webresponse to close when we close internal ResponseStream(Stream s, PackWebResponse response) { Init(s, response, null, null); } ////// Wraps PackWebResponse to ensure correct lifetime handling and stream length functionality /// /// stream to read from (baseStream) /// stream under the container /// response /// container to hold on to private void Init(Stream s, PackWebResponse response, Stream owningStream, Package container) { Debug.Assert(s != null, "Logic error: base stream cannot be null"); Debug.Assert(response != null, "Logic error: response cannot be null"); _innerStream = s; _response = response; _owningStream = owningStream; _container = container; } //------------------------------------------------------ // // Public Methods // //----------------------------------------------------- ////// Return the bytes requested /// /// destination buffer /// offset to write into that buffer /// how many bytes requested ///how many bytes were written into buffer ////// Blocks until data is available. /// The read semantics, and in particular the restoration of the position in case of an /// exception, is implemented by the inner stream, i.e. the stream returned by PackWebResponse. /// public override int Read(byte[] buffer, int offset, int count) { EventTrace.EasyTraceEvent(EventTrace.Keyword.KeywordXPS, EventTrace.Level.Verbose, EventTrace.Event.WClientDRXReadStreamBegin, count); CheckDisposed(); int rslt = _innerStream.Read(buffer, offset, count); EventTrace.EasyTraceEvent(EventTrace.Keyword.KeywordXPS, EventTrace.Level.Verbose, EventTrace.Event.WClientDRXReadStreamEnd, rslt); return rslt; } ////// Seek /// /// only zero is supported /// only SeekOrigin.Begin is supported ///zero public override long Seek(long offset, SeekOrigin origin) { CheckDisposed(); return _innerStream.Seek(offset, origin); } ////// SetLength /// ///not supported public override void SetLength(long newLength) { CheckDisposed(); _innerStream.SetLength(newLength); } ////// Write /// ///not supported public override void Write(byte[] buf, int offset, int count) { CheckDisposed(); _innerStream.Write(buf, offset, count); } ////// Flush /// ///not supported public override void Flush() { CheckDisposed(); _innerStream.Flush(); } //------------------------------------------------------ // // Public Properties // //------------------------------------------------------ ////// Is stream readable? /// public override bool CanRead { get { return (!_closed && _innerStream.CanRead); } } ////// Is stream seekable? /// ///We MUST support seek as this is used to implement ILockBytes.ReadAt() public override bool CanSeek { get { return (!_closed && _innerStream.CanSeek); } } ////// Is stream writeable? /// public override bool CanWrite { get { return (!_closed && _innerStream.CanWrite); } } ////// Logical byte position in this stream /// public override long Position { get { CheckDisposed(); return _innerStream.Position; } set { CheckDisposed(); _innerStream.Position = value; } } ////// Length /// public override long Length { get { CheckDisposed(); // inner stream should always know its length because it's based on a local file // or because it's on a NetStream that can fake this return _innerStream.Length; } } //----------------------------------------------------- // // Protected Methods // //------------------------------------------------------ protected override void Dispose(bool disposing) { try { if (disposing && !_closed) { #if DEBUG if (PackWebRequestFactory._traceSwitch.Enabled) System.Diagnostics.Trace.TraceInformation("ContainerResponseStream.Dispose(bool)"); #endif _container = null; // close the Part or NetStream _innerStream.Close(); if (_owningStream != null) { // in this case, the innerStream was the part so this is the NetStream _owningStream.Close(); } } } finally { _innerStream = null; _owningStream = null; _response = null; _closed = true; base.Dispose(disposing); } } //----------------------------------------------------- // // Private Methods // //----------------------------------------------------- private void CheckDisposed() { if (_closed) throw new ObjectDisposedException("ResponseStream"); } //----------------------------------------------------- // // Private Fields // //------------------------------------------------------ private bool _closed; // prevent recursion private Stream _innerStream; // stream we are emulating private Package _container; // container to release when we are closed private Stream _owningStream; // stream under the _innerStream when opening a Part private PackWebResponse _response; // packWebResponse we can consult for reliable length } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // Microsoft Avalon // Copyright (c) Microsoft Corporation, 2001 // // File: ResponseStream.cs // // Description: Exists so that the gc lifetime for the container // and the webresponse are shared. // // This wrapper is returned for any PackWebResponse satisified // with a container. It ensures that the container lives until // the stream is closed because we are unaware of the lifetime of // the stream and the client is unaware of the existence of the // container. // // Container is never closed because it may be used by other // responses. // // History: 11/17/03 - brucemac - created // 12/11/03 - brucemac - adapted from ResponseStream // 15/10/04 - brucemac - adapted from ContainerResponseStream //----------------------------------------------------------------------------- using System; using System.Diagnostics; using System.IO; using System.IO.Packaging; // for PackWebResponse using MS.Utility; using System.Windows; namespace MS.Internal.IO.Packaging { ////// Wrap returned stream so we can release the webresponse container when the stream is closed /// internal class ResponseStream : Stream { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- ////// Wraps PackWebResponse to ensure correct lifetime handling and stream length functionality /// /// stream to read from (baseStream) /// response /// stream under the package /// container to hold on to internal ResponseStream(Stream s, PackWebResponse response, Stream owningStream, Package container) { Debug.Assert(container != null, "Logic error: use other constructor for full package request streams"); Debug.Assert(owningStream != null, "Logic error: use other constructor for full package request streams"); Init(s, response, owningStream, container); } ////// Wraps stream returned by PackWebResponse to ensure correct lifetime handlingy /// /// stream to read from (baseStream) /// webresponse to close when we close internal ResponseStream(Stream s, PackWebResponse response) { Init(s, response, null, null); } ////// Wraps PackWebResponse to ensure correct lifetime handling and stream length functionality /// /// stream to read from (baseStream) /// stream under the container /// response /// container to hold on to private void Init(Stream s, PackWebResponse response, Stream owningStream, Package container) { Debug.Assert(s != null, "Logic error: base stream cannot be null"); Debug.Assert(response != null, "Logic error: response cannot be null"); _innerStream = s; _response = response; _owningStream = owningStream; _container = container; } //------------------------------------------------------ // // Public Methods // //----------------------------------------------------- ////// Return the bytes requested /// /// destination buffer /// offset to write into that buffer /// how many bytes requested ///how many bytes were written into buffer ////// Blocks until data is available. /// The read semantics, and in particular the restoration of the position in case of an /// exception, is implemented by the inner stream, i.e. the stream returned by PackWebResponse. /// public override int Read(byte[] buffer, int offset, int count) { EventTrace.EasyTraceEvent(EventTrace.Keyword.KeywordXPS, EventTrace.Level.Verbose, EventTrace.Event.WClientDRXReadStreamBegin, count); CheckDisposed(); int rslt = _innerStream.Read(buffer, offset, count); EventTrace.EasyTraceEvent(EventTrace.Keyword.KeywordXPS, EventTrace.Level.Verbose, EventTrace.Event.WClientDRXReadStreamEnd, rslt); return rslt; } ////// Seek /// /// only zero is supported /// only SeekOrigin.Begin is supported ///zero public override long Seek(long offset, SeekOrigin origin) { CheckDisposed(); return _innerStream.Seek(offset, origin); } ////// SetLength /// ///not supported public override void SetLength(long newLength) { CheckDisposed(); _innerStream.SetLength(newLength); } ////// Write /// ///not supported public override void Write(byte[] buf, int offset, int count) { CheckDisposed(); _innerStream.Write(buf, offset, count); } ////// Flush /// ///not supported public override void Flush() { CheckDisposed(); _innerStream.Flush(); } //------------------------------------------------------ // // Public Properties // //------------------------------------------------------ ////// Is stream readable? /// public override bool CanRead { get { return (!_closed && _innerStream.CanRead); } } ////// Is stream seekable? /// ///We MUST support seek as this is used to implement ILockBytes.ReadAt() public override bool CanSeek { get { return (!_closed && _innerStream.CanSeek); } } ////// Is stream writeable? /// public override bool CanWrite { get { return (!_closed && _innerStream.CanWrite); } } ////// Logical byte position in this stream /// public override long Position { get { CheckDisposed(); return _innerStream.Position; } set { CheckDisposed(); _innerStream.Position = value; } } ////// Length /// public override long Length { get { CheckDisposed(); // inner stream should always know its length because it's based on a local file // or because it's on a NetStream that can fake this return _innerStream.Length; } } //----------------------------------------------------- // // Protected Methods // //------------------------------------------------------ protected override void Dispose(bool disposing) { try { if (disposing && !_closed) { #if DEBUG if (PackWebRequestFactory._traceSwitch.Enabled) System.Diagnostics.Trace.TraceInformation("ContainerResponseStream.Dispose(bool)"); #endif _container = null; // close the Part or NetStream _innerStream.Close(); if (_owningStream != null) { // in this case, the innerStream was the part so this is the NetStream _owningStream.Close(); } } } finally { _innerStream = null; _owningStream = null; _response = null; _closed = true; base.Dispose(disposing); } } //----------------------------------------------------- // // Private Methods // //----------------------------------------------------- private void CheckDisposed() { if (_closed) throw new ObjectDisposedException("ResponseStream"); } //----------------------------------------------------- // // Private Fields // //------------------------------------------------------ private bool _closed; // prevent recursion private Stream _innerStream; // stream we are emulating private Package _container; // container to release when we are closed private Stream _owningStream; // stream under the _innerStream when opening a Part private PackWebResponse _response; // packWebResponse we can consult for reliable length } } // 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
- ListViewGroup.cs
- UnmanagedMemoryStreamWrapper.cs
- AuthenticationModulesSection.cs
- SectionInput.cs
- InstanceHandleConflictException.cs
- DocumentOrderQuery.cs
- InlinedAggregationOperator.cs
- PeerCollaborationPermission.cs
- HealthMonitoringSectionHelper.cs
- HideDisabledControlAdapter.cs
- WebPartTransformerCollection.cs
- ThemeableAttribute.cs
- ColorDialog.cs
- MappedMetaModel.cs
- SharedPersonalizationStateInfo.cs
- TextLineResult.cs
- CellConstantDomain.cs
- TableColumn.cs
- ExtentJoinTreeNode.cs
- MessageSmuggler.cs
- DataDocumentXPathNavigator.cs
- Normalization.cs
- followingquery.cs
- HandleExceptionArgs.cs
- ArgumentOutOfRangeException.cs
- TextModifier.cs
- TabControlEvent.cs
- DateTimePickerDesigner.cs
- XmlTextReaderImplHelpers.cs
- CacheMode.cs
- ProfileInfo.cs
- WorkflowServiceOperationListItem.cs
- ServiceMetadataContractBehavior.cs
- HMACSHA384.cs
- AuthenticatingEventArgs.cs
- OleStrCAMarshaler.cs
- Focus.cs
- WorkflowOperationBehavior.cs
- WindowsHyperlink.cs
- FileSecurity.cs
- PackUriHelper.cs
- SymbolMethod.cs
- Calendar.cs
- GPRECTF.cs
- TabControlToolboxItem.cs
- QueryableFilterUserControl.cs
- ListViewCommandEventArgs.cs
- AnonymousIdentificationModule.cs
- EdgeModeValidation.cs
- TimeStampChecker.cs
- brushes.cs
- COM2FontConverter.cs
- DateTimeFormat.cs
- IndexExpression.cs
- RequestCache.cs
- HttpDebugHandler.cs
- RegexStringValidator.cs
- ColorTransform.cs
- WSHttpBindingElement.cs
- unsafenativemethodstextservices.cs
- RequestSecurityTokenSerializer.cs
- smtppermission.cs
- UnsafeNativeMethods.cs
- XsdBuildProvider.cs
- SvcMapFileSerializer.cs
- _IPv6Address.cs
- MachineKeySection.cs
- MILUtilities.cs
- SemanticKeyElement.cs
- BoundingRectTracker.cs
- StylusEventArgs.cs
- _Win32.cs
- MetadataCache.cs
- TCPListener.cs
- NativeRecognizer.cs
- HtmlInputRadioButton.cs
- TreeWalker.cs
- HttpResponseHeader.cs
- CompilerState.cs
- NewItemsContextMenuStrip.cs
- CacheDependency.cs
- XmlAutoDetectWriter.cs
- MobileContainerDesigner.cs
- PaperSize.cs
- ConnectivityStatus.cs
- SymLanguageType.cs
- RoleManagerEventArgs.cs
- dsa.cs
- StartUpEventArgs.cs
- PeerReferralPolicy.cs
- DataGridHelper.cs
- ContentDefinition.cs
- ValidationRule.cs
- TabPage.cs
- AppDomainManager.cs
- ToolStripSplitStackLayout.cs
- XmlNamespaceManager.cs
- FrameworkContentElement.cs
- DataKey.cs
- backend.cs