Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / IO / __ConsoleStream.cs / 1305376 / __ConsoleStream.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** **[....] ** ** Class: ConsoleStream ** ** ** Purpose: Exposes a separate Stream for Console IO and ** handles WinCE appropriately. Also keeps us from using the ** ThreadPool for all Console output. ** ** ===========================================================*/ using System; using System.Runtime.InteropServices; using System.Security; using Microsoft.Win32; using Microsoft.Win32.SafeHandles; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Threading; using System.Diagnostics.Contracts; namespace System.IO { internal sealed class __ConsoleStream : Stream { internal const int DefaultBufferSize = 128; // From winerror.h private const int ERROR_BROKEN_PIPE = 109; // ERROR_NO_DATA ("The pipe is being closed") is returned when we write to // a console that is closing. private const int ERROR_NO_DATA = 232; [System.Security.SecurityCritical /*auto-generated*/] private SafeFileHandle _handle; private bool _canRead; private bool _canWrite; [System.Security.SecurityCritical] // auto-generated [ResourceExposure(ResourceScope.Process)] internal __ConsoleStream(SafeFileHandle handle, FileAccess access) { Contract.Assert(handle != null && !handle.IsInvalid, "__ConsoleStream expects a valid handle!"); _handle = handle; _canRead = access == FileAccess.Read; _canWrite = access == FileAccess.Write; } public override bool CanRead { [Pure] get { return _canRead; } } public override bool CanWrite { [Pure] get { return _canWrite; } } public override bool CanSeek { [Pure] get { return false; } } public override long Length { get { __Error.SeekNotSupported(); return 0; // compiler appeasement } } public override long Position { get { __Error.SeekNotSupported(); return 0; // compiler appeasement } set { __Error.SeekNotSupported(); } } [System.Security.SecuritySafeCritical] // auto-generated protected override void Dispose(bool disposing) { // We're probably better off not closing the OS handle here. First, // we allow a program to get multiple instances of __ConsoleStreams // around the same OS handle, so closing one handle would invalidate // them all. Additionally, we want a second AppDomain to be able to // write to stdout if a second AppDomain quits. if (_handle != null) { _handle = null; } _canRead = false; _canWrite = false; base.Dispose(disposing); } [System.Security.SecuritySafeCritical] // auto-generated public override void Flush() { if (_handle == null) __Error.FileNotOpen(); if (!CanWrite) __Error.WriteNotSupported(); } public override void SetLength(long value) { __Error.SeekNotSupported(); } [System.Security.SecuritySafeCritical] // auto-generated [ResourceExposure(ResourceScope.None)] [ResourceConsumption(ResourceScope.Process, ResourceScope.Process)] public override int Read([In, Out] byte[] buffer, int offset, int count) { if (buffer==null) throw new ArgumentNullException("buffer"); if (offset < 0 || count < 0) throw new ArgumentOutOfRangeException((offset < 0 ? "offset" : "count"), Environment.GetResourceString("ArgumentOutOfRange_NeedNonNegNum")); if (buffer.Length - offset < count) throw new ArgumentException(Environment.GetResourceString("Argument_InvalidOffLen")); Contract.EndContractBlock(); if (!_canRead) __Error.ReadNotSupported(); int errorCode = 0; int result = ReadFileNative(_handle, buffer, offset, count, 0, out errorCode); if (result == -1) { __Error.WinIOError(errorCode, String.Empty); } return result; } public override long Seek(long offset, SeekOrigin origin) { __Error.SeekNotSupported(); return 0; // compiler appeasement } [System.Security.SecuritySafeCritical] // auto-generated [ResourceExposure(ResourceScope.None)] [ResourceConsumption(ResourceScope.Process, ResourceScope.Process)] public override void Write(byte[] buffer, int offset, int count) { if (buffer==null) throw new ArgumentNullException("buffer"); if (offset < 0 || count < 0) throw new ArgumentOutOfRangeException((offset < 0 ? "offset" : "count"), Environment.GetResourceString("ArgumentOutOfRange_NeedNonNegNum")); if (buffer.Length - offset < count) throw new ArgumentException(Environment.GetResourceString("Argument_InvalidOffLen")); Contract.EndContractBlock(); if (!_canWrite) __Error.WriteNotSupported(); int errorCode = 0; int result = WriteFileNative(_handle, buffer, offset, count, 0, out errorCode); if (result == -1) { //BCLDebug.ConsoleError("__ConsoleStream::Write: throwing on error. Error code: "+errorCode+" 0x"+errorCode.ToString("x")+" handle: "+_handle.ToString()); __Error.WinIOError(errorCode, String.Empty); } return; } // P/Invoke wrappers for writing to and from a file, nearly identical // to the ones on FileStream. These are duplicated to save startup/hello // world working set. [System.Security.SecurityCritical] // auto-generated [ResourceExposure(ResourceScope.Process)] [ResourceConsumption(ResourceScope.Process)] private unsafe static int ReadFileNative(SafeFileHandle hFile, byte[] bytes, int offset, int count, int mustBeZero, out int errorCode) { Contract.Requires(offset >= 0, "offset >= 0"); Contract.Requires(count >= 0, "count >= 0"); Contract.Requires(bytes != null, "bytes != null"); // Don't corrupt memory when multiple threads are erroneously writing // to this stream simultaneously. if (bytes.Length - offset < count) throw new IndexOutOfRangeException(Environment.GetResourceString("IndexOutOfRange_IORaceCondition")); Contract.EndContractBlock(); // You can't use the fixed statement on an array of length 0. if (bytes.Length==0) { errorCode = 0; return 0; } // First, wait bytes to become available. This is preferable to letting ReadFile block, // since ReadFile is not abortable (via Thread.Abort), while WaitForAvailableConsoleInput is. WaitForAvailableConsoleInput(hFile); int r; int numBytesRead; fixed(byte* p = bytes) { r = ReadFile(hFile, p + offset, count, out numBytesRead, Win32Native.NULL); } if (r==0) { errorCode = Marshal.GetLastWin32Error(); if (errorCode == ERROR_BROKEN_PIPE) { // A pipe into stdin was closed. Not an error, but EOF. return 0; } return -1; } else errorCode = 0; return numBytesRead; } [System.Security.SecurityCritical] // auto-generated [ResourceExposure(ResourceScope.Process)] [ResourceConsumption(ResourceScope.Process)] private static unsafe int WriteFileNative(SafeFileHandle hFile, byte[] bytes, int offset, int count, int mustBeZero, out int errorCode) { Contract.Requires(offset >= 0, "offset >= 0"); Contract.Requires(count >= 0, "count >= 0"); Contract.Requires(bytes != null, "bytes != null"); Contract.Requires(bytes.Length >= offset + count, "bytes.Length >= offset + count"); // You can't use the fixed statement on an array of length 0. if (bytes.Length==0) { errorCode = 0; return 0; } int numBytesWritten = 0; int r; fixed(byte* p = bytes) { r = WriteFile(hFile, p + offset, count, out numBytesWritten, Win32Native.NULL); } if (r==0) { errorCode = Marshal.GetLastWin32Error(); // For pipes that are closing or broken, just stop. if (errorCode==ERROR_NO_DATA || errorCode==ERROR_BROKEN_PIPE) return 0; return -1; } else { errorCode = 0; } return numBytesWritten; } // The P/Invoke declarations for ReadFile and WriteFile are here for a reason! This prevents us from loading several classes // in the trivial hello world case. [System.Security.SecurityCritical] // auto-generated [DllImport(Win32Native.KERNEL32, SetLastError=true)] [SuppressUnmanagedCodeSecurityAttribute] [ResourceExposure(ResourceScope.Process)] unsafe private static extern int ReadFile(SafeFileHandle handle, byte* bytes, int numBytesToRead, out int numBytesRead, IntPtr mustBeZero); [System.Security.SecurityCritical] // auto-generated [DllImport(Win32Native.KERNEL32, SetLastError=true)] [SuppressUnmanagedCodeSecurityAttribute] [ResourceExposure(ResourceScope.Process)] internal static unsafe extern int WriteFile(SafeFileHandle handle, byte* bytes, int numBytesToWrite, out int numBytesWritten, IntPtr mustBeZero); [System.Security.SecurityCritical] // auto-generated [MethodImplAttribute(MethodImplOptions.InternalCall)] private static extern void WaitForAvailableConsoleInput(SafeFileHandle file); } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** **[....] ** ** Class: ConsoleStream ** ** ** Purpose: Exposes a separate Stream for Console IO and ** handles WinCE appropriately. Also keeps us from using the ** ThreadPool for all Console output. ** ** ===========================================================*/ using System; using System.Runtime.InteropServices; using System.Security; using Microsoft.Win32; using Microsoft.Win32.SafeHandles; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Threading; using System.Diagnostics.Contracts; namespace System.IO { internal sealed class __ConsoleStream : Stream { internal const int DefaultBufferSize = 128; // From winerror.h private const int ERROR_BROKEN_PIPE = 109; // ERROR_NO_DATA ("The pipe is being closed") is returned when we write to // a console that is closing. private const int ERROR_NO_DATA = 232; [System.Security.SecurityCritical /*auto-generated*/] private SafeFileHandle _handle; private bool _canRead; private bool _canWrite; [System.Security.SecurityCritical] // auto-generated [ResourceExposure(ResourceScope.Process)] internal __ConsoleStream(SafeFileHandle handle, FileAccess access) { Contract.Assert(handle != null && !handle.IsInvalid, "__ConsoleStream expects a valid handle!"); _handle = handle; _canRead = access == FileAccess.Read; _canWrite = access == FileAccess.Write; } public override bool CanRead { [Pure] get { return _canRead; } } public override bool CanWrite { [Pure] get { return _canWrite; } } public override bool CanSeek { [Pure] get { return false; } } public override long Length { get { __Error.SeekNotSupported(); return 0; // compiler appeasement } } public override long Position { get { __Error.SeekNotSupported(); return 0; // compiler appeasement } set { __Error.SeekNotSupported(); } } [System.Security.SecuritySafeCritical] // auto-generated protected override void Dispose(bool disposing) { // We're probably better off not closing the OS handle here. First, // we allow a program to get multiple instances of __ConsoleStreams // around the same OS handle, so closing one handle would invalidate // them all. Additionally, we want a second AppDomain to be able to // write to stdout if a second AppDomain quits. if (_handle != null) { _handle = null; } _canRead = false; _canWrite = false; base.Dispose(disposing); } [System.Security.SecuritySafeCritical] // auto-generated public override void Flush() { if (_handle == null) __Error.FileNotOpen(); if (!CanWrite) __Error.WriteNotSupported(); } public override void SetLength(long value) { __Error.SeekNotSupported(); } [System.Security.SecuritySafeCritical] // auto-generated [ResourceExposure(ResourceScope.None)] [ResourceConsumption(ResourceScope.Process, ResourceScope.Process)] public override int Read([In, Out] byte[] buffer, int offset, int count) { if (buffer==null) throw new ArgumentNullException("buffer"); if (offset < 0 || count < 0) throw new ArgumentOutOfRangeException((offset < 0 ? "offset" : "count"), Environment.GetResourceString("ArgumentOutOfRange_NeedNonNegNum")); if (buffer.Length - offset < count) throw new ArgumentException(Environment.GetResourceString("Argument_InvalidOffLen")); Contract.EndContractBlock(); if (!_canRead) __Error.ReadNotSupported(); int errorCode = 0; int result = ReadFileNative(_handle, buffer, offset, count, 0, out errorCode); if (result == -1) { __Error.WinIOError(errorCode, String.Empty); } return result; } public override long Seek(long offset, SeekOrigin origin) { __Error.SeekNotSupported(); return 0; // compiler appeasement } [System.Security.SecuritySafeCritical] // auto-generated [ResourceExposure(ResourceScope.None)] [ResourceConsumption(ResourceScope.Process, ResourceScope.Process)] public override void Write(byte[] buffer, int offset, int count) { if (buffer==null) throw new ArgumentNullException("buffer"); if (offset < 0 || count < 0) throw new ArgumentOutOfRangeException((offset < 0 ? "offset" : "count"), Environment.GetResourceString("ArgumentOutOfRange_NeedNonNegNum")); if (buffer.Length - offset < count) throw new ArgumentException(Environment.GetResourceString("Argument_InvalidOffLen")); Contract.EndContractBlock(); if (!_canWrite) __Error.WriteNotSupported(); int errorCode = 0; int result = WriteFileNative(_handle, buffer, offset, count, 0, out errorCode); if (result == -1) { //BCLDebug.ConsoleError("__ConsoleStream::Write: throwing on error. Error code: "+errorCode+" 0x"+errorCode.ToString("x")+" handle: "+_handle.ToString()); __Error.WinIOError(errorCode, String.Empty); } return; } // P/Invoke wrappers for writing to and from a file, nearly identical // to the ones on FileStream. These are duplicated to save startup/hello // world working set. [System.Security.SecurityCritical] // auto-generated [ResourceExposure(ResourceScope.Process)] [ResourceConsumption(ResourceScope.Process)] private unsafe static int ReadFileNative(SafeFileHandle hFile, byte[] bytes, int offset, int count, int mustBeZero, out int errorCode) { Contract.Requires(offset >= 0, "offset >= 0"); Contract.Requires(count >= 0, "count >= 0"); Contract.Requires(bytes != null, "bytes != null"); // Don't corrupt memory when multiple threads are erroneously writing // to this stream simultaneously. if (bytes.Length - offset < count) throw new IndexOutOfRangeException(Environment.GetResourceString("IndexOutOfRange_IORaceCondition")); Contract.EndContractBlock(); // You can't use the fixed statement on an array of length 0. if (bytes.Length==0) { errorCode = 0; return 0; } // First, wait bytes to become available. This is preferable to letting ReadFile block, // since ReadFile is not abortable (via Thread.Abort), while WaitForAvailableConsoleInput is. WaitForAvailableConsoleInput(hFile); int r; int numBytesRead; fixed(byte* p = bytes) { r = ReadFile(hFile, p + offset, count, out numBytesRead, Win32Native.NULL); } if (r==0) { errorCode = Marshal.GetLastWin32Error(); if (errorCode == ERROR_BROKEN_PIPE) { // A pipe into stdin was closed. Not an error, but EOF. return 0; } return -1; } else errorCode = 0; return numBytesRead; } [System.Security.SecurityCritical] // auto-generated [ResourceExposure(ResourceScope.Process)] [ResourceConsumption(ResourceScope.Process)] private static unsafe int WriteFileNative(SafeFileHandle hFile, byte[] bytes, int offset, int count, int mustBeZero, out int errorCode) { Contract.Requires(offset >= 0, "offset >= 0"); Contract.Requires(count >= 0, "count >= 0"); Contract.Requires(bytes != null, "bytes != null"); Contract.Requires(bytes.Length >= offset + count, "bytes.Length >= offset + count"); // You can't use the fixed statement on an array of length 0. if (bytes.Length==0) { errorCode = 0; return 0; } int numBytesWritten = 0; int r; fixed(byte* p = bytes) { r = WriteFile(hFile, p + offset, count, out numBytesWritten, Win32Native.NULL); } if (r==0) { errorCode = Marshal.GetLastWin32Error(); // For pipes that are closing or broken, just stop. if (errorCode==ERROR_NO_DATA || errorCode==ERROR_BROKEN_PIPE) return 0; return -1; } else { errorCode = 0; } return numBytesWritten; } // The P/Invoke declarations for ReadFile and WriteFile are here for a reason! This prevents us from loading several classes // in the trivial hello world case. [System.Security.SecurityCritical] // auto-generated [DllImport(Win32Native.KERNEL32, SetLastError=true)] [SuppressUnmanagedCodeSecurityAttribute] [ResourceExposure(ResourceScope.Process)] unsafe private static extern int ReadFile(SafeFileHandle handle, byte* bytes, int numBytesToRead, out int numBytesRead, IntPtr mustBeZero); [System.Security.SecurityCritical] // auto-generated [DllImport(Win32Native.KERNEL32, SetLastError=true)] [SuppressUnmanagedCodeSecurityAttribute] [ResourceExposure(ResourceScope.Process)] internal static unsafe extern int WriteFile(SafeFileHandle handle, byte* bytes, int numBytesToWrite, out int numBytesWritten, IntPtr mustBeZero); [System.Security.SecurityCritical] // auto-generated [MethodImplAttribute(MethodImplOptions.InternalCall)] private static extern void WaitForAvailableConsoleInput(SafeFileHandle file); } } // 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
- ConfigXmlCDataSection.cs
- ContextTokenTypeConverter.cs
- ScrollContentPresenter.cs
- RelationalExpressions.cs
- ObjectConverter.cs
- UIElementParagraph.cs
- LoginUtil.cs
- SystemIPGlobalStatistics.cs
- HttpsHostedTransportConfiguration.cs
- EventLogHandle.cs
- UdpDiscoveryMessageFilter.cs
- RegistryConfigurationProvider.cs
- Matrix.cs
- ExceptionUtility.cs
- MouseWheelEventArgs.cs
- ControlBuilder.cs
- XmlCharCheckingReader.cs
- HotSpot.cs
- EditorPartCollection.cs
- TCPListener.cs
- indexingfiltermarshaler.cs
- SelectiveScrollingGrid.cs
- TextComposition.cs
- StyleTypedPropertyAttribute.cs
- ArrayHelper.cs
- DataGridItemEventArgs.cs
- BookmarkUndoUnit.cs
- InlineObject.cs
- StrokeFIndices.cs
- WebPartVerb.cs
- HttpHandler.cs
- PersistenceTypeAttribute.cs
- ArraySortHelper.cs
- DnsPermission.cs
- BinaryConverter.cs
- BinaryMethodMessage.cs
- HttpsTransportElement.cs
- EnumBuilder.cs
- RayHitTestParameters.cs
- Vector3DCollectionConverter.cs
- EntitySqlQueryState.cs
- EventPrivateKey.cs
- MsmqIntegrationInputMessage.cs
- XmlExceptionHelper.cs
- RemotingConfiguration.cs
- Geometry3D.cs
- Ticks.cs
- XmlNamedNodeMap.cs
- HelpEvent.cs
- ColorAnimation.cs
- TemplateControlParser.cs
- AlternateViewCollection.cs
- RegexMatchCollection.cs
- OracleEncoding.cs
- CssStyleCollection.cs
- BinaryReader.cs
- LogEntryHeaderSerializer.cs
- ObjectListField.cs
- KnownTypesHelper.cs
- PriorityBinding.cs
- loginstatus.cs
- COM2AboutBoxPropertyDescriptor.cs
- LockCookie.cs
- X509UI.cs
- PropertyValue.cs
- DEREncoding.cs
- IndependentlyAnimatedPropertyMetadata.cs
- FormatException.cs
- TypedTableBase.cs
- GlobalItem.cs
- DataGridViewCellStyleConverter.cs
- CleanUpVirtualizedItemEventArgs.cs
- FixedPage.cs
- EntityDataSourceEntitySetNameItem.cs
- BadImageFormatException.cs
- SerializationInfoEnumerator.cs
- AnimatedTypeHelpers.cs
- ListViewVirtualItemsSelectionRangeChangedEvent.cs
- FormatException.cs
- ModifierKeysConverter.cs
- AuthStoreRoleProvider.cs
- BaseUriHelper.cs
- TextSimpleMarkerProperties.cs
- SpecularMaterial.cs
- WebPartVerb.cs
- SpeechAudioFormatInfo.cs
- NegotiationTokenProvider.cs
- mongolianshape.cs
- ParseNumbers.cs
- X509ThumbprintKeyIdentifierClause.cs
- RenderOptions.cs
- LineSegment.cs
- TargetInvocationException.cs
- ProcessThreadCollection.cs
- OdbcEnvironment.cs
- ToolStripButton.cs
- SingleResultAttribute.cs
- SqlCommand.cs
- XmlDataContract.cs
- StylusPointDescription.cs