* SqlConnection.cs: Removed extra destructor, as destructor on
[mono.git] / mcs / class / System.Data / System.Data.SqlClient / SqlParameterCollection.cs
index c70e333b861b8c644838734f7e0287d75cf75f5b..819b5509c9022f5f6699f488b53add4340f1cbaf 100644 (file)
 // Author:
 //   Rodrigo Moya (rodrigo@ximian.com)
 //   Daniel Morgan (danmorg@sc.rr.com)
+//   Tim Coleman (tim@timcoleman.com)
+//   Diego Caravana (diego@toth.it)
+//   Umadevi S (sumadevi@novell.com)
 //
 // (C) Ximian, Inc 2002
+// Copyright (C) Tim Coleman, 2002
 //
 
+//
+// 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 Mono.Data.Tds;
 using System;
 using System.ComponentModel;
 using System.Data;
 using System.Data.Common;
+
+#if NET_2_0
+using System.Data.ProviderBase;
+#endif // NET_2_0
+
 using System.Collections;
 
 namespace System.Data.SqlClient {
-       /// <summary>
-       /// Collects all parameters relevant to a Command object 
-       /// and their mappings to DataSet columns.
-       /// </summary>
+       [ListBindable (false)]
+       [Editor ("Microsoft.VSDesigner.Data.Design.DBParametersEditor, " + Consts.AssemblyMicrosoft_VSDesigner,
+                "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
+#if NET_2_0
+       public sealed class SqlParameterCollection : DbParameterBaseCollection, IDataParameterCollection, IList, ICollection, IEnumerable
+#else
        public sealed class SqlParameterCollection : MarshalByRefObject, IDataParameterCollection, IList, ICollection, IEnumerable
+#endif // NET_2_0
        {
-               private ArrayList parameterList = new ArrayList();
+               #region Fields
+
+               ArrayList list = new ArrayList();
+               TdsMetaParameterCollection metaParameters;
+               SqlCommand command;
+
+               #endregion // Fields
+
+               #region Constructors
 
-               [MonoTODO]
-               public IEnumerator GetEnumerator()
+               internal SqlParameterCollection (SqlCommand command)
                {
-                       throw new NotImplementedException ();
+                       this.command = command;
+                       metaParameters = new TdsMetaParameterCollection ();
                }
 
-               
-               public int Add( object value)
+               #endregion // Constructors
+
+               #region Properties
+#if ONLY_1_1 || ONLY_1_0
+               [Browsable (false)]
+               [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]      
+#endif
+
+
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        int Count {
+                       get { return list.Count; }                        
+               }
+
+#if NET_2_0
+               public override bool IsFixedSize {
+                       get {
+                               return list.IsFixedSize;
+                       }       
+               }
+
+               public override bool IsReadOnly {
+                       get {
+                               return list.IsReadOnly;
+                       }
+               }
+
+               public override bool IsSynchronized {
+                       get {
+                               return list.IsSynchronized;
+                       }
+               }
+
+               public override object SyncRoot {
+                       get {
+                               return list.SyncRoot;
+                       }
+               }
+       
+
+#endif
+
+               [Browsable (false)]
+               [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]      
+               public 
+#if NET_2_0
+               new
+#endif // NET_2_0
+        SqlParameter this [int index] {
+                       get { return (SqlParameter) list [index]; }                       
+                       set { list [index] = (SqlParameter) value; }                      
+               }
+
+               object IDataParameterCollection.this [string parameterName] {
+                       get { return this[parameterName]; }
+                       set { 
+                               if (!(value is SqlParameter))
+                                       throw new InvalidCastException ("Only SQLParameter objects can be used.");
+                               this [parameterName] = (SqlParameter) value;
+                       }
+               }
+
+               [Browsable (false)]
+               [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]      
+               public 
+#if NET_2_0
+               new
+#endif // NET_2_0
+        SqlParameter this [string parameterName] {
+                       get {
+                               foreach (SqlParameter p in list)
+                                       if (p.ParameterName.Equals (parameterName))
+                                               return p;
+                               throw new IndexOutOfRangeException ("The specified name does not exist: " + parameterName);
+                       }         
+                       set {   
+                               if (!Contains (parameterName))
+                                       throw new IndexOutOfRangeException("The specified name does not exist: " + parameterName);
+                               this [IndexOf (parameterName)] = value;
+                       }                         
+               }
+
+#if NET_2_0
+               protected  override DbParameter GetParameter (int index)
                {
-                       // Call the add version that receives a SqlParameter 
-                       
-                       // Check if value is a SqlParameter.
-                       CheckType(value);
-                       Add((SqlParameter) value);
+                       throw new NotImplementedException();
+               }
 
-                       return IndexOf (value);
+               protected override DbParameter GetParameter (string parameterName)
+               {
+                       throw new NotImplementedException ();
+               }
+       
+               protected  override void SetParameter (int index, DbParameter value)
+               {
+                        throw new NotImplementedException();
+                }
+               protected override void SetParameter (string parameterName, DbParameter value)
+               {
+                        throw new NotImplementedException();
+                }
+               /*public IEnumerator GetEnumerator ()
+               /*public IEnumerator GetEnumerator ()
+                        {
+                        throw new NotImplementedException();
+                }*/
+
+
+               protected override Type ItemType 
+               { 
+                       get {
+                               throw new NotImplementedException();
+                       }
+
+                }                                                          
+
+                                                                                                    
+#endif
+               object IList.this [int index] {
+                       get { return (SqlParameter) this [index]; }
+                       set { this [index] = (SqlParameter) value; }
                }
 
+               bool IList.IsFixedSize {
+                       get { return list.IsFixedSize; }
+               }
+
+               bool IList.IsReadOnly {
+                       get { return list.IsReadOnly; }
+               }
+
+               bool ICollection.IsSynchronized {
+                       get { return list.IsSynchronized; }
+               }
+
+               object ICollection.SyncRoot {
+                       get { return list.SyncRoot; }
+               }
+
+
+
+               internal TdsMetaParameterCollection MetaParameters {
+                       get { return metaParameters; }
+               }
                
-               public SqlParameter Add(SqlParameter value)
+               #endregion // Properties
+
+               #region Methods
+
+               public  
+#if NET_2_0
+               override
+#endif // NET_2_0
+        int Add (object value)
                {
-                       parameterList.Add(value);
-                       return value;
+                       if (!(value is SqlParameter))
+                               throw new InvalidCastException ("The parameter was not an SqlParameter.");
+                       Add ((SqlParameter) value);
+                       return IndexOf (value);
                }
-
                
-               public SqlParameter Add(string parameterName, object value)
+               public SqlParameter Add (SqlParameter value)
                {
-                       SqlParameter sqlparam = new SqlParameter();
-                       sqlparam.Value = value;
-                       // TODO: Get the dbtype and Sqldbtype from system type of value.
+                       if (value.Container != null)
+                               throw new ArgumentException ("The SqlParameter specified in the value parameter is already added to this or another SqlParameterCollection.");
                        
-                       return Add(sqlparam);
+                       value.Container = this;
+                       list.Add (value);
+                       metaParameters.Add (value.MetaParameter);
+                       return value;
                }
-
                
-               public SqlParameter Add(string parameterName, SqlDbType sqlDbType)
+               public SqlParameter Add (string parameterName, object value)
                {
-                       SqlParameter sqlparam = new SqlParameter();
-                       sqlparam.ParameterName = parameterName;
-                       sqlparam.SqlDbType = sqlDbType;
-                       return Add(sqlparam);                   
+                       return Add (new SqlParameter (parameterName, value));
                }
 
+#if NET_2_0
+                public SqlParameter AddWithValue (string parameterName, object value)
+                {
+                        return Add (parameterName, value);
+               }
+#endif // NET_2_0
+
                
-               public SqlParameter Add(string parameterName,
-                       SqlDbType sqlDbType, int size)
+               public SqlParameter Add (string parameterName, SqlDbType sqlDbType)
                {
-                       SqlParameter sqlparam = new SqlParameter();
-                       sqlparam.ParameterName = parameterName;
-                       sqlparam.SqlDbType = sqlDbType;
-                       sqlparam.Size = size;
-                       return Add(sqlparam);                   
+                       return Add (new SqlParameter (parameterName, sqlDbType));
                }
 
-               
-               public SqlParameter Add(string parameterName,
-                       SqlDbType sqlDbType, int size, string sourceColumn)
+               public SqlParameter Add (string parameterName, SqlDbType sqlDbType, int size)
                {
-                       SqlParameter sqlparam = new SqlParameter();
-                       sqlparam.ParameterName = parameterName;
-                       sqlparam.SqlDbType = sqlDbType;
-                       sqlparam.Size = size;
-                       sqlparam.SourceColumn = sourceColumn;
-                       return Add(sqlparam);                   
+                       return Add (new SqlParameter (parameterName, sqlDbType, size));
                }
 
-               [MonoTODO]
-               public void Clear()
+               public SqlParameter Add (string parameterName, SqlDbType sqlDbType, int size, string sourceColumn)
                {
-                       throw new NotImplementedException ();
+                       return Add (new SqlParameter (parameterName, sqlDbType, size, sourceColumn));
                }
 
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        void Clear()
+               {
+                       metaParameters.Clear ();
+                       
+                       foreach (SqlParameter p in list)
+                               p.Container = null;
+                       
+                       list.Clear ();
+               }
                
-               public bool Contains(object value)
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        bool Contains (object value)
                {
-                       // Check if value is a SqlParameter
-                       CheckType(value);
-                       return Contains(((SqlParameter)value).ParameterName);
+                       if (!(value is SqlParameter))
+                               throw new InvalidCastException ("The parameter was not an SqlParameter.");
+                       return Contains (((SqlParameter) value).ParameterName);
                }
 
-
-               [MonoTODO]
-               public bool Contains(string value)
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        bool Contains (string value)
                {
-                       for(int p = 0; p < parameterList.Count; p++) {
-                               if(((SqlParameter)parameterList[p]).ParameterName.Equals(value))
+                       foreach (SqlParameter p in list)
+                               if (p.ParameterName.Equals (value))
                                        return true;
-                       }
                        return false;
                }
+#if NET_2_0
+
+               public bool Contains (SqlParameter value) {
+       
+                       return (this.IndexOf(value) != -1);
+               }       
+
+#endif // NET_2_0
 
-               [MonoTODO]
-               public void CopyTo(Array array, int index)
+
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        void CopyTo (Array array, int index)
                {
-                       throw new NotImplementedException ();
+                       list.CopyTo (array, index);
                }
 
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        IEnumerator GetEnumerator()
+               {
+                       return list.GetEnumerator ();
+               }
                
-               public int IndexOf(object value)
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        int IndexOf (object value)
                {
-                       // Check if value is a SqlParameter
-                       CheckType(value);
-                       return IndexOf(((SqlParameter)value).ParameterName);
+                       if (!(value is SqlParameter))
+                               throw new InvalidCastException ("The parameter was not an SqlParameter.");
+                       return IndexOf (((SqlParameter) value).ParameterName);
                }
-
                
-               public int IndexOf(string parameterName)
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        int IndexOf (string parameterName)
                {
-                       int p = -1;
+                       for (int i = 0; i < Count; i += 1)
+                                if (this [i].ParameterName.Equals (parameterName))
+                                        return i;
+                        return -1;
 
-                       for(p = 0; p < parameterList.Count; p++) {
-                               if(((SqlParameter)parameterList[p]).ParameterName.Equals(parameterName))
-                                       return p;
-                       }
-                       return p;
                }
 
-               [MonoTODO]
-               public void Insert(int index, object value)
-               {
-                       throw new NotImplementedException ();
+#if NET_2_0
+               public int IndexOf (SqlParameter value) {
+                               return list.IndexOf(value);
                }
+               
+#endif // NET_2_0
 
-               [MonoTODO]
-               public void Remove(object value)
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        void Insert (int index, object value)
                {
-                       throw new NotImplementedException ();
+                       list.Insert (index, value);
                }
 
-               [MonoTODO]
-               public void RemoveAt(int index)
-               {
-                       throw new NotImplementedException ();
+#if NET_2_0
+               public void Insert (int index, SqlParameter value) {
+                       list.Insert (index,value);
                }
 
-               [MonoTODO]
-               public void RemoveAt(string parameterName)
-               {
-                       throw new NotImplementedException ();
-               }
-       
-               [MonoTODO]
-               public int Count {
-                       get {   
-                               return parameterList.Count;
-                       }                         
-               }
+#endif //NET_2_0       
 
-               object IList.this[int index] {
-                       [MonoTODO]
-                       get { 
-                               return (SqlParameter) this[index];
-                       }
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        void Remove (object value)
+               {
+                       //TODO : this neds validation to check if the object is a 
+                       // sqlparameter.
+                                       
+                       ((SqlParameter) value).Container = null;
                        
-                       [MonoTODO]
-                       set { 
-                               this[index] = (SqlParameter) value;
-                       }
+                       metaParameters.Remove (((SqlParameter) value).MetaParameter);
+                       list.Remove (value);
                }
 
-               public SqlParameter this[int index] {
-                       get {   
-                               return (SqlParameter) parameterList[index];
-                       }                         
-                       
-                       set {   
-                               parameterList[index] = (SqlParameter) value;
-                       }                         
-               }
 
-               object IDataParameterCollection.this[string parameterName] {
-                       [MonoTODO]
-                       get { 
-                               return this[parameterName];
-                       }
-                       
-                       [MonoTODO]
-                       set { 
-                               CheckType(value);
-                               this[parameterName] = (SqlParameter) value;
-                       }
-               }
+#if NET_2_0
+               public void Remove (SqlParameter value) {
+       
+                       //both this and the above code are the same. but need to work with
+                       // 1.1!
+                       value.Container = null;
+                       metaParameters.Remove (value.MetaParameter);
+                       list.Remove (value);
 
-               public SqlParameter this[string parameterName] {
-                       get {   
-                               for(int p = 0; p < parameterList.Count; p++) {
-                                       if(parameterName.Equals(((SqlParameter)parameterList[p]).ParameterName))
-                                               return (SqlParameter) parameterList[p];
-                               }
-                               throw new IndexOutOfRangeException("The specified name does not exist: " + parameterName);
-                       }         
-                       
-                       set {   
-                               for(int p = 0; p < parameterList.Count; p++) {
-                                       if(parameterName.Equals(((SqlParameter)parameterList[p]).ParameterName))
-                                               parameterList[p] = value;
-                               }
-                               throw new IndexOutOfRangeException("The specified name does not exist: " + parameterName);
-                       }                         
                }
 
-               bool IList.IsFixedSize {
-                       get {   
-                               throw new NotImplementedException ();
-                       }                         
+#endif //NET_2_0 
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        void RemoveAt (int index)
+               {
+                       this [index].Container = null;
+                       metaParameters.RemoveAt (index);
+                       list.RemoveAt (index);
                }
 
-               bool IList.IsReadOnly {
-                       get {   
-                               throw new NotImplementedException ();
-                       }                         
+               public 
+#if NET_2_0
+               override
+#endif // NET_2_0
+        void RemoveAt (string parameterName)
+               {
+                       RemoveAt (IndexOf (parameterName));
                }
 
-               bool ICollection.IsSynchronized {
-                       get {   
-                               throw new NotImplementedException ();
-                       }                         
-               }
+#if NET_2_0
+               public override void AddRange (Array values) {
+               
+                       if (values == null)
+                               throw new ArgumentNullException("The argument passed was null");
+                       foreach ( object value in values) {
+                          if (!(value is SqlParameter))
+                                       throw new InvalidCastException ("Element in the array parameter was not an SqlParameter.");                                                                     
+                          SqlParameter param = (SqlParameter) value;   
+                          if (param.Container != null)
+                                throw new ArgumentException ("An SqlParameter specified in the array is already added to this or another SqlParameterCollection.");
+                                                                                                    
+                        param.Container = this;
+                        list.Add (param);
+                        metaParameters.Add (param.MetaParameter);
+                        }
+       
+               }               
 
-               object ICollection.SyncRoot {
-                       get {   
-                               throw new NotImplementedException ();
-                       }                         
-               }
+               public void AddRange (SqlParameter[] values) {
                
-               /// <summary>
-               /// This method checks if the parameter value is of 
-               /// SqlParameter type. If it doesn't, throws an InvalidCastException.
-               /// </summary>
-               private void CheckType(object value)
-               {
-                       if(!(value is SqlParameter))
-                               throw new InvalidCastException("Only SQLParameter objects can be used.");
+                       this.AddRange(values);  
                }
-               
+#endif
+        
+               #endregion // Methods   
        }
 }