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
- GroupStyle.cs
- KnownBoxes.cs
- XamlTypeMapper.cs
- CodeDomComponentSerializationService.cs
- DefaultPerformanceCounters.cs
- EntityUtil.cs
- DynamicPropertyHolder.cs
- MonthChangedEventArgs.cs
- DrawListViewSubItemEventArgs.cs
- DateTimePicker.cs
- RangeContentEnumerator.cs
- COM2TypeInfoProcessor.cs
- DataSourceCache.cs
- _ListenerRequestStream.cs
- XmlAttribute.cs
- GeneralTransform.cs
- HandleRef.cs
- XmlDataSourceView.cs
- DataPagerFieldCollection.cs
- BrowsableAttribute.cs
- ArgumentNullException.cs
- HasCopySemanticsAttribute.cs
- WebBrowsableAttribute.cs
- ClrPerspective.cs
- NamespaceInfo.cs
- XAMLParseException.cs
- ReferenceAssemblyAttribute.cs
- SqlDependency.cs
- UntypedNullExpression.cs
- DemultiplexingClientMessageFormatter.cs
- dsa.cs
- LinkButton.cs
- ScriptResourceAttribute.cs
- PenLineJoinValidation.cs
- EventMemberCodeDomSerializer.cs
- Track.cs
- XPathException.cs
- CapabilitiesState.cs
- ConnectionManagementElement.cs
- _PooledStream.cs
- SystemTcpStatistics.cs
- DashStyle.cs
- OracleEncoding.cs
- ClrProviderManifest.cs
- CodeFieldReferenceExpression.cs
- SafeRightsManagementPubHandle.cs
- SingleResultAttribute.cs
- IriParsingElement.cs
- OleDbParameterCollection.cs
- SecurityResources.cs
- StateManagedCollection.cs
- TabRenderer.cs
- SecureStringHasher.cs
- TextTreeExtractElementUndoUnit.cs
- CompiledQueryCacheEntry.cs
- BindingsCollection.cs
- LineSegment.cs
- CodeArrayCreateExpression.cs
- GetPageCompletedEventArgs.cs
- Timer.cs
- CngAlgorithm.cs
- DesignBindingPropertyDescriptor.cs
- LineServicesRun.cs
- DataGridViewControlCollection.cs
- XamlTypeWithExplicitNamespace.cs
- SystemResources.cs
- ZipIOFileItemStream.cs
- ToolStripItemEventArgs.cs
- Point4D.cs
- TypeLibConverter.cs
- EditorOptionAttribute.cs
- util.cs
- Single.cs
- MDIWindowDialog.cs
- DependencyObject.cs
- XPathNodeHelper.cs
- EntityDataSourceContainerNameConverter.cs
- ParamArrayAttribute.cs
- OlePropertyStructs.cs
- TemplateParser.cs
- Section.cs
- ColumnMapVisitor.cs
- ContractBase.cs
- WindowsToolbarAsMenu.cs
- SeverityFilter.cs
- TdsParserSessionPool.cs
- UriGenerator.cs
- METAHEADER.cs
- Utility.cs
- HttpApplication.cs
- RuleSettingsCollection.cs
- LineProperties.cs
- SchemaEntity.cs
- UnauthorizedAccessException.cs
- PolygonHotSpot.cs
- HttpPostedFileWrapper.cs
- XmlNodeChangedEventArgs.cs
- DesignerSerializationOptionsAttribute.cs
- DataGridViewTopRowAccessibleObject.cs
- SafeRightsManagementEnvironmentHandle.cs