2 // System.Data.SqlClient.DbEnumerator.cs
5 // Tim Coleman (tim@timcoleman.com)
7 // Copyright (C) Tim Coleman, 2002
11 using System.Collections;
12 using System.ComponentModel;
15 namespace System.Data.Common {
16 public class DbEnumerator : IEnumerator
23 FieldNameLookup lookup;
30 public DbEnumerator (IDataReader reader)
31 : this (reader, false)
35 public DbEnumerator (IDataReader reader, bool closeReader)
38 this.closeReader = closeReader;
39 this.lookup = new FieldNameLookup ();
40 this.fieldCount = reader.FieldCount;
41 LoadSchema (reader.GetSchemaTable ());
44 #endregion // Constructors
48 public object Current {
50 object[] values = new object[fieldCount];
51 reader.GetValues (values);
52 return new DbDataRecord (schema, values, lookup);
56 #endregion // Properties
60 private void LoadSchema (DataTable schemaTable)
62 schema = new SchemaInfo [fieldCount];
64 foreach (DataRow row in schemaTable.Rows) {
65 SchemaInfo columnSchema = new SchemaInfo ();
67 lookup.Add ((string) row["ColumnName"]);
69 columnSchema.AllowDBNull = (bool) row ["AllowDBNull"];
70 columnSchema.ColumnName = row ["ColumnName"].ToString ();
71 columnSchema.ColumnOrdinal = (int) row ["ColumnOrdinal"];
72 columnSchema.ColumnSize = (int) row ["ColumnSize"];
73 columnSchema.DataTypeName = reader.GetDataTypeName (index);
74 columnSchema.FieldType = reader.GetFieldType (index);
75 columnSchema.IsReadOnly = (bool) row ["IsReadOnly"];
76 columnSchema.TableName = row ["BaseTableName"].ToString ();
78 if (row ["NumericPrecision"] != DBNull.Value)
79 columnSchema.NumericPrecision = (byte) row ["NumericPrecision"];
81 columnSchema.NumericPrecision = (byte) 0;
83 if (row ["NumericScale"] != DBNull.Value)
84 columnSchema.NumericScale = (byte) row ["NumericScale"];
86 columnSchema.NumericScale = (byte) 0;
88 schema [index] = columnSchema;
93 public bool MoveNext ()
102 [EditorBrowsable (EditorBrowsableState.Never)]
105 throw new NotSupportedException ();
108 #endregion // Methods