// // System.Data.Common.DataColumnMappingCollection // // Authors: // Rodrigo Moya (rodrigo@ximian.com) // Tim Coleman (tim@timcoleman.com) // // (C) Ximian, Inc // Copyright (C) Tim Coleman, 2002-2003 // using System; using System.Collections; using System.ComponentModel; using System.Data; namespace System.Data.Common { public sealed class DataColumnMappingCollection : MarshalByRefObject, IColumnMappingCollection , IList, ICollection, IEnumerable { #region Fields ArrayList list; Hashtable sourceColumns; Hashtable dataSetColumns; #endregion // Fields #region Constructors public DataColumnMappingCollection () { list = new ArrayList (); sourceColumns = new Hashtable (); dataSetColumns = new Hashtable (); } #endregion // Constructors #region Properties [Browsable (false)] [DataSysDescription ("The number of items in the collection")] [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)] public int Count { get { return list.Count; } } [Browsable (false)] [DataSysDescription ("The specified DataColumnMapping object.")] [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)] public DataColumnMapping this [int index] { get { return (DataColumnMapping)(list[index]); } set { DataColumnMapping mapping = (DataColumnMapping)(list[index]); sourceColumns[mapping] = value; dataSetColumns[mapping] = value; list[index] = value; } } [Browsable (false)] [DataSysDescription ("DataTableMappings_Item")] [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)] public DataColumnMapping this [string sourceColumn] { get { if (!Contains(sourceColumn)) { throw new IndexOutOfRangeException("DataColumnMappingCollection doesn't contains DataColumnMapping with SourceColumn '" + sourceColumn + "'."); } return (DataColumnMapping) sourceColumns[sourceColumn]; } set { this [list.IndexOf (sourceColumns[sourceColumn])] = value; } } object ICollection.SyncRoot { get { return list.SyncRoot; } } bool ICollection.IsSynchronized { get { return list.IsSynchronized; } } object IColumnMappingCollection.this [string sourceColumn] { get { return this [sourceColumn]; } set { if (!(value is DataColumnMapping)) throw new ArgumentException (); this [sourceColumn] = (DataColumnMapping) value; } } object IList.this [int index] { get { return this[index]; } set { if (!(value is DataColumnMapping)) throw new ArgumentException (); this [index] = (DataColumnMapping) value; } } bool IList.IsReadOnly { get { return false; } } bool IList.IsFixedSize { get { return false; } } #endregion // Properties #region Methods public int Add (object value) { if (!(value is DataColumnMapping)) throw new InvalidCastException (); list.Add (value); sourceColumns[((DataColumnMapping)value).SourceColumn] = value; dataSetColumns[((DataColumnMapping)value).DataSetColumn] = value; return list.IndexOf (value); } public DataColumnMapping Add (string sourceColumn, string dataSetColumn) { DataColumnMapping mapping = new DataColumnMapping (sourceColumn, dataSetColumn); Add (mapping); return mapping; } #if NET_2_0 [MonoTODO] public void AddRange (Array values) { throw new NotImplementedException (); } #endif public void AddRange (DataColumnMapping[] values) { foreach (DataColumnMapping mapping in values) Add (mapping); } public void Clear () { list.Clear (); } public bool Contains (object value) { if (!(value is DataColumnMapping)) throw new InvalidCastException("Object is not of type DataColumnMapping"); return (list.Contains (value)); } public bool Contains (string value) { return (sourceColumns.Contains (value)); } public void CopyTo (Array array, int index) { (list.ToArray()).CopyTo(array,index); } public DataColumnMapping GetByDataSetColumn (string value) { return (DataColumnMapping)(dataSetColumns[value]); } [EditorBrowsable (EditorBrowsableState.Advanced)] public static DataColumnMapping GetColumnMappingBySchemaAction (DataColumnMappingCollection columnMappings, string sourceColumn, MissingMappingAction mappingAction) { if (columnMappings.Contains (sourceColumn)) return columnMappings[sourceColumn]; if (mappingAction == MissingMappingAction.Ignore) return null; if (mappingAction == MissingMappingAction.Error) throw new InvalidOperationException (String.Format ("Missing SourceColumn mapping for '{0}'", sourceColumn)); return new DataColumnMapping (sourceColumn, sourceColumn); } #if NET_2_0 [MonoTODO] public static DataColumn GetDataColumn (DataColumnMappingCollection columnMappings, string sourceColumn, Type dataType, DataTable dataTable, MissingMappingAction mappingAction, MissingSchemaAction schemaAction) { throw new NotImplementedException (); } #endif public IEnumerator GetEnumerator () { return list.GetEnumerator (); } IColumnMapping IColumnMappingCollection.Add (string sourceColumnName, string dataSetColumnName) { return Add (sourceColumnName, dataSetColumnName); } IColumnMapping IColumnMappingCollection.GetByDataSetColumn (string dataSetColumnName) { return GetByDataSetColumn (dataSetColumnName); } public int IndexOf (object value) { return list.IndexOf (value); } public int IndexOf (string sourceColumn) { return list.IndexOf (sourceColumns[sourceColumn]); } public int IndexOfDataSetColumn (string value) { return list.IndexOf (dataSetColumns[value]); } public void Insert (int index, object value) { list.Insert (index, value); sourceColumns[((DataColumnMapping)value).SourceColumn] = value; dataSetColumns[((DataColumnMapping)value).DataSetColumn] = value; } public void Remove (object value) { int index = list.IndexOf (value); sourceColumns.Remove(((DataColumnMapping)value).SourceColumn); dataSetColumns.Remove(((DataColumnMapping)value).DataSetColumn); if (( index < 0 ) || (index >=list.Count)) throw new ArgumentException("There is no such element in collection."); list.Remove (value); } public void RemoveAt (int index) { if (( index < 0 ) || (index >=list.Count)) throw new IndexOutOfRangeException("There is no element in collection."); Remove (list[index]); } public void RemoveAt (string sourceColumn) { RemoveAt (list.IndexOf (sourceColumns[sourceColumn])); } #endregion // Methods } }