2 // System.Collections.CollectionBase.cs
5 // Nick Drochak II (ndrochak@gol.com)
7 // (C) 2001 Nick Drochak II
11 // Copyright (C) 2004 Novell, Inc (http://www.novell.com)
13 // Permission is hereby granted, free of charge, to any person obtaining
14 // a copy of this software and associated documentation files (the
15 // "Software"), to deal in the Software without restriction, including
16 // without limitation the rights to use, copy, modify, merge, publish,
17 // distribute, sublicense, and/or sell copies of the Software, and to
18 // permit persons to whom the Software is furnished to do so, subject to
19 // the following conditions:
21 // The above copyright notice and this permission notice shall be
22 // included in all copies or substantial portions of the Software.
24 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
28 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
29 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
30 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
34 using System.Runtime.InteropServices;
36 namespace System.Collections {
40 [System.Diagnostics.DebuggerDisplay ("Count={Count}")]
41 [System.Diagnostics.DebuggerTypeProxy (typeof (CollectionDebuggerView))]
47 abstract class CollectionBase : IList, ICollection, IEnumerable {
49 // private instance properties
50 private ArrayList list;
52 // public instance properties
53 public int Count { get { return InnerList.Count; } }
55 // Public Instance Methods
56 public IEnumerator GetEnumerator() { return InnerList.GetEnumerator(); }
62 public void RemoveAt (int index) {
63 object objectToRemove;
64 objectToRemove = InnerList[index];
65 OnValidate(objectToRemove);
66 OnRemove(index, objectToRemove);
67 InnerList.RemoveAt(index);
68 OnRemoveComplete(index, objectToRemove);
71 // Protected Instance Constructors
72 protected CollectionBase()
76 protected CollectionBase (int capacity)
78 list = new ArrayList (capacity);
85 list = new ArrayList ();
92 list = new ArrayList ();
94 list.Capacity = value;
98 // Protected Instance Properties
99 protected ArrayList InnerList {
102 list = new ArrayList ();
107 protected IList List {get { return this; } }
109 // Protected Instance Methods
110 protected virtual void OnClear() { }
111 protected virtual void OnClearComplete() { }
113 protected virtual void OnInsert(int index, object value) { }
114 protected virtual void OnInsertComplete(int index, object value) { }
116 protected virtual void OnRemove(int index, object value) { }
117 protected virtual void OnRemoveComplete(int index, object value) { }
119 protected virtual void OnSet(int index, object oldValue, object newValue) { }
120 protected virtual void OnSetComplete(int index, object oldValue, object newValue) { }
122 protected virtual void OnValidate(object value) {
124 throw new System.ArgumentNullException("CollectionBase.OnValidate: Invalid parameter value passed to method: null");
128 // ICollection methods
129 void ICollection.CopyTo(Array array, int index) {
130 InnerList.CopyTo(array, index);
132 object ICollection.SyncRoot {
133 get { return InnerList.SyncRoot; }
135 bool ICollection.IsSynchronized {
136 get { return InnerList.IsSynchronized; }
140 int IList.Add (object value) {
143 newPosition = InnerList.Count;
144 OnInsert(newPosition, value);
145 InnerList.Add(value);
147 OnInsertComplete(newPosition, value);
149 InnerList.RemoveAt (newPosition);
156 bool IList.Contains (object value) {
157 return InnerList.Contains(value);
160 int IList.IndexOf (object value) {
161 return InnerList.IndexOf(value);
164 void IList.Insert (int index, object value) {
166 OnInsert(index, value);
167 InnerList.Insert(index, value);
169 OnInsertComplete(index, value);
171 InnerList.RemoveAt (index);
176 void IList.Remove (object value) {
179 removeIndex = InnerList.IndexOf(value);
180 if (removeIndex == -1)
181 throw new ArgumentException ("The element cannot be found.", "value");
182 OnRemove(removeIndex, value);
183 InnerList.Remove(value);
184 OnRemoveComplete(removeIndex, value);
188 bool IList.IsFixedSize {
189 get { return InnerList.IsFixedSize; }
192 bool IList.IsReadOnly {
193 get { return InnerList.IsReadOnly; }
196 object IList.this[int index] {
197 get { return InnerList[index]; }
199 if (index < 0 || index >= InnerList.Count)
200 throw new ArgumentOutOfRangeException ("index");
203 // make sure we have been given a valid value
205 // save a reference to the object that is in the list now
206 oldValue = InnerList[index];
208 OnSet(index, oldValue, value);
209 InnerList[index] = value;
211 OnSetComplete(index, oldValue, value);
213 InnerList[index] = oldValue;