//
// System.ComponentModel.PropertyDescriptorCollection.cs
//
// Authors:
// Rodrigo Moya (rodrigo@ximian.com)
// Gonzalo Paniagua Javier (gonzalo@ximian.com)
// Andreas Nahr (ClassDevelopment@A-SoftTech.com)
//
// (C) Rodrigo Moya, 2002
// (c) 2002 Ximian, Inc. (http://www.ximian.com)
// (C) 2003 Andreas Nahr
//
//
// 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 System.Collections;
namespace System.ComponentModel
{
///
/// Represents a collection of PropertyDescriptor objects.
///
public class PropertyDescriptorCollection : IList, ICollection, IEnumerable, IDictionary
{
public static readonly PropertyDescriptorCollection Empty = new PropertyDescriptorCollection (null, true);
private ArrayList properties;
private bool readOnly;
public PropertyDescriptorCollection (PropertyDescriptor[] properties)
{
this.properties = new ArrayList ();
if (properties == null)
return;
this.properties.AddRange (properties);
}
public PropertyDescriptorCollection (PropertyDescriptor[] properties, bool readOnly) : this (properties)
{
this.readOnly = readOnly;
}
private PropertyDescriptorCollection ()
{
}
public int Add (PropertyDescriptor value)
{
if (readOnly) {
throw new NotSupportedException ();
}
properties.Add (value);
return properties.Count - 1;
}
int IList.Add (object value)
{
return Add ((PropertyDescriptor) value);
}
void IDictionary.Add (object key, object value)
{
if ((value as PropertyDescriptor) == null) {
throw new ArgumentException ("value");
}
Add ((PropertyDescriptor) value);
}
public void Clear ()
{
if (readOnly) {
throw new NotSupportedException ();
}
properties.Clear ();
}
void IList.Clear ()
{
Clear ();
}
void IDictionary.Clear ()
{
Clear ();
}
public bool Contains (PropertyDescriptor value)
{
return properties.Contains (value);
}
bool IList.Contains (object value)
{
return Contains ((PropertyDescriptor) value);
}
bool IDictionary.Contains (object value)
{
return Contains ((PropertyDescriptor) value);
}
public void CopyTo (Array array, int index)
{
properties.CopyTo (array, index);
}
public virtual PropertyDescriptor Find (string name, bool ignoreCase)
{
if (name == null)
throw new ArgumentNullException ("name");
for (int i = 0; i < properties.Count; ++i) {
PropertyDescriptor p = (PropertyDescriptor)properties [i];
if (ignoreCase) {
if (0 == String.Compare (name, p.Name, StringComparison.OrdinalIgnoreCase))
return p;
}
else {
if (0 == String.Compare (name, p.Name, StringComparison.Ordinal))
return p;
}
}
return null;
}
public virtual IEnumerator GetEnumerator ()
{
return properties.GetEnumerator ();
}
IEnumerator IEnumerable.GetEnumerator ()
{
return GetEnumerator ();
}
[MonoTODO]
IDictionaryEnumerator IDictionary.GetEnumerator ()
{
throw new NotImplementedException ();
}
public int IndexOf (PropertyDescriptor value)
{
return properties.IndexOf (value);
}
int IList.IndexOf (object value)
{
return IndexOf ((PropertyDescriptor) value);
}
public void Insert (int index, PropertyDescriptor value)
{
if (readOnly) {
throw new NotSupportedException ();
}
properties.Insert (index, value);
}
void IList.Insert (int index, object value)
{
Insert (index, (PropertyDescriptor) value);
}
public void Remove (PropertyDescriptor value)
{
if (readOnly) {
throw new NotSupportedException ();
}
properties.Remove (value);
}
void IDictionary.Remove (object value)
{
Remove ((PropertyDescriptor) value);
}
void IList.Remove (object value)
{
Remove ((PropertyDescriptor) value);
}
public void RemoveAt (int index)
{
if (readOnly) {
throw new NotSupportedException ();
}
properties.RemoveAt (index);
}
void IList.RemoveAt (int index)
{
RemoveAt (index);
}
private PropertyDescriptorCollection CloneCollection ()
{
PropertyDescriptorCollection col = new PropertyDescriptorCollection ();
col.properties = (ArrayList) properties.Clone ();
return col;
}
public virtual PropertyDescriptorCollection Sort ()
{
PropertyDescriptorCollection col = CloneCollection ();
col.InternalSort ((IComparer) null);
return col;
}
public virtual PropertyDescriptorCollection Sort (IComparer comparer)
{
PropertyDescriptorCollection col = CloneCollection ();
col.InternalSort (comparer);
return col;
}
public virtual PropertyDescriptorCollection Sort (string[] order)
{
PropertyDescriptorCollection col = CloneCollection ();
col.InternalSort (order);
return col;
}
public virtual PropertyDescriptorCollection Sort (string[] order, IComparer comparer)
{
PropertyDescriptorCollection col = CloneCollection ();
if (order != null) {
ArrayList sorted = col.ExtractItems (order);
col.InternalSort (comparer);
sorted.AddRange (col.properties);
col.properties = sorted;
} else {
col.InternalSort (comparer);
}
return col;
}
protected void InternalSort (IComparer ic)
{
if (ic == null)
ic = MemberDescriptor.DefaultComparer;
properties.Sort (ic);
}
protected void InternalSort (string [] order)
{
if (order != null) {
ArrayList sorted = ExtractItems (order);
InternalSort ((IComparer) null);
sorted.AddRange (properties);
properties = sorted;
} else {
InternalSort ((IComparer) null);
}
}
ArrayList ExtractItems (string[] names)
{
ArrayList sorted = new ArrayList (properties.Count);
object[] ext = new object [names.Length];
for (int n=0; n