ChangeLog: Updated
[mono.git] / mcs / class / System.Web / System.Web.UI.WebControls / ParameterCollection.cs
index be3d8a92a6f0c12c388a78b0221d720c74be5801..ffc899b609a850b6f1fd8f8a880eae25fe34a381 100644 (file)
@@ -5,9 +5,31 @@
 //
 // (C) 2003 Todd Berman
 
-#if NET_1_2
+//
+// 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.
+//
+
+#if NET_2_0
 
 using System.Web.UI;
+using System.Collections;
 using System.Collections.Specialized;
 
 namespace System.Web.UI.WebControls
@@ -30,17 +52,17 @@ namespace System.Web.UI.WebControls
 
                public int Add (Parameter param)
                {
-                       return base.Add (param);
+                       return ((IList)this).Add (param);
                }
 
                public int Add (string name, string value)
                {
-                       return base.Add (new Parameter (name, 1, value));
+                       return ((IList)this).Add (new Parameter (name, TypeCode.Object, value));
                }
 
                public int Add (string name, TypeCode type, string value)
                {
-                       return base.Add (new Parameter (name, type, value));
+                       return ((IList)this).Add (new Parameter (name, type, value));
                }
 
                protected override object CreateKnownType (int idx)
@@ -48,22 +70,16 @@ namespace System.Web.UI.WebControls
                        switch (idx) {
                        case 0:
                                return new ControlParameter ();
-                               break;
                        case 1:
-                               return new CookieParameter ();
-                               break;
+                               return new CookieParameter ();                  
                        case 2:
-                               return new FormParameter ();
-                               break;
+                               return new FormParameter ();                    
                        case 3:
-                               return new Parameter ();
-                               break;
+                               return new Parameter ();                
                        case 4:
-                               return new QueryStringParameter ();
-                               break;
+                               return new QueryStringParameter ();             
                        case 5:
-                               return new SessionParameter ();
-                               break;
+                               return new SessionParameter ();                 
                        }
 
                        throw new ArgumentOutOfRangeException ("index");
@@ -74,7 +90,8 @@ namespace System.Web.UI.WebControls
                        return _knownTypes;
                }
 
-               public IOrderedDictionary GetValues (Control control)
+               [MonoTODO ("Take care of HTTPContext parameter")]
+               public IOrderedDictionary GetValues (HttpContext context, Control control)
                {
                        if (_values == null)
                        {
@@ -94,7 +111,7 @@ namespace System.Web.UI.WebControls
                
                public void Insert (int idx, Parameter param)
                {
-                       base.Insert (idx, param);
+                       ((IList)this).Insert (idx, param);
                }
 
                protected override void OnClearComplete ()
@@ -118,7 +135,7 @@ namespace System.Web.UI.WebControls
                protected virtual void OnParametersChanged (EventArgs e)
                {
                        if (_parametersChanged != null)
-                               _parametersChanged.Invoke (this, e);
+                               _parametersChanged(this, e);
                        
                        _values = null;
                }
@@ -127,35 +144,37 @@ namespace System.Web.UI.WebControls
                {
                        base.OnValidate (o);
                        
-                       if (!o is Parameter)
+                       if ((o is Parameter) == false)
                                throw new ArgumentException ("o is not a Parameter");
                }
 
                public void Remove (Parameter param)
                {
-                       base.Remove (param);
+                       ((IList)this).Remove (param);
                }
 
                public void RemoveAt (int idx)
                {
-                       base.RemoveAr (idx);
+                       ((IList)this).RemoveAt (idx);
                }
 
                protected override void SetDirtyObject (object o)
-               {
-                       ((Parameter)o).SetDirty();
+               {\r
+                       Parameter param = (Parameter)o;\r
+                       if (Contains (param))\r
+                               param.SetDirty ();\r
                }
 
-               internal void ParametersChanged ()
+               internal void CallOnParameterChanged ()
                {
                        OnParametersChanged (EventArgs.Empty);
                }
 
-               private int Contains (string name)
+               private int IndexOfString (string name)
                {
                        for (int i = 0; i < Count; i++)
                        {
-                               if (this[i].Name == name)
+                               if (((Parameter)((IList)this)[i]).Name == name)
                                        return i;
                        }
                        return -1;
@@ -163,10 +182,10 @@ namespace System.Web.UI.WebControls
 
                public Parameter this[int idx] {
                        get {
-                               return (Parameter) base[idx];
+                               return (Parameter) ((IList)this)[idx];
                        }
                        set {
-                               base[idx] = value;
+                               ((IList)this)[idx] = value;
                        }
                }
 
@@ -175,7 +194,7 @@ namespace System.Web.UI.WebControls
                                int idx = IndexOfString (name);
                                if (idx == -1)
                                        return null;
-                               return this[idx];
+                               return ((Parameter) ((IList)this)[idx]);
                        }
                        set {
                                int idx = IndexOfString (name);
@@ -183,15 +202,36 @@ namespace System.Web.UI.WebControls
                                        Add (value);
                                        return;
                                }
-                               this[idx] = value;
+                               ((IList)this)[idx] = value;
                        }
                }
 
                public event EventHandler ParametersChanged {
-                       get { _parametersChanged += value; }
-                       set { _parametersChanged -= value; }
-               }
-                       
+                       add { _parametersChanged += value; }
+                       remove { _parametersChanged -= value; }
+               }\r
+\r
+               public bool Contains (Parameter param)\r
+               {\r
+                       return ((IList)this).Contains (param);\r
+               }\r
+\r
+               public void CopyTo (Parameter[] paramArray, int index)\r
+               {\r
+                       ((IList)this).CopyTo (paramArray, index);\r
+               }\r
+\r
+               public int IndexOf (Parameter param)\r
+               {\r
+                       return ((IList)this).IndexOf (param);\r
+               }\r
+\r
+               protected override void OnRemoveComplete (int index, object value)\r
+               {\r
+                       base.OnRemoveComplete (index, value);                   \r
+                       OnParametersChanged (EventArgs.Empty);\r
+               }\r
+               \r
        }
 }