aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/MergedCollection.cs
diff options
context:
space:
mode:
authorShlomo Hecht <shlomo@twine-s.com>2019-04-23 22:25:54 +0300
committerShlomo Hecht <shlomo@twine-s.com>2019-04-23 22:25:54 +0300
commitebcb9ce27131e4bbd14c96b5f897a67bc752aaeb (patch)
tree293aee8b1751ce7fce542645722c0f1a96b73097 /Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/MergedCollection.cs
parent52967e858bd52621208f6360e84f4c47ec435816 (diff)
parent636ad730569dfef1a4ee04c8d716d510bcc47ee1 (diff)
downloadTango-ebcb9ce27131e4bbd14c96b5f897a67bc752aaeb.tar.gz
Tango-ebcb9ce27131e4bbd14c96b5f897a67bc752aaeb.zip
merge alarm handling from remote
Diffstat (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/MergedCollection.cs')
-rw-r--r--Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/MergedCollection.cs70
1 files changed, 70 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/MergedCollection.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/MergedCollection.cs
new file mode 100644
index 000000000..79574053b
--- /dev/null
+++ b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/MergedCollection.cs
@@ -0,0 +1,70 @@
+// Copyright (c) AlphaSierraPapa for the SharpDevelop Team (for details please see \doc\copyright.txt)
+// This code is distributed under the GNU LGPL (for details please see \doc\license.txt)
+
+using System;
+using System.Collections.Generic;
+using System.Collections.ObjectModel;
+using System.Collections.Specialized;
+
+namespace Tango.Scripting.Editors.Xml
+{
+ /// <summary>
+ /// Two collections in sequence
+ /// </summary>
+ public class MergedCollection<T, TCollection> : ObservableCollection<T> where TCollection : INotifyCollectionChanged, IList<T>
+ {
+ TCollection a;
+ TCollection b;
+
+ /// <summary> Create a wrapper containing elements of 'a' and then 'b' </summary>
+ [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Naming", "CA1704:IdentifiersShouldBeSpelledCorrectly")]
+ public MergedCollection(TCollection a, TCollection b)
+ {
+ this.a = a;
+ this.b = b;
+
+ this.a.CollectionChanged += SourceCollectionAChanged;
+ this.b.CollectionChanged += SourceCollectionBChanged;
+
+ Reset();
+ }
+
+ void Reset()
+ {
+ this.Clear();
+ foreach(T item in a) this.Add(item);
+ foreach(T item in b) this.Add(item);
+ }
+
+ void SourceCollectionAChanged(object sender, NotifyCollectionChangedEventArgs e)
+ {
+ SourceCollectionChanged(0, e);
+ }
+
+ void SourceCollectionBChanged(object sender, NotifyCollectionChangedEventArgs e)
+ {
+ SourceCollectionChanged(a.Count, e);
+ }
+
+ void SourceCollectionChanged(int collectionStart, NotifyCollectionChangedEventArgs e)
+ {
+ switch(e.Action) {
+ case NotifyCollectionChangedAction.Add:
+ for (int i = 0; i < e.NewItems.Count; i++) {
+ this.InsertItem(collectionStart + e.NewStartingIndex + i, (T)e.NewItems[i]);
+ }
+ break;
+ case NotifyCollectionChangedAction.Remove:
+ for (int i = 0; i < e.OldItems.Count; i++) {
+ this.RemoveAt(collectionStart + e.OldStartingIndex);
+ }
+ break;
+ case NotifyCollectionChangedAction.Reset:
+ Reset();
+ break;
+ default:
+ throw new NotSupportedException(e.Action.ToString());
+ }
+ }
+ }
+}