aboutsummaryrefslogtreecommitdiff
path: root/source/ShiftUI/Internal/AutoCompleteStringCollection.cs
diff options
context:
space:
mode:
authorMichaelTheShifter <[email protected]>2016-07-20 09:40:36 -0400
committerMichaelTheShifter <[email protected]>2016-07-20 09:40:36 -0400
commitd40fed5ce2bc806a91245adb18039634eac13ed0 (patch)
treef1d7168aee6db109ac2c738ad18c9db667a6ba69 /source/ShiftUI/Internal/AutoCompleteStringCollection.cs
parentf1856e8ed30ed882229fd3fa2a4038122a5fb441 (diff)
downloadshiftos-c-_theultimatehacker-d40fed5ce2bc806a91245adb18039634eac13ed0.tar.gz
shiftos-c-_theultimatehacker-d40fed5ce2bc806a91245adb18039634eac13ed0.tar.bz2
shiftos-c-_theultimatehacker-d40fed5ce2bc806a91245adb18039634eac13ed0.zip
Move ShiftUI source code to ShiftOS
This'll be a lot easier to work on.
Diffstat (limited to 'source/ShiftUI/Internal/AutoCompleteStringCollection.cs')
-rw-r--r--source/ShiftUI/Internal/AutoCompleteStringCollection.cs203
1 files changed, 203 insertions, 0 deletions
diff --git a/source/ShiftUI/Internal/AutoCompleteStringCollection.cs b/source/ShiftUI/Internal/AutoCompleteStringCollection.cs
new file mode 100644
index 0000000..2142d47
--- /dev/null
+++ b/source/ShiftUI/Internal/AutoCompleteStringCollection.cs
@@ -0,0 +1,203 @@
+//
+// AutoCompleteStringCollection.cs
+//
+// 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.
+//
+// Copyright (c) 2006 Daniel Nauck
+//
+// Author:
+// Daniel Nauck (dna(at)mono-project(dot)de)
+
+
+using System;
+using System.Collections;
+using System.ComponentModel;
+using System.Reflection;
+
+namespace ShiftUI
+{
+ public class AutoCompleteStringCollection : IList, ICollection, IEnumerable
+ {
+ private ArrayList list = null;
+
+ public AutoCompleteStringCollection ()
+ {
+ list = new ArrayList ();
+ }
+
+ public event CollectionChangeEventHandler CollectionChanged;
+
+ protected void OnCollectionChanged (CollectionChangeEventArgs e)
+ {
+ if(CollectionChanged == null)
+ return;
+
+ CollectionChanged (this, e);
+ }
+
+ #region IEnumerable Members
+
+ public IEnumerator GetEnumerator ()
+ {
+ return list.GetEnumerator ();
+ }
+
+ #endregion
+
+ #region ICollection Members
+
+ void ICollection.CopyTo (Array array, int index)
+ {
+ list.CopyTo (array, index);
+ }
+
+ public void CopyTo (string[] array, int index)
+ {
+ list.CopyTo (array, index);
+ }
+
+ public int Count
+ {
+ get { return list.Count; }
+ }
+
+ public bool IsSynchronized
+ {
+ get { return false; }
+ }
+
+ public object SyncRoot
+ {
+ get { return this; }
+ }
+
+ #endregion
+
+ #region IList Members
+
+ int IList.Add (object value)
+ {
+ return Add ((string)value);
+ }
+
+ public int Add (string value)
+ {
+ int index = list.Add (value);
+ OnCollectionChanged (new CollectionChangeEventArgs (CollectionChangeAction.Add, value));
+ return index;
+ }
+
+ public void AddRange (string[] value)
+ {
+ if (value == null)
+ throw new ArgumentNullException ("value", "Argument cannot be null!");
+
+ list.AddRange (value);
+ OnCollectionChanged (new CollectionChangeEventArgs (CollectionChangeAction.Refresh, null));
+ }
+
+ public void Clear ()
+ {
+ list.Clear ();
+ OnCollectionChanged (new CollectionChangeEventArgs (CollectionChangeAction.Refresh, null));
+ }
+
+ bool IList.Contains (object value)
+ {
+ return Contains ((string)value);
+ }
+
+ public bool Contains (string value)
+ {
+ return list.Contains (value);
+ }
+
+ int IList.IndexOf (object value)
+ {
+ return IndexOf ((string)value);
+ }
+
+ public int IndexOf (string value)
+ {
+ return list.IndexOf (value);
+ }
+
+ void IList.Insert (int index, object value)
+ {
+ Insert (index, (string)value);
+ }
+
+ public void Insert (int index, string value)
+ {
+ list.Insert (index, value);
+ OnCollectionChanged (new CollectionChangeEventArgs (CollectionChangeAction.Add, value));
+ }
+
+ bool IList.IsFixedSize
+ {
+ get { return false; }
+ }
+
+ bool IList.IsReadOnly
+ {
+ get { return false; }
+ }
+
+ public bool IsReadOnly
+ {
+ get { return false; }
+ }
+
+ void IList.Remove (object value)
+ {
+ Remove((string)value);
+ }
+
+ public void Remove (string value)
+ {
+ list.Remove (value);
+ OnCollectionChanged (new CollectionChangeEventArgs (CollectionChangeAction.Remove, value));
+ }
+
+ public void RemoveAt (int index)
+ {
+ string value = this[index];
+ list.RemoveAt (index);
+ OnCollectionChanged (new CollectionChangeEventArgs (CollectionChangeAction.Remove, value));
+ }
+
+ object IList.this[int index]
+ {
+ get { return this[index]; }
+ set { this[index] = (string)value; }
+ }
+
+ public string this[int index]
+ {
+ get { return (string)list[index]; }
+ set {
+ OnCollectionChanged (new CollectionChangeEventArgs (CollectionChangeAction.Remove, list[index]));
+ list[index] = value;
+ OnCollectionChanged (new CollectionChangeEventArgs (CollectionChangeAction.Add, value));
+ }
+ }
+ #endregion
+ }
+}