// // System.Data.Common.DbDataReader.cs // // Author: // Tim Coleman (tim@timcoleman.com) // // Copyright (C) Tim Coleman, 2003 // // // Copyright (C) 2004 Novell, Inc (http://www.novell.com) // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // using System.Collections; using System.ComponentModel; using System.Data; using System.IO; using System.Threading; using System.Threading.Tasks; namespace System.Data.Common { public abstract class DbDataReader : MarshalByRefObject, IDataReader, IDataRecord, IDisposable, IEnumerable { #region Constructors protected DbDataReader () { } #endregion // Constructors #region Properties public abstract int Depth { get; } public abstract int FieldCount { get; } public abstract bool HasRows { get; } public abstract bool IsClosed { get; } public abstract object this [int ordinal] { get; } public abstract object this [string name] { get; } public abstract int RecordsAffected { get; } public virtual int VisibleFieldCount { get { return FieldCount; } } #endregion // Properties #region Methods public abstract void Close (); public abstract bool GetBoolean (int ordinal); public abstract byte GetByte (int ordinal); public abstract long GetBytes (int ordinal, long dataOffset, byte[] buffer, int bufferOffset, int length); public abstract char GetChar (int ordinal); public abstract long GetChars (int ordinal, long dataOffset, char[] buffer, int bufferOffset, int length); [EditorBrowsable (EditorBrowsableState.Never)] public void Dispose () { Dispose (true); } protected virtual void Dispose (bool disposing) { if (disposing) Close (); } [EditorBrowsable (EditorBrowsableState.Never)] public DbDataReader GetData (int ordinal) { return ((DbDataReader) this [ordinal]); } public abstract string GetDataTypeName (int ordinal); public abstract DateTime GetDateTime (int ordinal); public abstract decimal GetDecimal (int ordinal); public abstract double GetDouble (int ordinal); [EditorBrowsable (EditorBrowsableState.Never)] public abstract IEnumerator GetEnumerator (); public abstract Type GetFieldType (int ordinal); public abstract float GetFloat (int ordinal); public abstract Guid GetGuid (int ordinal); public abstract short GetInt16 (int ordinal); public abstract int GetInt32 (int ordinal); public abstract long GetInt64 (int ordinal); public abstract string GetName (int ordinal); public abstract int GetOrdinal (string name); [EditorBrowsable (EditorBrowsableState.Never)] public virtual Type GetProviderSpecificFieldType (int ordinal) { return GetFieldType (ordinal); } [EditorBrowsable (EditorBrowsableState.Never)] public virtual object GetProviderSpecificValue (int ordinal) { return GetValue (ordinal); } [EditorBrowsable (EditorBrowsableState.Never)] public virtual int GetProviderSpecificValues (object[] values) { return GetValues (values); } protected virtual DbDataReader GetDbDataReader (int ordinal) { return ((DbDataReader) this [ordinal]); } public abstract DataTable GetSchemaTable (); public abstract string GetString (int ordinal); public abstract object GetValue (int ordinal); public abstract int GetValues (object[] values); IDataReader IDataRecord.GetData (int ordinal) { return ((IDataReader) this).GetData (ordinal); } public abstract bool IsDBNull (int ordinal); public abstract bool NextResult (); public abstract bool Read (); internal static DataTable GetSchemaTableTemplate () { Type booleanType = typeof (bool); Type stringType = typeof (string); Type intType = typeof (int); Type typeType = typeof (Type); Type shortType = typeof (short); DataTable schemaTable = new DataTable ("SchemaTable"); schemaTable.Columns.Add ("ColumnName", stringType); schemaTable.Columns.Add ("ColumnOrdinal", intType); schemaTable.Columns.Add ("ColumnSize", intType); schemaTable.Columns.Add ("NumericPrecision", shortType); schemaTable.Columns.Add ("NumericScale", shortType); schemaTable.Columns.Add ("IsUnique", booleanType); schemaTable.Columns.Add ("IsKey", booleanType); schemaTable.Columns.Add ("BaseServerName", stringType); schemaTable.Columns.Add ("BaseCatalogName", stringType); schemaTable.Columns.Add ("BaseColumnName", stringType); schemaTable.Columns.Add ("BaseSchemaName", stringType); schemaTable.Columns.Add ("BaseTableName", stringType); schemaTable.Columns.Add ("DataType", typeType); schemaTable.Columns.Add ("AllowDBNull", booleanType); schemaTable.Columns.Add ("ProviderType", intType); schemaTable.Columns.Add ("IsAliased", booleanType); schemaTable.Columns.Add ("IsExpression", booleanType); schemaTable.Columns.Add ("IsIdentity", booleanType); schemaTable.Columns.Add ("IsAutoIncrement", booleanType); schemaTable.Columns.Add ("IsRowVersion", booleanType); schemaTable.Columns.Add ("IsHidden", booleanType); schemaTable.Columns.Add ("IsLong", booleanType); schemaTable.Columns.Add ("IsReadOnly", booleanType); return schemaTable; } public virtual T GetFieldValue (int i) { return (T) GetValue (i); } public Task GetFieldValueAsync (int ordinal) { return GetFieldValueAsync (ordinal, CancellationToken.None); } public virtual Task GetFieldValueAsync (int ordinal, CancellationToken cancellationToken) { if (cancellationToken.IsCancellationRequested) { return TaskHelper.CreateCanceledTask (); } try { return Task.FromResult (GetFieldValue (ordinal)); } catch (Exception e) { return TaskHelper.CreateExceptionTask (e); } } public Task NextResultAsync () { return NextResultAsync (CancellationToken.None); } public Task IsDBNullAsync (int ordinal) { return IsDBNullAsync (ordinal, CancellationToken.None); } public virtual Stream GetStream (int i) { long offset = 0L; byte [] buffer = new byte [1024 * 8]; long read; MemoryStream memoryStream = new MemoryStream (); while ((read = this.GetBytes (i, offset, buffer, 0, buffer.Length)) > 0) { memoryStream.Write (buffer, 0, (int) read); offset += read; } memoryStream.Seek (0, SeekOrigin.Begin); return memoryStream; } public virtual TextReader GetTextReader (int i) { String value; if (IsDBNull (i)) value = string.Empty; else value = this.GetString (i); return new StringReader (value); } public virtual Task IsDBNullAsync (int ordinal, CancellationToken cancellationToken) { if (cancellationToken.IsCancellationRequested) { return TaskHelper.CreateCanceledTask (); } try { return Task.FromResult (IsDBNull (ordinal)); } catch (Exception e) { return TaskHelper.CreateExceptionTask (e); } } public virtual Task NextResultAsync (CancellationToken cancellationToken) { if (cancellationToken.IsCancellationRequested) { return TaskHelper.CreateCanceledTask (); } try { return Task.FromResult (NextResult ()); } catch (Exception e) { return TaskHelper.CreateExceptionTask (e); } } public Task ReadAsync () { return ReadAsync (CancellationToken.None); } public virtual Task ReadAsync (CancellationToken cancellationToken) { if (cancellationToken.IsCancellationRequested) { return TaskHelper.CreateCanceledTask (); } try { return Task.FromResult (Read ()); } catch (Exception e) { return TaskHelper.CreateExceptionTask (e); } } #endregion // Methods } }