// 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
}
}